88 lines
2.4 KiB
PHP
88 lines
2.4 KiB
PHP
<?php
|
|
|
|
namespace Tests\Feature\Auth;
|
|
|
|
use App\Models\User;
|
|
use Illuminate\Auth\Notifications\ResetPassword;
|
|
use Illuminate\Foundation\Testing\RefreshDatabase;
|
|
use Illuminate\Support\Facades\Notification;
|
|
use Tests\TestCase;
|
|
|
|
class PasswordResetTest extends TestCase
|
|
{
|
|
use RefreshDatabase;
|
|
|
|
public function test_reset_password_link_screen_can_be_rendered()
|
|
{
|
|
$response = $this->get(route('password.request'));
|
|
|
|
$response->assertStatus(200);
|
|
}
|
|
|
|
public function test_reset_password_link_can_be_requested()
|
|
{
|
|
Notification::fake();
|
|
|
|
$user = User::factory()->create();
|
|
|
|
$this->post(route('password.email'), ['email' => $user->email]);
|
|
|
|
Notification::assertSentTo($user, ResetPassword::class);
|
|
}
|
|
|
|
public function test_reset_password_screen_can_be_rendered()
|
|
{
|
|
Notification::fake();
|
|
|
|
$user = User::factory()->create();
|
|
|
|
$this->post(route('password.email'), ['email' => $user->email]);
|
|
|
|
Notification::assertSentTo($user, ResetPassword::class, function ($notification) {
|
|
$response = $this->get(route('password.reset', $notification->token));
|
|
|
|
$response->assertStatus(200);
|
|
|
|
return true;
|
|
});
|
|
}
|
|
|
|
public function test_password_can_be_reset_with_valid_token()
|
|
{
|
|
Notification::fake();
|
|
|
|
$user = User::factory()->create();
|
|
|
|
$this->post(route('password.email'), ['email' => $user->email]);
|
|
|
|
Notification::assertSentTo($user, ResetPassword::class, function ($notification) use ($user) {
|
|
$response = $this->post(route('password.store'), [
|
|
'token' => $notification->token,
|
|
'email' => $user->email,
|
|
'password' => 'password',
|
|
'password_confirmation' => 'password',
|
|
]);
|
|
|
|
$response
|
|
->assertSessionHasNoErrors()
|
|
->assertRedirect(route('login'));
|
|
|
|
return true;
|
|
});
|
|
}
|
|
|
|
public function test_password_cannot_be_reset_with_invalid_token(): void
|
|
{
|
|
$user = User::factory()->create();
|
|
|
|
$response = $this->post(route('password.store'), [
|
|
'token' => 'invalid-token',
|
|
'email' => $user->email,
|
|
'password' => 'newpassword123',
|
|
'password_confirmation' => 'newpassword123',
|
|
]);
|
|
|
|
$response->assertSessionHasErrors('email');
|
|
}
|
|
}
|