<?php
namespace App\Tests\Api\User;
use App\Entity\User;
use App\Factory\UserFactory;
use App\Tests\Support\ApiTester;
use Codeception\Util\HttpCode;
class UserPatchCest
{
protected static function expectedProperties(): array
{
return [
'id' => 'integer',
'login' => 'string',
'firstname' => 'string',
'lastname' => 'string',
'email' => 'string:email',
];
}
public function anonymousUserForbiddenToPatchUser(ApiTester $I): void
{
UserFactory::createOne();
$I->sendPatch('/api/users/1');
$I->seeResponseCodeIs(HttpCode::UNAUTHORIZED);
}
public function authenticatedUserForbiddenToPatchOtherUser(ApiTester $I): void
{
$user = UserFactory::createOne()->_real();
UserFactory::createOne();
$I->amLoggedInAs($user);
$I->sendPatch('/api/users/2');
$I->seeResponseCodeIs(HttpCode::FORBIDDEN);
}
public function authenticatedUserCanPatchOwnData(ApiTester $I): void
{
$dataInit = [
'lastname' => 'lastname1',
'firstname' => 'firstname1',
'login' => 'login1',
];
$user = UserFactory::createOne($dataInit)->_real();
$I->amLoggedInAs($user);
$dataPatch = [
'lastname' => 'lastname2',
'firstname' => 'firstname2',
'login' => 'login2',
];
$I->sendPatch('/api/users/1', $dataPatch);
$I->seeResponseCodeIsSuccessful();
$I->seeResponseIsJson();
$I->seeResponseIsAnEntity(User::class, '/api/users/1');
$I->seeResponseIsAnItem(self::expectedProperties(), $dataPatch);
}
}