mirror of
https://github.com/elyby/oauth2-server.git
synced 2024-11-27 01:02:12 +05:30
39 lines
1.4 KiB
PHP
39 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace LeagueTests\AuthorizationValidators;
|
|
|
|
use Lcobucci\JWT\Builder;
|
|
use League\OAuth2\Server\AuthorizationValidators\BearerTokenValidator;
|
|
use League\OAuth2\Server\CryptKey;
|
|
use League\OAuth2\Server\Repositories\AccessTokenRepositoryInterface;
|
|
use PHPUnit\Framework\TestCase;
|
|
use Zend\Diactoros\ServerRequest;
|
|
|
|
class BearerTokenValidatorTest extends TestCase
|
|
{
|
|
public function testThrowExceptionWhenAccessTokenIsNotSigned()
|
|
{
|
|
$accessTokenRepositoryMock = $this->getMockBuilder(AccessTokenRepositoryInterface::class)->getMock();
|
|
|
|
$bearerTokenValidator = new BearerTokenValidator($accessTokenRepositoryMock);
|
|
$bearerTokenValidator->setPublicKey(new CryptKey('file://' . __DIR__ . '/../Stubs/public.key'));
|
|
|
|
$unsignedJwt = (new Builder())
|
|
->setAudience('client-id')
|
|
->setId('token-id', true)
|
|
->setIssuedAt(time())
|
|
->setNotBefore(time())
|
|
->setExpiration(time())
|
|
->setSubject('user-id')
|
|
->set('scopes', 'scope1 scope2 scope3 scope4')
|
|
->getToken();
|
|
|
|
$request = (new ServerRequest())->withHeader('authorization', sprintf('Bearer %s', $unsignedJwt));
|
|
|
|
$this->expectException(\League\OAuth2\Server\Exception\OAuthServerException::class);
|
|
$this->expectExceptionCode(9);
|
|
|
|
$bearerTokenValidator->validateAuthorization($request);
|
|
}
|
|
}
|