mirror of
https://github.com/elyby/accounts.git
synced 2024-11-10 07:22:00 +05:30
Добавлены тесты для ответа сервера о истёкшем токене
Добавлены doc-блоки для поведений в базовом контроллере
This commit is contained in:
parent
bdc96d82c1
commit
cb038c897b
@ -7,6 +7,11 @@ use yii\filters\auth\HttpBearerAuth;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @property \common\models\Account|null $account
|
* @property \common\models\Account|null $account
|
||||||
|
*
|
||||||
|
* Поведения:
|
||||||
|
* @mixin \yii\filters\ContentNegotiator
|
||||||
|
* @mixin \yii\filters\VerbFilter
|
||||||
|
* @mixin \yii\filters\auth\CompositeAuth
|
||||||
*/
|
*/
|
||||||
class Controller extends \yii\rest\Controller {
|
class Controller extends \yii\rest\Controller {
|
||||||
use ApiNormalize;
|
use ApiNormalize;
|
||||||
|
@ -34,4 +34,22 @@ class AccountsCurrentCest {
|
|||||||
$I->canSeeResponseJsonMatchesJsonPath('$.passwordChangedAt');
|
$I->canSeeResponseJsonMatchesJsonPath('$.passwordChangedAt');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testExpiredCurrent(FunctionalTester $I) {
|
||||||
|
// Устанавливаем заведомо истёкший токен
|
||||||
|
$I->amBearerAuthenticated(
|
||||||
|
'eyJhbGciOiJIUzI1NiJ9.eyJhdWQiOiJodHRwOlwvXC9sb2NhbGhvc3QiLCJpc3MiOiJodHRwOlwvXC9sb2NhbGhvc3QiLCJpYXQiO' .
|
||||||
|
'jE0NjQ2Mjc1NDUsImV4cCI6MTQ2NDYzMTE0NSwianRpIjoxfQ.9c1mm0BK-cuW1qh15F12s2Fh37IN43YeeZeU4DFtlrE'
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->route->current();
|
||||||
|
$I->canSeeResponseCodeIs(401);
|
||||||
|
$I->canSeeResponseIsJson();
|
||||||
|
$I->canSeeResponseContainsJson([
|
||||||
|
'name' => 'Unauthorized',
|
||||||
|
'message' => 'Token expired',
|
||||||
|
'code' => 0,
|
||||||
|
'status' => 401,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -18,10 +18,7 @@ class AccountIdentityTest extends DbTestCase {
|
|||||||
|
|
||||||
public function fixtures() {
|
public function fixtures() {
|
||||||
return [
|
return [
|
||||||
'accounts' => [
|
'accounts' => AccountFixture::class,
|
||||||
'class' => AccountFixture::class,
|
|
||||||
'dataFile' => '@tests/codeception/common/fixtures/data/accounts.php',
|
|
||||||
],
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -32,16 +29,13 @@ class AccountIdentityTest extends DbTestCase {
|
|||||||
expect($identity->getId())->equals($this->accounts['admin']['id']);
|
expect($identity->getId())->equals($this->accounts['admin']['id']);
|
||||||
});
|
});
|
||||||
|
|
||||||
// TODO: нормально оттестить исключение, если токен истёк
|
$this->specify('get unauthorized exception with "Token expired" message if token valid, but expire', function() {
|
||||||
return;
|
$expiredToken = 'eyJhbGciOiJIUzI1NiJ9.eyJhdWQiOiJodHRwOlwvXC9sb2NhbGhvc3Q6ODA4MCIsImlzcyI6Imh0d' .
|
||||||
|
'HA6XC9cL2xvY2FsaG9zdDo4MDgwIiwiaWF0IjoxNDY0NTkzMTkzLCJleHAiOjE0NjQ1OTY3OTN9.DV' .
|
||||||
|
'8uwh0OQhBYXkrNvxwJeO-kEjb9MQeLr3-6GoHM7RY';
|
||||||
|
|
||||||
$this->specify('get unauthorized with "Token expired message if token valid, but expire"', function() {
|
|
||||||
$originalTimezone = date_default_timezone_get();
|
|
||||||
date_default_timezone_set('America/Los_Angeles');
|
|
||||||
try {
|
try {
|
||||||
$token = $this->generateToken();
|
AccountIdentity::findIdentityByAccessToken($expiredToken);
|
||||||
date_default_timezone_set($originalTimezone);
|
|
||||||
AccountIdentity::findIdentityByAccessToken($token);
|
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
expect($e)->isInstanceOf(UnauthorizedHttpException::class);
|
expect($e)->isInstanceOf(UnauthorizedHttpException::class);
|
||||||
expect($e->getMessage())->equals('Token expired');
|
expect($e->getMessage())->equals('Token expired');
|
||||||
|
Loading…
Reference in New Issue
Block a user