From 284a9f75b2d1911f776647d428da4210fec82794 Mon Sep 17 00:00:00 2001 From: Bubka <858858+Bubka@users.noreply.github.com> Date: Tue, 3 Mar 2020 17:06:40 +0100 Subject: [PATCH] Enhance unit tests coverage --- tests/Feature/AuthTest.php | 174 +++++++++++++++++++++++++++++++++ tests/Unit/QrcodeTest.php | 69 ++++++------- tests/Unit/TwoFAccountTest.php | 80 ++++++++++++++- tests/Unit/UserTest.php | 5 + 4 files changed, 289 insertions(+), 39 deletions(-) create mode 100644 tests/Feature/AuthTest.php diff --git a/tests/Feature/AuthTest.php b/tests/Feature/AuthTest.php new file mode 100644 index 00000000..b65e2dd7 --- /dev/null +++ b/tests/Feature/AuthTest.php @@ -0,0 +1,174 @@ +json('POST', '/api/password/email', [ + 'email' => '' + ]); + + $response->assertStatus(422) + ->assertJsonValidationErrors(['email']); + } + + /** + * Testing submitting the email password request with an invalid + * email address. + */ + public function testSubmitEmailPasswordRequestWithInvalidEmail() + { + $response = $this->json('POST', '/api/password/email', [ + 'email' => 'nametest.com' + ]); + + $response->assertStatus(422) + ->assertJsonValidationErrors(['email']); + } + + /** + * Testing submitting the email password request with an unknown + * email address. + */ + public function testSubmitEmailPasswordRequestWithUnknownEmail() + { + $response = $this->json('POST', '/api/password/email', [ + 'email' => 'name@test.com' + ]); + + $response->assertStatus(422) + ->assertJsonValidationErrors(['email']); + } + + /** + * Testing submitting the email password request with a valid email address. + */ + public function testSubmitEmailPasswordRequest() + { + Notification::fake(); + + $this->user = factory(User::class)->create([ + 'name' => 'user', + 'email' => 'user@example.org', + 'password' => bcrypt('password'), + 'email_verified_at' => now(), + 'remember_token' => \Illuminate\Support\Str::random(10), + ]); + + //$this->expectsNotification($this->user, ResetPassword::class); + + $response = $this->json('POST', '/api/password/email', [ + 'email' => $this->user->email + ]); + + $response->assertStatus(200); + + $token = \Illuminate\Support\Facades\DB::table('password_resets')->first(); + $this->assertNotNull($token); + + // Notification::assertSentTo($this->user, ResetPassword::class, function ($notification, $channels) use ($token) { + // return Hash::check($notification->token, $token->token) === true; + // }); + } + + + + /** + * Testing submitting the reset password without + * email address. + */ + public function testSubmitResetPasswordWithoutInput() + { + $response = $this->json('POST', '/api/password/reset', [ + 'email' => '', + 'password' => '', + 'password_confirmation' => '', + 'token' => '' + ]); + + $response->assertStatus(422) + ->assertJsonValidationErrors(['email', 'password', 'token']); + } + + /** + * Testing submitting the reset password with + * invalid input. + */ + public function testSubmitResetPasswordWithInvalidInput() + { + $response = $this->json('POST', '/api/password/reset', [ + 'email' => 'qsdqsdqsd', + 'password' => 'foofoofoo', + 'password_confirmation' => 'barbarbar', + 'token' => 'token' + ]); + + $response->assertStatus(422) + ->assertJsonValidationErrors(['email', 'password']); + } + + /** + * Testing submitting the reset password with + * invalid input. + */ + public function testSubmitResetPasswordWithTooShortPasswords() + { + $response = $this->json('POST', '/api/password/reset', [ + 'email' => 'foo@bar.com', + 'password' => 'foo', + 'password_confirmation' => 'foo', + 'token' => 'token' + ]); + + $response->assertStatus(422) + ->assertJsonValidationErrors(['password']); + } + + /** + * Testing submitting the rest password. + */ + public function testSubmitResetPassword() + { + Notification::fake(); + + $this->user = factory(User::class)->create([ + 'name' => 'user', + 'email' => 'user@example.org', + 'password' => bcrypt('password'), + 'email_verified_at' => now(), + 'remember_token' => \Illuminate\Support\Str::random(10) + ]); + + $token = Password::broker()->createToken($this->user); + + $response = $this->json('POST', '/api/password/reset', [ + 'email' => $this->user->email, + 'password' => 'newpassword', + 'password_confirmation' => 'newpassword', + 'token' => $token + ]); + + $this->user->refresh(); + + $response->assertStatus(200); + $this->assertTrue(Hash::check('newpassword', $this->user->password)); + + } + +} diff --git a/tests/Unit/QrcodeTest.php b/tests/Unit/QrcodeTest.php index 08119099..3a7201c1 100644 --- a/tests/Unit/QrcodeTest.php +++ b/tests/Unit/QrcodeTest.php @@ -7,6 +7,7 @@ use Illuminate\Http\UploadedFile; use Illuminate\Support\Facades\Storage; use Illuminate\Foundation\Testing\WithoutMiddleware; use Tests\TestCase; +use Tests\Classes\LocalFile; class QrcodeTest extends TestCase { @@ -15,7 +16,7 @@ class QrcodeTest extends TestCase /** - * test upload icon with no missing image resource via API + * test Decode a qrcode without providing a file resource via API * * @test */ @@ -29,53 +30,53 @@ class QrcodeTest extends TestCase } - /** - * test Qrcode decode with an invalid image resource via API - * - * @test - */ - // public function testQrcodeDecodeWithInvalidImage() - // { - - // Storage::fake('qrcodes'); - - // $file = UploadedFile::fake()->image('qrcode.jpg'); - - // $this->expectException(\Illuminate\Validation\ValidationException::class); - - // $response = $this->json('POST', '/api/qrcode/decode', [ - // 'qrcode' => $file, - // ]); - // } - - /** * test delete an uploaded icon via API * * @test */ - public function testDecodeQrcode() + public function testDecodeInvalidQrcode() { - //Storage::fake('qrcodes'); - - $image = ''; - - - //Storage::put('tests/qrcodeTest.png', base64_decode($image)); - - //$this->assertFileExists('storage/app/tests/qrcodeTest.png'); + $file = LocalFile::fake()->invalidQrcode(); $response = $this->withHeaders([ 'Content-Type' => 'multipart/form-data', ]) ->json('POST', '/api/qrcode/decode', [ - 'qrcode' => $image + 'qrcode' => $file ]); - $response->dump(); - $response->dumpHeaders(); + $response->assertStatus(422); + } - $response->assertStatus(200); + + /** + * test Decode a qrcode via API + * + * @test + */ + public function testDecodeValidQrcode() + { + $file = LocalFile::fake()->validQrcode(); + + $response = $this->withHeaders(['Content-Type' => 'multipart/form-data']) + ->json('POST', '/api/qrcode/decode', [ + 'qrcode' => $file + ]); + + $response->assertStatus(200) + ->assertJsonFragment([ + 'service' => 'test@test.com', + 'account' => '', + 'options' => [ + 'algorithm' => 'sha1', + 'digits' => 6, + 'epoch' => 0, + 'period' => 30, + 'secret' => 'A4GRFHVIRBGY7UIW' + ], + 'uri' => 'otpauth://totp/test@test.com?secret=A4GRFHVIRBGY7UIW' + ]); } } \ No newline at end of file diff --git a/tests/Unit/TwoFAccountTest.php b/tests/Unit/TwoFAccountTest.php index 22eb5c04..3d06ab79 100644 --- a/tests/Unit/TwoFAccountTest.php +++ b/tests/Unit/TwoFAccountTest.php @@ -127,11 +127,11 @@ class TwoFAccountTest extends TestCase /** - * test TOTP generation via API + * test TOTP generation for a given existing account via API * * @test */ - public function testTOTPgeneration() + public function testTOTPgenerationWithProvidedAccountId() { $twofaccount = factory(TwoFAccount::class)->create([ 'service' => 'testTOTP', @@ -149,11 +149,29 @@ class TwoFAccountTest extends TestCase /** - * test TwoFAccount update via API + * test TOTP generation as preview via API * * @test */ - public function testTwoFAccountUpdate() + public function testTOTPgenerationPreview() + { + $uri = 'otpauth://totp/test@test.com?secret=A4GRFHVVRBGY7UIW&issuer=test'; + + $response = $this->actingAs($this->user, 'api') + ->json('POST', '/api/twofaccounts/otp', ['data' => $uri]) + ->assertStatus(200) + ->assertJsonStructure([ + 'otp', + ]); + } + + + /** + * test TwoFAccount TOTP update via API + * + * @test + */ + public function testTwoFAccountTOTPUpdate() { $twofaccount = factory(TwoFAccount::class)->create(); @@ -174,6 +192,37 @@ class TwoFAccountTest extends TestCase } + /** + * test TwoFAccount HOTP update via API + * + * @test + */ + public function testTwoFAccountHOTPUpdate() + { + $twofaccount = factory(TwoFAccount::class)->create([ + 'service' => 'test.com', + 'account' => 'test', + 'uri' => 'otpauth://hotp/service?counter=1&secret=A4GRFHVVRBGY7UIW' + ]); + + $response = $this->actingAs($this->user, 'api') + ->json('PUT', '/api/twofaccounts/' . $twofaccount->id, [ + 'service' => 'testUpdate.com', + 'account' => 'testUpdate', + 'icon' => 'testUpdate.png', + 'counter' => '5' + ]) + ->assertStatus(200) + ->assertJson([ + 'id' => 1, + 'service' => 'testUpdate.com', + 'account' => 'testUpdate', + 'uri' => 'otpauth://hotp/service?counter=5&secret=A4GRFHVVRBGY7UIW', + 'icon' => 'testUpdate.png', + ]); + } + + /** * test TwoFAccount update via API * @@ -187,7 +236,8 @@ class TwoFAccountTest extends TestCase $response = $this->actingAs($this->user, 'api') ->json('PUT', '/api/twofaccounts/' . $id, [ - 'service' => 'testUpdate' + 'service' => 'testUpdate', + 'icon' => 'name.png' ]) ->assertStatus(404); } @@ -235,4 +285,24 @@ class TwoFAccountTest extends TestCase ->assertStatus(204); } + + /** + * test TwoFAccounts batch deletion via API + * + * @test + */ + public function testTwoFAccountBatchDestroy() + { + $twofaccount = factory(TwoFAccount::class)->create(); + $twofaccount = factory(TwoFAccount::class)->create(); + $twofaccount = factory(TwoFAccount::class)->create(); + + $ids = \Illuminate\Support\Facades\DB::table('twofaccounts')->value('id'); + + $response = $this->actingAs($this->user, 'api') + ->json('DELETE', '/api/twofaccounts/batch', [ + 'data' => $ids]) + ->assertStatus(204); + } + } diff --git a/tests/Unit/UserTest.php b/tests/Unit/UserTest.php index 197ffccc..c71edb64 100644 --- a/tests/Unit/UserTest.php +++ b/tests/Unit/UserTest.php @@ -6,6 +6,7 @@ use App\User; use Tests\TestCase; use Illuminate\Auth\Authenticatable; use Illuminate\Support\Facades\Auth; +use Illuminate\Support\Facades\Hash; class UserTest extends TestCase { @@ -277,6 +278,10 @@ class UserTest extends TestCase $response->assertStatus(200) ->assertJsonStructure(['message']); + + $user->refresh(); + + $this->assertTrue(Hash::check('passwordUpdated', $user->password)); }