69 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace Tests\Feature;
 | 
						|
 | 
						|
use App\Models\User;
 | 
						|
use Illuminate\Foundation\Testing\RefreshDatabase;
 | 
						|
use Laravel\Fortify\Features;
 | 
						|
use Tests\TestCase;
 | 
						|
 | 
						|
class TwoFactorAuthenticationSettingsTest extends TestCase
 | 
						|
{
 | 
						|
    use RefreshDatabase;
 | 
						|
 | 
						|
    public function test_two_factor_authentication_can_be_enabled(): void
 | 
						|
    {
 | 
						|
        if (! Features::canManageTwoFactorAuthentication()) {
 | 
						|
            $this->markTestSkipped('Two factor authentication is not enabled.');
 | 
						|
        }
 | 
						|
 | 
						|
        $this->actingAs($user = User::factory()->create());
 | 
						|
 | 
						|
        $this->withSession(['auth.password_confirmed_at' => time()]);
 | 
						|
 | 
						|
        $response = $this->post('/user/two-factor-authentication');
 | 
						|
 | 
						|
        $this->assertNotNull($user->fresh()->two_factor_secret);
 | 
						|
        $this->assertCount(8, $user->fresh()->recoveryCodes());
 | 
						|
    }
 | 
						|
 | 
						|
    public function test_recovery_codes_can_be_regenerated(): void
 | 
						|
    {
 | 
						|
        if (! Features::canManageTwoFactorAuthentication()) {
 | 
						|
            $this->markTestSkipped('Two factor authentication is not enabled.');
 | 
						|
        }
 | 
						|
 | 
						|
        $this->actingAs($user = User::factory()->create());
 | 
						|
 | 
						|
        $this->withSession(['auth.password_confirmed_at' => time()]);
 | 
						|
 | 
						|
        $this->post('/user/two-factor-authentication');
 | 
						|
        $this->post('/user/two-factor-recovery-codes');
 | 
						|
 | 
						|
        $user = $user->fresh();
 | 
						|
 | 
						|
        $this->post('/user/two-factor-recovery-codes');
 | 
						|
 | 
						|
        $this->assertCount(8, $user->recoveryCodes());
 | 
						|
        $this->assertCount(8, array_diff($user->recoveryCodes(), $user->fresh()->recoveryCodes()));
 | 
						|
    }
 | 
						|
 | 
						|
    public function test_two_factor_authentication_can_be_disabled(): void
 | 
						|
    {
 | 
						|
        if (! Features::canManageTwoFactorAuthentication()) {
 | 
						|
            $this->markTestSkipped('Two factor authentication is not enabled.');
 | 
						|
        }
 | 
						|
 | 
						|
        $this->actingAs($user = User::factory()->create());
 | 
						|
 | 
						|
        $this->withSession(['auth.password_confirmed_at' => time()]);
 | 
						|
 | 
						|
        $this->post('/user/two-factor-authentication');
 | 
						|
 | 
						|
        $this->assertNotNull($user->fresh()->two_factor_secret);
 | 
						|
 | 
						|
        $this->delete('/user/two-factor-authentication');
 | 
						|
 | 
						|
        $this->assertNull($user->fresh()->two_factor_secret);
 | 
						|
    }
 | 
						|
}
 |