Initial commit
This commit is contained in:
116
laravel/tests/Feature/AuthControllerTest.php
Normal file
116
laravel/tests/Feature/AuthControllerTest.php
Normal file
@@ -0,0 +1,116 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Tests\Feature;
|
||||
|
||||
use App\Contracts\AuthServiceContract;
|
||||
use App\Data\Auth\LoginData;
|
||||
use App\Data\Auth\LoginResult;
|
||||
use App\Enums\LoginError;
|
||||
use App\Models\User;
|
||||
use Illuminate\Support\Facades\Hash;
|
||||
use Laravel\Sanctum\PersonalAccessToken;
|
||||
use Mockery;
|
||||
use Tests\TestCase;
|
||||
|
||||
class AuthControllerTest extends TestCase
|
||||
{
|
||||
private const string LOGIN_URL = '/api/login';
|
||||
private const string LOGOUT_URL = '/api/logout';
|
||||
|
||||
public function test_it_returns_correct_error_for_invalid_credentials(): void
|
||||
{
|
||||
User::factory()->create([
|
||||
'email' => 'test@example.com',
|
||||
'password' => Hash::make('password123'),
|
||||
]);
|
||||
|
||||
$response = $this->postJson(self::LOGIN_URL, [
|
||||
'email' => 'test@example.com',
|
||||
'password' => 'ne_password123',
|
||||
]);
|
||||
|
||||
$response->assertStatus(401)
|
||||
->assertJson([
|
||||
'message' => 'Invalid credentials',
|
||||
]);
|
||||
}
|
||||
|
||||
public function test_it_returns_success_response(): void
|
||||
{
|
||||
User::factory()->create([
|
||||
'email' => 'test@example.com',
|
||||
'password' => Hash::make('password123'),
|
||||
]);
|
||||
|
||||
$response = $this->postJson(self::LOGIN_URL, [
|
||||
'email' => 'test@example.com',
|
||||
'password' => 'password123',
|
||||
]);
|
||||
|
||||
$response->assertStatus(200)
|
||||
->assertJsonStructure([
|
||||
'token',
|
||||
]);
|
||||
}
|
||||
|
||||
public function test_it_handles_server_error_from_service(): void
|
||||
{
|
||||
$mock = $this->mock(AuthServiceContract::class);
|
||||
|
||||
$mock->shouldReceive('attemptLogin')
|
||||
->once()
|
||||
->with(Mockery::type(LoginData::class))
|
||||
->andReturn(LoginResult::error(LoginError::SERVER_ERROR));
|
||||
|
||||
$response = $this->postJson(self::LOGIN_URL, [
|
||||
'email' => 'test@example.com',
|
||||
'password' => 'password123',
|
||||
]);
|
||||
|
||||
$response->assertStatus(500)
|
||||
->assertJson([
|
||||
'message' => 'Authentication failed',
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
public function test_user_can_logout_successfully(): void
|
||||
{
|
||||
User::factory()->create([
|
||||
'email' => 'test@example.com',
|
||||
'password' => Hash::make('password123'),
|
||||
]);
|
||||
|
||||
$loginResponse = $this->postJson(self::LOGIN_URL, [
|
||||
'email' => 'test@example.com',
|
||||
'password' => 'password123',
|
||||
]);
|
||||
|
||||
$token = $loginResponse->json('token');
|
||||
|
||||
$tokenBefore = PersonalAccessToken::findToken($token);
|
||||
$this->assertNotNull($tokenBefore, 'Token should exist before logout');
|
||||
|
||||
$logoutResponse = $this->postJson(self::LOGOUT_URL, [], [
|
||||
'Authorization' => 'Bearer ' . $token,
|
||||
]);
|
||||
|
||||
$logoutResponse->assertStatus(200)
|
||||
->assertJson([
|
||||
'message' => 'Logged out',
|
||||
]);
|
||||
|
||||
$tokenAfter = PersonalAccessToken::findToken($token);
|
||||
$this->assertNull($tokenAfter);
|
||||
|
||||
$this->refreshApplication();
|
||||
|
||||
$tasksResponse = $this->getJson('/api/tasks', [
|
||||
'Authorization' => 'Bearer ' . $token,
|
||||
]);
|
||||
|
||||
$tasksResponse->assertStatus(401);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user