get('/forgot-password'); $response->assertStatus(200); })->skip(function () { return ! Features::enabled(Features::resetPasswords()); }, 'Password updates are not enabled.'); test('reset password link can be requested', function () { Notification::fake(); $user = User::factory()->create(); $response = $this->post('/forgot-password', [ 'email' => $user->email, ]); Notification::assertSentTo($user, ResetPassword::class); })->skip(function () { return ! Features::enabled(Features::resetPasswords()); }, 'Password updates are not enabled.'); test('reset password screen can be rendered', function () { Notification::fake(); $user = User::factory()->create(); $response = $this->post('/forgot-password', [ 'email' => $user->email, ]); Notification::assertSentTo($user, ResetPassword::class, function (object $notification) { $response = $this->get('/reset-password/'.$notification->token); $response->assertStatus(200); return true; }); })->skip(function () { return ! Features::enabled(Features::resetPasswords()); }, 'Password updates are not enabled.'); test('password can be reset with valid token', function () { Notification::fake(); $user = User::factory()->create(); $response = $this->post('/forgot-password', [ 'email' => $user->email, ]); Notification::assertSentTo($user, ResetPassword::class, function (object $notification) use ($user) { $response = $this->post('/reset-password', [ 'token' => $notification->token, 'email' => $user->email, 'password' => 'password', 'password_confirmation' => 'password', ]); $response->assertSessionHasNoErrors(); return true; }); })->skip(function () { return ! Features::enabled(Features::resetPasswords()); }, 'Password updates are not enabled.');