user = User::factory()->create(); } /** * @test */ public function test_index_returns_group_collection_with_pseudo_group() { Group::factory()->count(3)->for($this->user)->create(); $response = $this->actingAs($this->user, 'api-guard') ->json('GET', '/api/v1/groups') ->assertOk() ->assertJsonCount(4, $key = null) ->assertJsonStructure([ '*' => [ 'id', 'name', 'twofaccounts_count', ], ]) ->assertJsonFragment([ 'id' => 0, 'name' => 'All', 'twofaccounts_count' => 0, ]); } /** * @test */ public function test_store_returns_created_group_resource() { $response = $this->actingAs($this->user, 'api-guard') ->json('POST', '/api/v1/groups', [ 'name' => 'My second group', ]) ->assertCreated() ->assertJsonFragment([ 'name' => 'My second group', 'twofaccounts_count' => 0, ]); } /** * @test */ public function test_store_invalid_data_returns_validation_error() { $response = $this->actingAs($this->user, 'api-guard') ->json('POST', '/api/v1/groups', [ 'name' => null, ]) ->assertStatus(422); } /** * @test */ public function test_show_returns_group_resource() { $group = Group::factory()->for($this->user)->create([ 'name' => 'My group', ]); $response = $this->actingAs($this->user, 'api-guard') ->json('GET', '/api/v1/groups/' . $group->id) ->assertOk() ->assertJsonFragment([ 'name' => 'My group', 'twofaccounts_count' => 0, ]); } /** * @test */ public function test_show_missing_group_returns_not_found() { $response = $this->actingAs($this->user, 'api-guard') ->json('GET', '/api/v1/groups/1000') ->assertNotFound() ->assertJsonStructure([ 'message', ]); } /** * @test */ public function test_update_returns_updated_group_resource() { $group = Group::factory()->for($this->user)->create(); $response = $this->actingAs($this->user, 'api-guard') ->json('PUT', '/api/v1/groups/' . $group->id, [ 'name' => 'name updated', ]) ->assertOk() ->assertJsonFragment([ 'name' => 'name updated', 'twofaccounts_count' => 0, ]); } /** * @test */ public function test_update_missing_group_returns_not_found() { $response = $this->actingAs($this->user, 'api-guard') ->json('PUT', '/api/v1/groups/1000', [ 'name' => 'testUpdate', ]) ->assertNotFound() ->assertJsonStructure([ 'message', ]); } /** * @test */ public function test_update_with_invalid_data_returns_validation_error() { $group = Group::factory()->for($this->user)->create(); $response = $this->actingAs($this->user, 'api-guard') ->json('PUT', '/api/v1/groups/' . $group->id, [ 'name' => null, ]) ->assertStatus(422); } /** * @test */ public function test_assign_accounts_returns_updated_group_resource() { $group = Group::factory()->for($this->user)->create(); $accounts = TwoFAccount::factory()->count(2)->for($this->user)->create(); $response = $this->actingAs($this->user, 'api-guard') ->json('POST', '/api/v1/groups/' . $group->id . '/assign', [ 'ids' => [$accounts[0]->id, $accounts[1]->id], ]) ->assertOk() ->assertExactJson([ 'id' => $group->id, 'name' => $group->name, 'twofaccounts_count' => 2, ]); } /** * @test */ public function test_assign_accounts_to_missing_group_returns_not_found() { $accounts = TwoFAccount::factory()->count(2)->for($this->user)->create(); $response = $this->actingAs($this->user, 'api-guard') ->json('POST', '/api/v1/groups/1000/assign', [ 'ids' => [$accounts[0]->id, $accounts[1]->id], ]) ->assertNotFound() ->assertJsonStructure([ 'message', ]); } /** * @test */ public function test_assign_invalid_accounts_returns_validation_error() { $group = Group::factory()->for($this->user)->create(); $accounts = TwoFAccount::factory()->count(2)->for($this->user)->create(); $response = $this->actingAs($this->user, 'api-guard') ->json('POST', '/api/v1/groups/' . $group->id . '/assign', [ 'ids' => 1, ]) ->assertStatus(422); } /** * @test */ public function test_get_assigned_accounts_returns_twofaccounts_collection() { $group = Group::factory()->for($this->user)->create(); $accounts = TwoFAccount::factory()->count(2)->for($this->user)->create(); $assign = $this->actingAs($this->user, 'api-guard') ->json('POST', '/api/v1/groups/' . $group->id . '/assign', [ 'ids' => [$accounts[0]->id, $accounts[1]->id], ]); $response = $this->actingAs($this->user, 'api-guard') ->json('GET', '/api/v1/groups/' . $group->id . '/twofaccounts') ->assertOk() ->assertJsonCount(2) ->assertJsonStructure([ '*' => [ 'group_id', 'service', 'account', 'icon', 'otp_type', 'digits', 'algorithm', 'period', 'counter', ], ]); } /** * @test */ public function test_get_assigned_accounts_returns_twofaccounts_collection_with_secret() { $group = Group::factory()->for($this->user)->create(); $accounts = TwoFAccount::factory()->count(2)->for($this->user)->create(); $assign = $this->actingAs($this->user, 'api-guard') ->json('POST', '/api/v1/groups/' . $group->id . '/assign', [ 'ids' => [$accounts[0]->id, $accounts[1]->id], ]); $response = $this->actingAs($this->user, 'api-guard') ->json('GET', '/api/v1/groups/' . $group->id . '/twofaccounts?withSecret=1') ->assertOk() ->assertJsonCount(2) ->assertJsonStructure([ '*' => [ 'group_id', 'service', 'account', 'icon', 'secret', 'otp_type', 'digits', 'algorithm', 'period', 'counter', ], ]); } /** * @test */ public function test_get_assigned_accounts_of_missing_group_returns_not_found() { $response = $this->actingAs($this->user, 'api-guard') ->json('GET', '/api/v1/groups/1000/twofaccounts') ->assertNotFound() ->assertJsonStructure([ 'message', ]); } /** * test Group deletion via API * * @test */ public function test_destroy_group_returns_success() { $group = Group::factory()->for($this->user)->create(); $response = $this->actingAs($this->user, 'api-guard') ->json('DELETE', '/api/v1/groups/' . $group->id) ->assertNoContent(); } /** * test Group deletion via API * * @test */ public function test_destroy_missing_group_returns_not_found() { $response = $this->actingAs($this->user, 'api-guard') ->json('DELETE', '/api/v1/groups/1000') ->assertNotFound() ->assertJsonStructure([ 'message', ]); } }