skipUnlessFortifyHas(Features::twoFactorAuthentication()); Features::twoFactorAuthentication([ 'confirm' => true, 'confirmPassword' => true, ]); $user = User::factory()->create(); $this->actingAs($user) ->withSession(['auth.password_confirmed_at' => time()]) ->get(route('security.edit')) ->assertInertia(fn (Assert $page) => $page ->component('settings/Security') ->where('canManageTwoFactor', true) ->where('twoFactorEnabled', false), ); }); test('security page requires password confirmation when enabled', function () { $this->skipUnlessFortifyHas(Features::twoFactorAuthentication()); $user = User::factory()->create(); Features::twoFactorAuthentication([ 'confirm' => true, 'confirmPassword' => true, ]); $response = $this->actingAs($user) ->get(route('security.edit')); $response->assertRedirect(route('password.confirm')); }); test('security page does not require password confirmation when disabled', function () { $this->skipUnlessFortifyHas(Features::twoFactorAuthentication()); $user = User::factory()->create(); Features::twoFactorAuthentication([ 'confirm' => true, 'confirmPassword' => false, ]); $this->actingAs($user) ->get(route('security.edit')) ->assertOk() ->assertInertia(fn (Assert $page) => $page ->component('settings/Security'), ); }); test('security page renders without two factor when feature is disabled', function () { $this->skipUnlessFortifyHas(Features::twoFactorAuthentication()); config(['fortify.features' => []]); $user = User::factory()->create(); $this->actingAs($user) ->get(route('security.edit')) ->assertOk() ->assertInertia(fn (Assert $page) => $page ->component('settings/Security') ->where('canManageTwoFactor', false) ->missing('twoFactorEnabled') ->missing('requiresConfirmation'), ); }); test('password can be updated', function () { $user = User::factory()->create(); $response = $this ->actingAs($user) ->from(route('security.edit')) ->put(route('user-password.update'), [ 'current_password' => 'password', 'password' => 'new-password', 'password_confirmation' => 'new-password', ]); $response ->assertSessionHasNoErrors() ->assertRedirect(route('security.edit')); expect(Hash::check('new-password', $user->refresh()->password))->toBeTrue(); }); test('correct password must be provided to update password', function () { $user = User::factory()->create(); $response = $this ->actingAs($user) ->from(route('security.edit')) ->put(route('user-password.update'), [ 'current_password' => 'wrong-password', 'password' => 'new-password', 'password_confirmation' => 'new-password', ]); $response ->assertSessionHasErrors('current_password') ->assertRedirect(route('security.edit')); });