2016-02-12 17:53:07 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace LeagueTests\Grant;
|
|
|
|
|
|
|
|
use League\Event\Emitter;
|
2016-03-28 16:42:34 +02:00
|
|
|
use League\OAuth2\Server\CryptKey;
|
2016-04-09 15:25:45 +01:00
|
|
|
use League\OAuth2\Server\Entities\AccessTokenEntityInterface;
|
|
|
|
use League\OAuth2\Server\Entities\AuthCodeEntityInterface;
|
|
|
|
use League\OAuth2\Server\Entities\RefreshTokenEntityInterface;
|
2016-02-12 17:53:07 +00:00
|
|
|
use League\OAuth2\Server\Grant\AbstractGrant;
|
2016-02-18 12:07:50 +00:00
|
|
|
use League\OAuth2\Server\Repositories\AccessTokenRepositoryInterface;
|
|
|
|
use League\OAuth2\Server\Repositories\AuthCodeRepositoryInterface;
|
2016-02-19 18:09:39 -05:00
|
|
|
use League\OAuth2\Server\Repositories\ClientRepositoryInterface;
|
|
|
|
use League\OAuth2\Server\Repositories\RefreshTokenRepositoryInterface;
|
|
|
|
use League\OAuth2\Server\Repositories\ScopeRepositoryInterface;
|
2016-04-10 15:58:01 +01:00
|
|
|
use League\OAuth2\Server\RequestTypes\AuthorizationRequest;
|
2016-04-09 15:44:38 +01:00
|
|
|
use LeagueTests\Stubs\AccessTokenEntity;
|
2016-04-09 10:46:40 -04:00
|
|
|
use LeagueTests\Stubs\AuthCodeEntity;
|
|
|
|
use LeagueTests\Stubs\ClientEntity;
|
2016-04-09 15:44:38 +01:00
|
|
|
use LeagueTests\Stubs\RefreshTokenEntity;
|
2016-03-15 01:10:47 +01:00
|
|
|
use LeagueTests\Stubs\ScopeEntity;
|
2016-02-12 17:53:07 +00:00
|
|
|
use Zend\Diactoros\ServerRequest;
|
|
|
|
|
|
|
|
class AbstractGrantTest extends \PHPUnit_Framework_TestCase
|
|
|
|
{
|
|
|
|
public function testGetSet()
|
|
|
|
{
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
2016-03-28 16:42:34 +02:00
|
|
|
$grantMock->setPrivateKey(new CryptKey(__DIR__ . '/../Stubs/private.key'));
|
|
|
|
$grantMock->setPublicKey(new CryptKey(__DIR__ . '/../Stubs/public.key'));
|
2016-02-12 17:53:07 +00:00
|
|
|
$grantMock->setEmitter(new Emitter());
|
|
|
|
}
|
|
|
|
|
2016-02-18 11:36:20 +00:00
|
|
|
public function testValidateClientPublic()
|
2016-02-12 17:53:07 +00:00
|
|
|
{
|
|
|
|
$client = new ClientEntity();
|
2016-02-18 11:36:20 +00:00
|
|
|
|
|
|
|
$clientRepositoryMock = $this->getMockBuilder(ClientRepositoryInterface::class)->getMock();
|
|
|
|
$clientRepositoryMock->method('getClientEntity')->willReturn($client);
|
|
|
|
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setClientRepository($clientRepositoryMock);
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$serverRequest = $serverRequest->withParsedBody(
|
|
|
|
[
|
|
|
|
'client_id' => 'foo',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
$validateClientMethod = $abstractGrantReflection->getMethod('validateClient');
|
|
|
|
$validateClientMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$result = $validateClientMethod->invoke($grantMock, $serverRequest, true, true);
|
|
|
|
$this->assertEquals($client, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testValidateClientConfidential()
|
|
|
|
{
|
|
|
|
$client = new ClientEntity();
|
|
|
|
|
2016-02-12 17:53:07 +00:00
|
|
|
$clientRepositoryMock = $this->getMockBuilder(ClientRepositoryInterface::class)->getMock();
|
|
|
|
$clientRepositoryMock->method('getClientEntity')->willReturn($client);
|
|
|
|
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setClientRepository($clientRepositoryMock);
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$serverRequest = $serverRequest->withParsedBody(
|
|
|
|
[
|
|
|
|
'client_id' => 'foo',
|
|
|
|
'client_secret' => 'bar',
|
|
|
|
'redirect_uri' => 'http://foo/bar',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
$validateClientMethod = $abstractGrantReflection->getMethod('validateClient');
|
|
|
|
$validateClientMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$result = $validateClientMethod->invoke($grantMock, $serverRequest, true, true);
|
|
|
|
$this->assertEquals($client, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException \League\OAuth2\Server\Exception\OAuthServerException
|
|
|
|
*/
|
|
|
|
public function testValidateClientMissingClientId()
|
|
|
|
{
|
|
|
|
$client = new ClientEntity();
|
|
|
|
$clientRepositoryMock = $this->getMockBuilder(ClientRepositoryInterface::class)->getMock();
|
|
|
|
$clientRepositoryMock->method('getClientEntity')->willReturn($client);
|
|
|
|
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setClientRepository($clientRepositoryMock);
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$validateClientMethod = $abstractGrantReflection->getMethod('validateClient');
|
|
|
|
$validateClientMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$validateClientMethod->invoke($grantMock, $serverRequest, true, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException \League\OAuth2\Server\Exception\OAuthServerException
|
|
|
|
*/
|
|
|
|
public function testValidateClientMissingClientSecret()
|
|
|
|
{
|
|
|
|
$clientRepositoryMock = $this->getMockBuilder(ClientRepositoryInterface::class)->getMock();
|
2016-03-22 16:29:04 +00:00
|
|
|
$clientRepositoryMock->method('getClientEntity')->willReturn(null);
|
2016-02-12 17:53:07 +00:00
|
|
|
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setClientRepository($clientRepositoryMock);
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$serverRequest = $serverRequest->withParsedBody([
|
|
|
|
'client_id' => 'foo',
|
|
|
|
]);
|
|
|
|
|
|
|
|
$validateClientMethod = $abstractGrantReflection->getMethod('validateClient');
|
|
|
|
$validateClientMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$validateClientMethod->invoke($grantMock, $serverRequest, true, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException \League\OAuth2\Server\Exception\OAuthServerException
|
|
|
|
*/
|
2016-02-18 11:36:20 +00:00
|
|
|
public function testValidateClientInvalidClientSecret()
|
2016-02-12 17:53:07 +00:00
|
|
|
{
|
|
|
|
$clientRepositoryMock = $this->getMockBuilder(ClientRepositoryInterface::class)->getMock();
|
2016-03-22 16:29:04 +00:00
|
|
|
$clientRepositoryMock->method('getClientEntity')->willReturn(null);
|
2016-02-12 17:53:07 +00:00
|
|
|
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setClientRepository($clientRepositoryMock);
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$serverRequest = $serverRequest->withParsedBody([
|
2016-02-19 18:09:39 -05:00
|
|
|
'client_id' => 'foo',
|
2016-02-18 11:36:20 +00:00
|
|
|
'client_secret' => 'foo',
|
2016-02-12 17:53:07 +00:00
|
|
|
]);
|
|
|
|
|
|
|
|
$validateClientMethod = $abstractGrantReflection->getMethod('validateClient');
|
|
|
|
$validateClientMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$validateClientMethod->invoke($grantMock, $serverRequest, true, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException \League\OAuth2\Server\Exception\OAuthServerException
|
|
|
|
*/
|
2016-02-18 11:36:20 +00:00
|
|
|
public function testValidateClientInvalidRedirectUri()
|
2016-02-12 17:53:07 +00:00
|
|
|
{
|
|
|
|
$client = new ClientEntity();
|
2016-02-18 11:36:20 +00:00
|
|
|
$client->setRedirectUri('http://foo/bar');
|
2016-02-12 17:53:07 +00:00
|
|
|
$clientRepositoryMock = $this->getMockBuilder(ClientRepositoryInterface::class)->getMock();
|
|
|
|
$clientRepositoryMock->method('getClientEntity')->willReturn($client);
|
|
|
|
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setClientRepository($clientRepositoryMock);
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$serverRequest = $serverRequest->withParsedBody([
|
2016-04-09 15:44:38 +01:00
|
|
|
'client_id' => 'foo',
|
|
|
|
'redirect_uri' => 'http://bar/foo',
|
2016-02-12 17:53:07 +00:00
|
|
|
]);
|
|
|
|
|
|
|
|
$validateClientMethod = $abstractGrantReflection->getMethod('validateClient');
|
|
|
|
$validateClientMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$validateClientMethod->invoke($grantMock, $serverRequest, true, true);
|
|
|
|
}
|
|
|
|
|
2016-02-18 11:36:20 +00:00
|
|
|
/**
|
|
|
|
* @expectedException \League\OAuth2\Server\Exception\OAuthServerException
|
2016-04-09 13:36:08 +01:00
|
|
|
*/
|
|
|
|
public function testValidateClientInvalidRedirectUriArray()
|
|
|
|
{
|
|
|
|
$client = new ClientEntity();
|
|
|
|
$client->setRedirectUri(['http://foo/bar']);
|
|
|
|
$clientRepositoryMock = $this->getMockBuilder(ClientRepositoryInterface::class)->getMock();
|
|
|
|
$clientRepositoryMock->method('getClientEntity')->willReturn($client);
|
|
|
|
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setClientRepository($clientRepositoryMock);
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$serverRequest = $serverRequest->withParsedBody([
|
2016-04-09 15:44:38 +01:00
|
|
|
'client_id' => 'foo',
|
|
|
|
'redirect_uri' => 'http://bar/foo',
|
2016-04-09 13:36:08 +01:00
|
|
|
]);
|
|
|
|
|
|
|
|
$validateClientMethod = $abstractGrantReflection->getMethod('validateClient');
|
|
|
|
$validateClientMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$validateClientMethod->invoke($grantMock, $serverRequest, true, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException \League\OAuth2\Server\Exception\OAuthServerException
|
2016-02-18 11:36:20 +00:00
|
|
|
*/
|
|
|
|
public function testValidateClientBadClient()
|
|
|
|
{
|
|
|
|
$clientRepositoryMock = $this->getMockBuilder(ClientRepositoryInterface::class)->getMock();
|
|
|
|
$clientRepositoryMock->method('getClientEntity')->willReturn(null);
|
|
|
|
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setClientRepository($clientRepositoryMock);
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$serverRequest = $serverRequest->withParsedBody([
|
|
|
|
'client_id' => 'foo',
|
|
|
|
'client_secret' => 'bar',
|
|
|
|
]);
|
|
|
|
|
|
|
|
$validateClientMethod = $abstractGrantReflection->getMethod('validateClient');
|
|
|
|
$validateClientMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$validateClientMethod->invoke($grantMock, $serverRequest, true);
|
|
|
|
}
|
|
|
|
|
2016-02-12 17:53:07 +00:00
|
|
|
public function testCanRespondToRequest()
|
|
|
|
{
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->method('getIdentifier')->willReturn('foobar');
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$serverRequest = $serverRequest->withParsedBody([
|
|
|
|
'grant_type' => 'foobar',
|
|
|
|
]);
|
|
|
|
|
2016-04-10 10:28:12 +01:00
|
|
|
$this->assertTrue($grantMock->canRespondToAccessTokenRequest($serverRequest));
|
2016-02-12 17:53:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testIssueRefreshToken()
|
|
|
|
{
|
2016-02-18 12:07:50 +00:00
|
|
|
$refreshTokenRepoMock = $this->getMock(RefreshTokenRepositoryInterface::class);
|
2016-03-25 14:09:26 +01:00
|
|
|
$refreshTokenRepoMock
|
|
|
|
->expects($this->once())
|
|
|
|
->method('getNewRefreshToken')
|
|
|
|
->willReturn(new RefreshTokenEntity());
|
2016-02-18 12:07:50 +00:00
|
|
|
|
2016-02-12 17:53:07 +00:00
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setRefreshTokenTTL(new \DateInterval('PT1M'));
|
2016-02-18 12:07:50 +00:00
|
|
|
$grantMock->setRefreshTokenRepository($refreshTokenRepoMock);
|
2016-02-12 17:53:07 +00:00
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
$issueRefreshTokenMethod = $abstractGrantReflection->getMethod('issueRefreshToken');
|
|
|
|
$issueRefreshTokenMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$accessToken = new AccessTokenEntity();
|
|
|
|
/** @var RefreshTokenEntityInterface $refreshToken */
|
|
|
|
$refreshToken = $issueRefreshTokenMethod->invoke($grantMock, $accessToken);
|
|
|
|
$this->assertTrue($refreshToken instanceof RefreshTokenEntityInterface);
|
|
|
|
$this->assertFalse($refreshToken->isExpired());
|
|
|
|
$this->assertEquals($accessToken, $refreshToken->getAccessToken());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testIssueAccessToken()
|
|
|
|
{
|
2016-02-18 12:07:50 +00:00
|
|
|
$accessTokenRepoMock = $this->getMock(AccessTokenRepositoryInterface::class);
|
2016-03-25 14:09:26 +01:00
|
|
|
$accessTokenRepoMock->method('getNewToken')->willReturn(new AccessTokenEntity());
|
2016-02-18 12:07:50 +00:00
|
|
|
|
2016-02-12 17:53:07 +00:00
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
2016-02-18 12:07:50 +00:00
|
|
|
$grantMock->setAccessTokenRepository($accessTokenRepoMock);
|
2016-02-12 17:53:07 +00:00
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
$issueAccessTokenMethod = $abstractGrantReflection->getMethod('issueAccessToken');
|
|
|
|
$issueAccessTokenMethod->setAccessible(true);
|
|
|
|
|
|
|
|
/** @var AccessTokenEntityInterface $accessToken */
|
|
|
|
$accessToken = $issueAccessTokenMethod->invoke(
|
|
|
|
$grantMock,
|
|
|
|
new \DateInterval('PT1H'),
|
|
|
|
new ClientEntity(),
|
|
|
|
123,
|
|
|
|
[new ScopeEntity()]
|
|
|
|
);
|
|
|
|
$this->assertTrue($accessToken instanceof AccessTokenEntityInterface);
|
|
|
|
$this->assertFalse($accessToken->isExpired());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testIssueAuthCode()
|
|
|
|
{
|
2016-02-18 12:07:50 +00:00
|
|
|
$authCodeRepoMock = $this->getMock(AuthCodeRepositoryInterface::class);
|
2016-03-25 14:09:26 +01:00
|
|
|
$authCodeRepoMock->expects($this->once())->method('getNewAuthCode')->willReturn(new AuthCodeEntity());
|
2016-02-18 12:07:50 +00:00
|
|
|
|
2016-02-12 17:53:07 +00:00
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
2016-02-18 12:07:50 +00:00
|
|
|
$grantMock->setAuthCodeRepository($authCodeRepoMock);
|
2016-02-12 17:53:07 +00:00
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
$issueAuthCodeMethod = $abstractGrantReflection->getMethod('issueAuthCode');
|
|
|
|
$issueAuthCodeMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$this->assertTrue(
|
|
|
|
$issueAuthCodeMethod->invoke(
|
|
|
|
$grantMock,
|
|
|
|
new \DateInterval('PT1H'),
|
|
|
|
new ClientEntity(),
|
|
|
|
123,
|
|
|
|
'http://foo/bar',
|
|
|
|
[new ScopeEntity()]
|
|
|
|
) instanceof AuthCodeEntityInterface
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetCookieParameter()
|
|
|
|
{
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->method('getIdentifier')->willReturn('foobar');
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
$method = $abstractGrantReflection->getMethod('getCookieParameter');
|
|
|
|
$method->setAccessible(true);
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$serverRequest = $serverRequest->withCookieParams([
|
|
|
|
'foo' => 'bar',
|
|
|
|
]);
|
|
|
|
|
|
|
|
$this->assertEquals('bar', $method->invoke($grantMock, 'foo', $serverRequest));
|
|
|
|
$this->assertEquals('foo', $method->invoke($grantMock, 'bar', $serverRequest, 'foo'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetQueryStringParameter()
|
|
|
|
{
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->method('getIdentifier')->willReturn('foobar');
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
$method = $abstractGrantReflection->getMethod('getQueryStringParameter');
|
|
|
|
$method->setAccessible(true);
|
|
|
|
|
|
|
|
$serverRequest = new ServerRequest();
|
|
|
|
$serverRequest = $serverRequest->withQueryParams([
|
|
|
|
'foo' => 'bar',
|
|
|
|
]);
|
|
|
|
|
|
|
|
$this->assertEquals('bar', $method->invoke($grantMock, 'foo', $serverRequest));
|
|
|
|
$this->assertEquals('foo', $method->invoke($grantMock, 'bar', $serverRequest, 'foo'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testValidateScopes()
|
|
|
|
{
|
|
|
|
$scope = new ScopeEntity();
|
|
|
|
$scopeRepositoryMock = $this->getMockBuilder(ScopeRepositoryInterface::class)->getMock();
|
|
|
|
$scopeRepositoryMock->method('getScopeEntityByIdentifier')->willReturn($scope);
|
|
|
|
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setScopeRepository($scopeRepositoryMock);
|
|
|
|
|
2016-04-10 13:53:16 +01:00
|
|
|
$this->assertEquals([$scope], $grantMock->validateScopes('basic '));
|
2016-02-12 17:53:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException \League\OAuth2\Server\Exception\OAuthServerException
|
|
|
|
*/
|
|
|
|
public function testValidateScopesBadScope()
|
|
|
|
{
|
|
|
|
$scopeRepositoryMock = $this->getMockBuilder(ScopeRepositoryInterface::class)->getMock();
|
|
|
|
$scopeRepositoryMock->method('getScopeEntityByIdentifier')->willReturn(null);
|
|
|
|
|
|
|
|
/** @var AbstractGrant $grantMock */
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setScopeRepository($scopeRepositoryMock);
|
|
|
|
|
2016-04-10 13:53:16 +01:00
|
|
|
$grantMock->validateScopes('basic ');
|
2016-02-12 17:53:07 +00:00
|
|
|
}
|
2016-02-18 18:14:59 +01:00
|
|
|
|
|
|
|
public function testGenerateUniqueIdentifier()
|
|
|
|
{
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
|
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
|
|
|
$method = $abstractGrantReflection->getMethod('generateUniqueIdentifier');
|
|
|
|
$method->setAccessible(true);
|
|
|
|
|
|
|
|
$this->assertTrue(is_string($method->invoke($grantMock)));
|
|
|
|
}
|
2016-04-10 15:58:01 +01:00
|
|
|
|
|
|
|
public function testCanRespondToAuthorizationRequest()
|
|
|
|
{
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$this->assertFalse($grantMock->canRespondToAuthorizationRequest(new ServerRequest()));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException \LogicException
|
|
|
|
*/
|
|
|
|
public function testValidateAuthorizationRequest()
|
|
|
|
{
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->validateAuthorizationRequest(new ServerRequest());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException \LogicException
|
|
|
|
*/
|
|
|
|
public function testCompleteAuthorizationRequest()
|
|
|
|
{
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->completeAuthorizationRequest(new AuthorizationRequest());
|
|
|
|
}
|
2016-02-12 17:53:07 +00:00
|
|
|
}
|