2014-01-17 10:36:57 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace LeagueTests\Grant;
|
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
use LeagueTests\Stubs\StubAbstractGrant;
|
2014-02-24 14:42:22 +00:00
|
|
|
use League\OAuth2\Server\AuthorizationServer;
|
2014-11-08 18:26:12 +00:00
|
|
|
use League\OAuth2\Server\Entity\ClientEntity;
|
|
|
|
use League\OAuth2\Server\Entity\ScopeEntity;
|
2014-05-01 14:33:11 +01:00
|
|
|
use League\OAuth2\Server\Exception\InvalidRequestException;
|
2014-11-08 18:26:12 +00:00
|
|
|
use League\OAuth2\Server\Grant;
|
2014-01-17 10:36:57 +00:00
|
|
|
use Mockery as M;
|
|
|
|
|
|
|
|
class AbstractGrantTest extends \PHPUnit_Framework_TestCase
|
|
|
|
{
|
2014-05-03 10:55:25 +01:00
|
|
|
public function testSetGet()
|
2014-01-17 10:36:57 +00:00
|
|
|
{
|
2014-11-08 18:26:12 +00:00
|
|
|
$server = new AuthorizationServer();
|
2014-01-17 10:36:57 +00:00
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
$grant = new StubAbstractGrant();
|
2014-01-17 10:36:57 +00:00
|
|
|
$grant->setIdentifier('foobar');
|
|
|
|
$grant->setAccessTokenTTL(300);
|
|
|
|
$grant->setAuthorizationServer($server);
|
|
|
|
|
|
|
|
$this->assertEquals('foobar', $grant->getIdentifier());
|
|
|
|
$this->assertEquals('foobar', $grant->getResponseType());
|
|
|
|
$this->assertEquals(300, $grant->getAccessTokenTTL());
|
2014-02-24 14:42:22 +00:00
|
|
|
$this->assertTrue($grant->getAuthorizationServer() instanceof AuthorizationServer);
|
2014-01-17 10:36:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testFormatScopes()
|
|
|
|
{
|
|
|
|
$server = M::mock('League\OAuth2\Server\AbstractServer');
|
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
$grant = new StubAbstractGrant();
|
2014-01-17 10:36:57 +00:00
|
|
|
$reflectedGrant = new \ReflectionClass('LeagueTests\Stubs\StubAbstractGrant');
|
|
|
|
$method = $reflectedGrant->getMethod('formatScopes');
|
|
|
|
$method->setAccessible(true);
|
|
|
|
|
|
|
|
$scopes = [
|
2014-07-11 18:19:10 +01:00
|
|
|
(new ScopeEntity($server))->hydrate(['id' => 'scope1', 'description' => 'foo']),
|
2014-11-08 18:26:12 +00:00
|
|
|
(new ScopeEntity($server))->hydrate(['id' => 'scope2', 'description' => 'bar']),
|
2014-01-17 10:36:57 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
$result = $method->invokeArgs($grant, [$scopes]);
|
|
|
|
|
|
|
|
$this->assertTrue(isset($result['scope1']));
|
|
|
|
$this->assertTrue(isset($result['scope2']));
|
2014-05-02 17:21:53 +01:00
|
|
|
$this->assertTrue($result['scope1'] instanceof ScopeEntity);
|
|
|
|
$this->assertTrue($result['scope2'] instanceof ScopeEntity);
|
2014-01-17 10:36:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testValidateScopes()
|
|
|
|
{
|
2014-11-08 18:26:12 +00:00
|
|
|
$server = new AuthorizationServer();
|
2014-01-17 10:36:57 +00:00
|
|
|
|
|
|
|
$scopeStorage = M::mock('League\OAuth2\Server\Storage\ScopeInterface');
|
|
|
|
$scopeStorage->shouldReceive('setServer');
|
|
|
|
$scopeStorage->shouldReceive('get')->andReturn(
|
2014-07-11 18:19:10 +01:00
|
|
|
(new ScopeEntity($server))->hydrate(['id' => 'foo'])
|
2014-01-17 10:36:57 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$server->setScopeStorage($scopeStorage);
|
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
$grant = new StubAbstractGrant();
|
2014-01-17 10:36:57 +00:00
|
|
|
$grant->setAuthorizationServer($server);
|
|
|
|
|
2014-09-30 23:55:21 +01:00
|
|
|
$client = (new ClientEntity($server))->hydrate(['id' => 'testapp']);
|
|
|
|
|
2014-01-17 10:36:57 +00:00
|
|
|
$this->assertEquals(
|
|
|
|
[
|
2014-11-08 18:26:12 +00:00
|
|
|
'foo' => (new ScopeEntity($server))->hydrate(['id' => 'foo']),
|
2014-01-17 10:36:57 +00:00
|
|
|
],
|
2014-09-30 23:55:21 +01:00
|
|
|
$grant->validateScopes('foo', $client)
|
2014-01-17 10:36:57 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testValidateScopesMissingScope()
|
|
|
|
{
|
2014-05-01 14:33:11 +01:00
|
|
|
$this->setExpectedException('League\OAuth2\Server\Exception\InvalidRequestException');
|
2014-01-17 10:36:57 +00:00
|
|
|
|
|
|
|
$scopeStorage = M::mock('League\OAuth2\Server\Storage\ScopeInterface');
|
|
|
|
$scopeStorage->shouldReceive('setServer');
|
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
$server = new AuthorizationServer();
|
2014-01-17 10:36:57 +00:00
|
|
|
$server->requireScopeParam(true);
|
|
|
|
$server->setScopeStorage($scopeStorage);
|
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
$grant = new StubAbstractGrant();
|
2014-01-17 10:36:57 +00:00
|
|
|
$grant->setAuthorizationServer($server);
|
|
|
|
|
2014-09-30 23:55:21 +01:00
|
|
|
$client = (new ClientEntity($server))->hydrate(['id' => 'testapp']);
|
|
|
|
|
|
|
|
$grant->validateScopes(null, $client);
|
2014-01-17 10:36:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testValidateScopesInvalidScope()
|
|
|
|
{
|
2014-05-01 14:33:11 +01:00
|
|
|
$this->setExpectedException('League\OAuth2\Server\Exception\InvalidScopeException');
|
2014-01-17 10:36:57 +00:00
|
|
|
|
|
|
|
$scopeStorage = M::mock('League\OAuth2\Server\Storage\ScopeInterface');
|
|
|
|
$scopeStorage->shouldReceive('setServer');
|
|
|
|
$scopeStorage->shouldReceive('get')->andReturn(null);
|
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
$server = new AuthorizationServer();
|
2014-01-17 10:36:57 +00:00
|
|
|
$server->setScopeStorage($scopeStorage);
|
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
$grant = new StubAbstractGrant();
|
2014-01-17 10:36:57 +00:00
|
|
|
$grant->setAuthorizationServer($server);
|
|
|
|
|
2014-09-30 23:55:21 +01:00
|
|
|
$client = (new ClientEntity($server))->hydrate(['id' => 'testapp']);
|
|
|
|
|
|
|
|
$grant->validateScopes('blah', $client);
|
2014-01-17 10:36:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testValidateScopesDefaultScope()
|
|
|
|
{
|
2014-11-08 18:26:12 +00:00
|
|
|
$server = new AuthorizationServer();
|
2014-01-17 10:36:57 +00:00
|
|
|
|
|
|
|
$scopeStorage = M::mock('League\OAuth2\Server\Storage\ScopeInterface');
|
|
|
|
$scopeStorage->shouldReceive('setServer');
|
|
|
|
$scopeStorage->shouldReceive('get')->andReturn(
|
2014-07-11 18:19:10 +01:00
|
|
|
(new ScopeEntity($server))->hydrate(['id' => 'foo'])
|
2014-01-17 10:36:57 +00:00
|
|
|
);
|
|
|
|
$server->setScopeStorage($scopeStorage);
|
|
|
|
|
|
|
|
$server->requireScopeParam(true);
|
|
|
|
$server->setScopeStorage($scopeStorage);
|
|
|
|
$server->setDefaultScope('foo');
|
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
$grant = new StubAbstractGrant();
|
2014-01-17 10:36:57 +00:00
|
|
|
$grant->setAuthorizationServer($server);
|
|
|
|
|
2014-09-30 23:55:21 +01:00
|
|
|
$client = (new ClientEntity($server))->hydrate(['id' => 'testapp']);
|
|
|
|
|
|
|
|
$grant->validateScopes(null, $client);
|
2014-01-17 10:36:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testValidateScopesDefaultScopeArray()
|
|
|
|
{
|
2014-11-08 18:26:12 +00:00
|
|
|
$server = new AuthorizationServer();
|
2014-01-17 10:36:57 +00:00
|
|
|
|
|
|
|
$scopeStorage = M::mock('League\OAuth2\Server\Storage\ScopeInterface');
|
|
|
|
$scopeStorage->shouldReceive('setServer');
|
|
|
|
$scopeStorage->shouldReceive('get')->andReturn(
|
2014-07-11 18:19:10 +01:00
|
|
|
(new ScopeEntity($server))->hydrate(['id' => 'foo'])
|
2014-01-17 10:36:57 +00:00
|
|
|
);
|
|
|
|
$server->setScopeStorage($scopeStorage);
|
|
|
|
|
|
|
|
$server->requireScopeParam(true);
|
|
|
|
$server->setScopeStorage($scopeStorage);
|
|
|
|
$server->setDefaultScope(['foo', 'bar']);
|
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
$grant = new StubAbstractGrant();
|
2014-01-17 10:36:57 +00:00
|
|
|
$grant->setAuthorizationServer($server);
|
|
|
|
|
2014-09-30 23:55:21 +01:00
|
|
|
$client = (new ClientEntity($server))->hydrate(['id' => 'testapp']);
|
|
|
|
|
|
|
|
$grant->validateScopes(null, $client);
|
2014-01-17 10:36:57 +00:00
|
|
|
}
|
|
|
|
}
|