get(route('password.request')); $response->assertStatus(200); }); test('reset password link can be requested', function () { Notification::fake(); $user = User::factory()->create(); $this->post(route('password.request'), ['email' => $user->email]); Notification::assertSentTo($user, ResetPassword::class); }); test('reset password screen can be rendered', function () { Notification::fake(); $user = User::factory()->create(); $this->post(route('password.request'), ['email' => $user->email]); Notification::assertSentTo($user, ResetPassword::class, function ($notification) { $response = $this->get(route('password.reset', $notification->token)); $response->assertStatus(200); return true; }); }); test('password can be reset with valid token', function () { Notification::fake(); $user = User::factory()->create(); $this->post(route('password.request'), ['email' => $user->email]); Notification::assertSentTo($user, ResetPassword::class, function ($notification) use ($user) { $response = $this->post(route('password.update'), [ 'token' => $notification->token, 'email' => $user->email, 'password' => 'password', 'password_confirmation' => 'password', ]); $response ->assertSessionHasNoErrors() ->assertRedirect(route('login', absolute: false)); return true; }); });