mirror of
https://github.com/elyby/accounts.git
synced 2025-01-25 04:52:04 +05:30
45 lines
1.3 KiB
PHP
45 lines
1.3 KiB
PHP
<?php
|
|
declare(strict_types=1);
|
|
|
|
namespace api\tests;
|
|
|
|
use api\tests\_generated\FunctionalTesterActions;
|
|
use Codeception\Actor;
|
|
use common\models\Account;
|
|
use InvalidArgumentException;
|
|
use Yii;
|
|
|
|
class FunctionalTester extends Actor {
|
|
use FunctionalTesterActions;
|
|
|
|
public function amAuthenticated(string $asUsername = 'admin') {
|
|
/** @var Account $account */
|
|
$account = Account::findOne(['username' => $asUsername]);
|
|
if ($account === null) {
|
|
throw new InvalidArgumentException("Cannot find account for username \"{$asUsername}\"");
|
|
}
|
|
|
|
$token = Yii::$app->user->createJwtAuthenticationToken($account);
|
|
$jwt = Yii::$app->user->serializeToken($token);
|
|
$this->amBearerAuthenticated($jwt);
|
|
|
|
return $account->id;
|
|
}
|
|
|
|
public function notLoggedIn(): void {
|
|
$this->haveHttpHeader('Authorization', null);
|
|
Yii::$app->user->logout();
|
|
}
|
|
|
|
public function canSeeAuthCredentials($expectRefresh = false): void {
|
|
$this->canSeeResponseJsonMatchesJsonPath('$.access_token');
|
|
$this->canSeeResponseJsonMatchesJsonPath('$.expires_in');
|
|
if ($expectRefresh) {
|
|
$this->canSeeResponseJsonMatchesJsonPath('$.refresh_token');
|
|
} else {
|
|
$this->cantSeeResponseJsonMatchesJsonPath('$.refresh_token');
|
|
}
|
|
}
|
|
|
|
}
|