mirror of
https://github.com/elyby/accounts.git
synced 2025-01-22 19:43:11 +05:30
dd2c4bc413
Все действия, связанные с аккаунтами, теперь вызываются через url `/api/v1/accounts/<id>/<action>`. Добавлена вменяемая система разграничения прав на основе RBAC. Теперь oAuth2 токены генерируются как случайная строка в 40 символов длинной, а не UUID. Исправлен баг с неправильным временем жизни токена в ответе успешного запроса аутентификации. Теперь все unit тесты можно успешно прогнать без наличия интернета.
71 lines
2.4 KiB
PHP
71 lines
2.4 KiB
PHP
<?php
|
|
namespace tests\codeception\api\functional;
|
|
|
|
use tests\codeception\api\_pages\SignupRoute;
|
|
use tests\codeception\api\FunctionalTester;
|
|
|
|
class RepeatAccountActivationCest {
|
|
|
|
public function testInvalidEmailOrAccountState(FunctionalTester $I) {
|
|
$route = new SignupRoute($I);
|
|
|
|
$I->wantTo('error.email_required on empty for submitting');
|
|
$route->sendRepeatMessage();
|
|
$I->canSeeResponseCodeIs(200);
|
|
$I->canSeeResponseIsJson();
|
|
$I->canSeeResponseContainsJson([
|
|
'success' => false,
|
|
'errors' => [
|
|
'email' => 'error.email_required',
|
|
],
|
|
]);
|
|
|
|
$I->wantTo('error.email_not_found if email is not presented in db');
|
|
$route->sendRepeatMessage('im-not@exists.net');
|
|
$I->canSeeResponseCodeIs(200);
|
|
$I->canSeeResponseIsJson();
|
|
$I->canSeeResponseContainsJson([
|
|
'success' => false,
|
|
'errors' => [
|
|
'email' => 'error.email_not_found',
|
|
],
|
|
]);
|
|
|
|
$I->wantTo('error.account_already_activated if passed email matches with already activated account');
|
|
$route->sendRepeatMessage('admin@ely.by');
|
|
$I->canSeeResponseCodeIs(200);
|
|
$I->canSeeResponseIsJson();
|
|
$I->canSeeResponseContainsJson([
|
|
'success' => false,
|
|
'errors' => [
|
|
'email' => 'error.account_already_activated',
|
|
],
|
|
]);
|
|
|
|
$I->wantTo('error.recently_sent_message if last message was send too recently');
|
|
$route->sendRepeatMessage('achristiansen@gmail.com');
|
|
$I->canSeeResponseCodeIs(200);
|
|
$I->canSeeResponseIsJson();
|
|
$I->canSeeResponseContainsJson([
|
|
'success' => false,
|
|
'errors' => [
|
|
'email' => 'error.recently_sent_message',
|
|
],
|
|
]);
|
|
$I->canSeeResponseJsonMatchesJsonPath('$.data.canRepeatIn');
|
|
$I->canSeeResponseJsonMatchesJsonPath('$.data.repeatFrequency');
|
|
}
|
|
|
|
public function testSuccess(FunctionalTester $I) {
|
|
$route = new SignupRoute($I);
|
|
|
|
$I->wantTo('successfully resend account activation message');
|
|
$route->sendRepeatMessage('jon@ely.by');
|
|
$I->canSeeResponseCodeIs(200);
|
|
$I->canSeeResponseIsJson();
|
|
$I->canSeeResponseContainsJson(['success' => true]);
|
|
$I->cantSeeResponseJsonMatchesJsonPath('$.errors');
|
|
}
|
|
|
|
}
|