Squashed commit of the following: commit 74ed84617fcbecf661695763323e50d049a88db7 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Mon Jan 15 12:46:29 2018 +0000 Test passes so remove the dump statement commit a7d3323be02da64f76e8ec88713e3de84a13ded7 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Mon Jan 15 12:40:35 2018 +0000 Values with spaces need to be quoted commit 58a120bb238f14346793c388b948b7351d3b51fd Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Mon Jan 15 12:37:23 2018 +0000 We need a diplay name for the tests to work now we are using strict type checking commit b46f177053bd697db9a4835d073f2f37e088b26f Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Mon Jan 15 12:31:29 2018 +0000 Get travis to show more info about failing test commit 60323f3ce5a0561329a1721ee94821571cdcc86a Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Mon Jan 15 12:23:27 2018 +0000 Remove un-used namnepsace imports commit 096d3505920bc94ff8677c77430eca0aae0be58a Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Mon Jan 15 12:21:55 2018 +0000 we need php7.2 for object type-hint commit bb818bc19c73d02d510af9f002199f5718a54608 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Mon Jan 15 12:15:48 2018 +0000 Added lots of strict_types
59 lines
1.8 KiB
PHP
59 lines
1.8 KiB
PHP
<?php
|
|
|
|
namespace Tests\Feature;
|
|
|
|
use Tests\TestCase;
|
|
use Lcobucci\JWT\Builder;
|
|
use App\Services\TokenService;
|
|
use Lcobucci\JWT\Signer\Hmac\Sha256;
|
|
|
|
class TokenServiceTest extends TestCase
|
|
{
|
|
/**
|
|
* Given the token is dependent on a random nonce, the time of creation and
|
|
* the APP_KEY, to test, we shall create a token, and then verify it.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function test_token_creation_and_validation()
|
|
{
|
|
$tokenService = new TokenService();
|
|
$data = [
|
|
'me' => 'https://example.org',
|
|
'client_id' => 'https://quill.p3k.io',
|
|
'scope' => 'post'
|
|
];
|
|
$token = $tokenService->getNewToken($data);
|
|
$valid = $tokenService->validateToken($token);
|
|
$validData = [
|
|
'me' => $valid->getClaim('me'),
|
|
'client_id' => $valid->getClaim('client_id'),
|
|
'scope' => $valid->getClaim('scope')
|
|
];
|
|
$this->assertSame($data, $validData);
|
|
}
|
|
|
|
/**
|
|
* @expectedException App\Exceptions\InvalidTokenException
|
|
* @expectedExceptionMessage Token failed validation
|
|
*/
|
|
public function test_token_with_different_singing_key_throws_exception()
|
|
{
|
|
$data = [
|
|
'me' => 'https://example.org',
|
|
'client_id' => 'https://quill.p3k.io',
|
|
'scope' => 'post'
|
|
];
|
|
$signer = new Sha256();
|
|
$token = (new Builder())->set('me', $data['me'])
|
|
->set('client_id', $data['client_id'])
|
|
->set('scope', $data['scope'])
|
|
->set('date_issued', time())
|
|
->set('nonce', bin2hex(random_bytes(8)))
|
|
->sign($signer, 'r4ndomk3y')
|
|
->getToken();
|
|
|
|
$service = new TokenService();
|
|
$token = $service->validateToken($token);
|
|
}
|
|
}
|