forge/tests/Feature/User/AuthenticationTest.php
2024-10-01 00:50:38 -04:00

52 lines
1.2 KiB
PHP
Executable File

<?php
use App\Models\User;
test('login screen can be rendered', function () {
$response = $this->get('/login');
$response->assertStatus(200);
});
test('users can authenticate using the login screen', function () {
$user = User::factory()->create();
$response = $this->post('/login', [
'email' => $user->email,
'password' => 'password',
]);
$this->assertAuthenticated();
$response->assertRedirect(route('dashboard', absolute: false));
});
test('users cannot authenticate with invalid password', function () {
$user = User::factory()->create();
$this->post('/login', [
'email' => $user->email,
'password' => 'wrong-password',
]);
$this->assertGuest();
});
test('users can authenticate using Discord', function () {
$response = $this->get(route('login.socialite', ['provider' => 'discord']));
$response->assertStatus(302);
$response->assertRedirect();
});
test('user can not authenticate using a null password', function () {
$user = User::factory()->create();
$response = $this->post('/login', [
'email' => $user->email,
'password' => null,
]);
$this->assertGuest();
$response->assertSessionHasErrors('password');
});