Initial commit

This commit is contained in:
James
2024-12-03 21:27:44 +01:00
commit 613e1a767c
125 changed files with 16298 additions and 0 deletions

View File

@@ -0,0 +1,49 @@
<?php
declare(strict_types=1);
use App\Models\User;
use function Pest\Laravel\actingAs;
use function Pest\Laravel\assertAuthenticated;
use function Pest\Laravel\assertGuest;
use function Pest\Laravel\get;
use function Pest\Laravel\post;
test('login screen can be rendered', function () {
$response = get('/login');
$response->assertStatus(200);
});
test('users can authenticate using the login screen', function () {
$user = User::factory()->create();
$response = post('/login', [
'email' => $user->email,
'password' => 'password',
]);
assertAuthenticated();
$response->assertRedirect(route('dashboard', absolute: false));
});
test('users can not authenticate with invalid password', function () {
$user = User::factory()->create();
post('/login', [
'email' => $user->email,
'password' => 'wrong-password',
]);
assertGuest();
});
test('users can logout', function () {
$user = User::factory()->create();
$response = actingAs($user)->post('/logout');
assertGuest();
$response->assertRedirect('/');
});

View File

@@ -0,0 +1,25 @@
<?php
declare(strict_types=1);
use function Pest\Laravel\assertAuthenticated;
use function Pest\Laravel\get;
use function Pest\Laravel\post;
test('registration screen can be rendered', function () {
$response = get('/register');
$response->assertStatus(200);
});
test('new users can register', function () {
$response = post('/register', [
'name' => 'Test User',
'email' => 'test@example.com',
'password' => 'password',
'password_confirmation' => 'password',
]);
assertAuthenticated();
$response->assertRedirect(route('dashboard', absolute: false));
});