2017-04-03 14:54:33 +03:00
|
|
|
<?php
|
2019-02-20 22:58:52 +03:00
|
|
|
namespace api\tests\functional\internal;
|
2017-04-03 14:54:33 +03:00
|
|
|
|
2019-02-20 22:58:52 +03:00
|
|
|
use api\tests\_pages\InternalRoute;
|
|
|
|
use api\tests\functional\_steps\OauthSteps;
|
|
|
|
use api\tests\FunctionalTester;
|
2017-04-03 14:54:33 +03:00
|
|
|
|
|
|
|
class InfoCest {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var InternalRoute
|
|
|
|
*/
|
|
|
|
private $route;
|
|
|
|
|
|
|
|
public function _before(FunctionalTester $I) {
|
|
|
|
$this->route = new InternalRoute($I);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetInfoById(OauthSteps $I) {
|
2017-09-19 20:06:16 +03:00
|
|
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant(['internal_account_info']);
|
2017-04-03 14:54:33 +03:00
|
|
|
$I->amBearerAuthenticated($accessToken);
|
|
|
|
|
|
|
|
$this->route->info('id', 1);
|
|
|
|
$this->expectSuccessResponse($I);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetInfoByUuid(OauthSteps $I) {
|
2017-09-19 20:06:16 +03:00
|
|
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant(['internal_account_info']);
|
2017-04-03 14:54:33 +03:00
|
|
|
$I->amBearerAuthenticated($accessToken);
|
|
|
|
|
|
|
|
$this->route->info('uuid', 'df936908-b2e1-544d-96f8-2977ec213022');
|
|
|
|
$this->expectSuccessResponse($I);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetInfoByUsername(OauthSteps $I) {
|
2017-09-19 20:06:16 +03:00
|
|
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant(['internal_account_info']);
|
2017-04-03 14:54:33 +03:00
|
|
|
$I->amBearerAuthenticated($accessToken);
|
|
|
|
|
|
|
|
$this->route->info('username', 'admin');
|
|
|
|
$this->expectSuccessResponse($I);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testInvalidParams(OauthSteps $I) {
|
2017-09-19 20:06:16 +03:00
|
|
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant(['internal_account_info']);
|
2017-04-03 14:54:33 +03:00
|
|
|
$I->amBearerAuthenticated($accessToken);
|
|
|
|
|
|
|
|
$this->route->info('', '');
|
|
|
|
$I->canSeeResponseCodeIs(400);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAccountNotFound(OauthSteps $I) {
|
2017-09-19 20:06:16 +03:00
|
|
|
$accessToken = $I->getAccessTokenByClientCredentialsGrant(['internal_account_info']);
|
2017-04-03 14:54:33 +03:00
|
|
|
$I->amBearerAuthenticated($accessToken);
|
|
|
|
|
|
|
|
$this->route->info('username', 'this-user-not-exists');
|
|
|
|
$I->canSeeResponseCodeIs(404);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param OauthSteps $I
|
|
|
|
*/
|
|
|
|
private function expectSuccessResponse(OauthSteps $I): void {
|
|
|
|
$I->canSeeResponseCodeIs(200);
|
|
|
|
$I->canSeeResponseIsJson();
|
|
|
|
$I->canSeeResponseContainsJson([
|
|
|
|
'id' => 1,
|
|
|
|
'uuid' => 'df936908-b2e1-544d-96f8-2977ec213022',
|
|
|
|
'email' => 'admin@ely.by',
|
|
|
|
'username' => 'Admin',
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|