From 13f526ccb136868f4f02de6a0e1fa05fb8f92050 Mon Sep 17 00:00:00 2001 From: Bubka <858858+Bubka@users.noreply.github.com> Date: Mon, 2 Mar 2020 17:11:17 +0100 Subject: [PATCH] Enhance unit tests coverage --- tests/Unit/IconTest.php | 61 ++++++++++++++++++++ tests/Unit/OtpTest.php | 99 +++++++++++++++++++++++++++++++++ tests/Unit/QrcodeTest.php | 81 +++++++++++++++++++++++++++ tests/Unit/RouteTest.php | 22 ++++++++ tests/Unit/UserTest.php | 113 +++++++++++++++++++++++++++++++++++++- 5 files changed, 373 insertions(+), 3 deletions(-) create mode 100644 tests/Unit/IconTest.php create mode 100644 tests/Unit/OtpTest.php create mode 100644 tests/Unit/QrcodeTest.php create mode 100644 tests/Unit/RouteTest.php diff --git a/tests/Unit/IconTest.php b/tests/Unit/IconTest.php new file mode 100644 index 00000000..ec1a24e4 --- /dev/null +++ b/tests/Unit/IconTest.php @@ -0,0 +1,61 @@ +json('POST', '/api/icon/upload', [ + 'icon' => '', + ]) + ->assertStatus(422); + } + + + /** + * test upload icon via API + * + * @test + */ + public function testIconUpload() + { + + $file = UploadedFile::fake()->image('testIcon.jpg'); + + $response = $this->json('POST', '/api/icon/upload', [ + 'icon' => $file, + ]) + ->assertStatus(201); + + } + + + /** + * test delete an uploaded icon via API + * + * @test + */ + public function testIconDelete() + { + + $response = $this->json('DELETE', '/api/icon/delete/testIcon.jpg') + ->assertStatus(204); + + } + +} \ No newline at end of file diff --git a/tests/Unit/OtpTest.php b/tests/Unit/OtpTest.php new file mode 100644 index 00000000..0f771b24 --- /dev/null +++ b/tests/Unit/OtpTest.php @@ -0,0 +1,99 @@ +assertArrayHasKey('otp', $result); + $this->assertArrayHasKey('position', $result); + } + + + /** + * test HOTP generation (with $isPreview = false to prevent db update) + * + * @test + */ + public function testHOTPGeneration() + { + $uri = 'otpauth://hotp/test:test@test.com?counter=16&secret=A4GRFHVIRBGY7UIW'; + + $result = OTP::generate($uri, true); + + $this->assertArrayHasKey('otp', $result); + $this->assertArrayHasKey('counter', $result); + $this->assertArrayHasKey('nextUri', $result); + } + + + /** + * test if provided TOTP uri is valid + * + * @test + */ + public function testTOTPUriIsValid() + { + $uri = 'otpauth://totp/test@test.com?secret=A4GRFHVIRBGY7UIW&issuer=test'; + + $result = OTP::get($uri); + + $this->assertInstanceOf(TOTP::class, $result); + } + + + /** + * test if provided HOTP uri is valid + * + * @test + */ + public function testHOTPUriIsValid() + { + $uri = 'otpauth://hotp/test:test@test.com?counter=16&secret=A4GRFHVIRBGY7UIW'; + + $result = OTP::get($uri); + + $this->assertInstanceOf(HOTP::class, $result); + } + + + /** + * test invalid privded uri returns a ValidationException exception + * + * @test + */ + public function testInvalidUriReturnValidationException() + { + $uri = 'otpauth://totp/'; + + $this->expectException(\Illuminate\Validation\ValidationException::class); + + OTP::get($uri); + } + +} diff --git a/tests/Unit/QrcodeTest.php b/tests/Unit/QrcodeTest.php new file mode 100644 index 00000000..08119099 --- /dev/null +++ b/tests/Unit/QrcodeTest.php @@ -0,0 +1,81 @@ +json('POST', '/api/qrcode/decode', [ + 'qrcode' => '', + ]) + ->assertStatus(422); + } + + + /** + * 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() + { + //Storage::fake('qrcodes'); + + $image = ''; + + + //Storage::put('tests/qrcodeTest.png', base64_decode($image)); + + //$this->assertFileExists('storage/app/tests/qrcodeTest.png'); + + $response = $this->withHeaders([ + 'Content-Type' => 'multipart/form-data', + ]) + ->json('POST', '/api/qrcode/decode', [ + 'qrcode' => $image + ]); + + $response->dump(); + $response->dumpHeaders(); + + $response->assertStatus(200); + } + +} \ No newline at end of file diff --git a/tests/Unit/RouteTest.php b/tests/Unit/RouteTest.php new file mode 100644 index 00000000..800043bf --- /dev/null +++ b/tests/Unit/RouteTest.php @@ -0,0 +1,22 @@ +get('/'); + + $response->assertViewIs('landing'); + } + +} \ No newline at end of file diff --git a/tests/Unit/UserTest.php b/tests/Unit/UserTest.php index 8f8b3219..197ffccc 100644 --- a/tests/Unit/UserTest.php +++ b/tests/Unit/UserTest.php @@ -24,12 +24,27 @@ class UserTest extends TestCase } + /** + * test Existing user count via API + * + * @test + */ + public function testExistingUserCount() + { + $response = $this->json('POST', '/api/checkuser') + ->assertStatus(200) + ->assertJson([ + 'userCount' => '1', + ]); + } + + /** * test creation of another user via API * * @test */ - public function testMoreThanOneUserCreation() + public function testUserCreationWithAnExistingUser() { $response = $this->json('POST', '/api/register', [ 'name' => 'testCreate', @@ -49,6 +64,9 @@ class UserTest extends TestCase */ public function testUserCreationWithMissingValues() { + // we delete the existing user + User::destroy(1); + $response = $this->json('POST', '/api/register', [ 'name' => '', 'email' => '', @@ -56,7 +74,7 @@ class UserTest extends TestCase 'password_confirmation' => '', ]); - $response->assertStatus(400); + $response->assertStatus(422); } @@ -67,6 +85,9 @@ class UserTest extends TestCase */ public function testUserCreationWithInvalidData() { + // we delete the existing user + User::destroy(1); + $response = $this->json('POST', '/api/register', [ 'name' => 'testInvalid', 'email' => 'email', @@ -74,7 +95,7 @@ class UserTest extends TestCase 'password_confirmation' => 'tset', ]); - $response->assertStatus(400); + $response->assertStatus(422); } @@ -173,6 +194,92 @@ class UserTest extends TestCase } + /** + * test User update with wrong current password via API + * + * @test + */ + public function testUserUpdateWithWrongCurrentPassword() + { + $user = User::find(1); + + $response = $this->actingAs($user, 'api') + ->json('PATCH', '/api/user', [ + 'name' => 'userUpdated', + 'email' => 'userUpdated@example.org', + 'password' => 'wrongPassword', + ]); + + $response->assertStatus(400) + ->assertJsonStructure(['message']); + } + + + /** + * test User update via API + * + * @test + */ + public function testUserUpdate() + { + $user = User::find(1); + + $response = $this->actingAs($user, 'api') + ->json('PATCH', '/api/user', [ + 'name' => 'userUpdated', + 'email' => 'userUpdated@example.org', + 'password' => 'password', + ]); + + $response->assertStatus(200) + ->assertJsonFragment([ + 'username' => 'userUpdated' + ]); + } + + + /** + * test User password update with wrong current password via API + * + * @test + */ + public function testUserPasswordUpdateWithWrongCurrentPassword() + { + $user = User::find(1); + + $response = $this->actingAs($user, 'api') + ->json('PATCH', '/api/password', [ + 'currentPassword' => 'wrongPassword', + 'password' => 'passwordUpdated', + 'password_confirmation' => 'passwordUpdated', + ]); + + $response->assertStatus(400) + ->assertJsonStructure(['message']); + } + + + /** + * test User password update via API + * + * @test + */ + public function testUserPasswordUpdate() + { + $user = User::find(1); + + $response = $this->actingAs($user, 'api') + ->json('PATCH', '/api/password', [ + 'currentPassword' => 'password', + 'password' => 'passwordUpdated', + 'password_confirmation' => 'passwordUpdated', + ]); + + $response->assertStatus(200) + ->assertJsonStructure(['message']); + } + + /** * test User creation via API *