118 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			118 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Pterodactyl - Panel
 | |
|  * Copyright (c) 2015 - 2017 Dane Everitt <dane@daneeveritt.com>.
 | |
|  *
 | |
|  * This software is licensed under the terms of the MIT license.
 | |
|  * https://opensource.org/licenses/MIT
 | |
|  */
 | |
| 
 | |
| namespace Tests\Unit\Services\Users;
 | |
| 
 | |
| use Mockery as m;
 | |
| use Tests\TestCase;
 | |
| use Pterodactyl\Models\User;
 | |
| use PragmaRX\Google2FA\Contracts\Google2FA;
 | |
| use Pterodactyl\Services\Users\ToggleTwoFactorService;
 | |
| use Pterodactyl\Contracts\Repository\UserRepositoryInterface;
 | |
| 
 | |
| class ToggleTwoFactorServiceTest extends TestCase
 | |
| {
 | |
|     /**
 | |
|      * @var \PragmaRX\Google2FA\Contracts\Google2FA
 | |
|      */
 | |
|     protected $google2FA;
 | |
| 
 | |
|     /**
 | |
|      * @var \Pterodactyl\Contracts\Repository\UserRepositoryInterface
 | |
|      */
 | |
|     protected $repository;
 | |
| 
 | |
|     /**
 | |
|      * @var \Pterodactyl\Services\Users\ToggleTwoFactorService
 | |
|      */
 | |
|     protected $service;
 | |
| 
 | |
|     /**
 | |
|      * Setup tests.
 | |
|      */
 | |
|     public function setUp()
 | |
|     {
 | |
|         parent::setUp();
 | |
| 
 | |
|         $this->google2FA = m::mock(Google2FA::class);
 | |
|         $this->repository = m::mock(UserRepositoryInterface::class);
 | |
| 
 | |
|         $this->service = new ToggleTwoFactorService($this->google2FA, $this->repository);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test that 2FA can be enabled for a user.
 | |
|      */
 | |
|     public function testTwoFactorIsEnabledForUser()
 | |
|     {
 | |
|         $model = factory(User::class)->make(['totp_secret' => 'secret', 'use_totp' => false]);
 | |
| 
 | |
|         $this->google2FA->shouldReceive('verifyKey')->with($model->totp_secret, 'test-token', 2)->once()->andReturn(true);
 | |
|         $this->repository->shouldReceive('withoutFresh')->withNoArgs()->once()->andReturnSelf()
 | |
|             ->shouldReceive('update')->with($model->id, ['use_totp' => true])->once()->andReturnNull();
 | |
| 
 | |
|         $this->assertTrue($this->service->handle($model, 'test-token'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test that 2FA can be disabled for a user.
 | |
|      */
 | |
|     public function testTwoFactorIsDisabled()
 | |
|     {
 | |
|         $model = factory(User::class)->make(['totp_secret' => 'secret', 'use_totp' => true]);
 | |
| 
 | |
|         $this->google2FA->shouldReceive('verifyKey')->with($model->totp_secret, 'test-token', 2)->once()->andReturn(true);
 | |
|         $this->repository->shouldReceive('withoutFresh')->withNoArgs()->once()->andReturnSelf()
 | |
|             ->shouldReceive('update')->with($model->id, ['use_totp' => false])->once()->andReturnNull();
 | |
| 
 | |
|         $this->assertTrue($this->service->handle($model, 'test-token'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test that 2FA will remain disabled for a user.
 | |
|      */
 | |
|     public function testTwoFactorRemainsDisabledForUser()
 | |
|     {
 | |
|         $model = factory(User::class)->make(['totp_secret' => 'secret', 'use_totp' => false]);
 | |
| 
 | |
|         $this->google2FA->shouldReceive('verifyKey')->with($model->totp_secret, 'test-token', 2)->once()->andReturn(true);
 | |
|         $this->repository->shouldReceive('withoutFresh')->withNoArgs()->once()->andReturnSelf()
 | |
|             ->shouldReceive('update')->with($model->id, ['use_totp' => false])->once()->andReturnNull();
 | |
| 
 | |
|         $this->assertTrue($this->service->handle($model, 'test-token', false));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test that an exception is thrown if the token provided is invalid.
 | |
|      *
 | |
|      * @expectedException \Pterodactyl\Exceptions\Service\User\TwoFactorAuthenticationTokenInvalid
 | |
|      */
 | |
|     public function testExceptionIsThrownIfTokenIsInvalid()
 | |
|     {
 | |
|         $model = factory(User::class)->make();
 | |
|         $this->google2FA->shouldReceive('verifyKey')->once()->andReturn(false);
 | |
| 
 | |
|         $this->service->handle($model, 'test-token');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test that an integer can be passed in place of a user model.
 | |
|      */
 | |
|     public function testIntegerCanBePassedInPlaceOfUserModel()
 | |
|     {
 | |
|         $model = factory(User::class)->make(['totp_secret' => 'secret', 'use_totp' => false]);
 | |
| 
 | |
|         $this->repository->shouldReceive('find')->with($model->id)->once()->andReturn($model);
 | |
|         $this->google2FA->shouldReceive('verifyKey')->once()->andReturn(true);
 | |
|         $this->repository->shouldReceive('withoutFresh->update')->once()->andReturnNull();
 | |
| 
 | |
|         $this->assertTrue($this->service->handle($model->id, 'test-token'));
 | |
|     }
 | |
| }
 | 
