123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- <?php
- namespace Tests\Api\v1\Requests;
- use App\Api\v1\Requests\TwoFAccountStoreRequest;
- use Illuminate\Foundation\Testing\WithoutMiddleware;
- use Illuminate\Support\Facades\Auth;
- use Illuminate\Support\Facades\Validator;
- use Tests\TestCase;
- /**
- * @covers \App\Api\v1\Requests\TwoFAccountStoreRequest
- * @covers \App\Rules\IsBase32Encoded
- */
- class TwoFAccountStoreRequestTest extends TestCase
- {
- use WithoutMiddleware;
- /**
- * @test
- */
- public function test_user_is_authorized()
- {
- Auth::shouldReceive('check')
- ->once()
- ->andReturn(true);
- $request = new TwoFAccountStoreRequest();
- $this->assertTrue($request->authorize());
- }
- /**
- * @dataProvider provideValidData
- */
- public function test_valid_data(array $data): void
- {
- $request = new TwoFAccountStoreRequest();
- $validator = Validator::make($data, $request->rules());
- $this->assertFalse($validator->fails());
- }
- /**
- * Provide Valid data for validation test
- */
- public function provideValidData(): array
- {
- return [
- [[
- 'service' => 'MyService',
- 'account' => 'MyAccount',
- 'icon' => 'icon.png',
- 'otp_type' => 'totp',
- 'secret' => 'A4GRFHZVRBGY7UIW',
- 'digits' => 6,
- 'algorithm' => 'sha1',
- 'period' => 30,
- ]],
- [[
- 'service' => 'MyService',
- 'account' => 'MyAccount',
- 'icon' => 'icon.png',
- 'otp_type' => 'hotp',
- 'secret' => 'A4GRFHZVRBGY7UIW',
- 'digits' => 8,
- 'algorithm' => 'sha1',
- 'counter' => 10,
- ]],
- [[
- 'service' => null,
- 'account' => 'MyAccount',
- 'icon' => null,
- 'otp_type' => 'hotp',
- 'secret' => 'A4GRFHZVRBGY7UIW',
- 'digits' => null,
- 'algorithm' => null,
- 'counter' => null,
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- 'algorithm' => 'sha256',
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- 'algorithm' => 'sha512',
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- 'algorithm' => 'md5',
- ]],
- ];
- }
- /**
- * @dataProvider provideInvalidData
- */
- public function test_invalid_data(array $data): void
- {
- $request = new TwoFAccountStoreRequest();
- $validator = Validator::make($data, $request->rules());
- $this->assertTrue($validator->fails());
- }
- /**
- * Provide invalid data for validation test
- */
- public function provideInvalidData(): array
- {
- return [
- [[
- 'account' => 'My:Account',
- 'otp_type' => 'totp',
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'Xotp',
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => null,
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- 'service' => 'My:Service',
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- 'secret' => 'notaBase32String',
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- 'secret' => 123456,
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- 'digits' => 4,
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- 'digits' => 11,
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- 'period' => 0,
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'hotp',
- 'counter' => -1,
- ]],
- [[
- 'account' => 'MyAccount',
- 'otp_type' => 'totp',
- 'algorithm' => 'shaX',
- ]],
- ];
- }
- }
|