Edit file File name : TagControllerTest.php Content :<?php /* * This file is part of the Kimai time-tracking app. * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace App\Tests\API; use App\Entity\Tag; use App\Entity\User; use App\Tests\DataFixtures\TagFixtures; use Symfony\Component\HttpFoundation\Response; /** * @group integration */ class TagControllerTest extends APIControllerBaseTest { /** * @return Tag[] */ protected function importTagFixtures(): array { $tagList = ['Test', 'Administration', 'Support', '#2018-001', '#2018-002', '#2018-003', 'Development', 'Marketing', 'First Level Support', 'Bug Fixing']; $fixture = new TagFixtures(); $fixture->setTagArray($tagList); return $this->importFixture($fixture); } public function testIsSecure() { $this->assertUrlIsSecured('/api/tags'); } public function testGetCollection() { $client = $this->getClientForAuthenticatedUser(User::ROLE_USER); $this->importTagFixtures(); $this->assertAccessIsGranted($client, '/api/tags'); $result = json_decode($client->getResponse()->getContent(), true); $this->assertIsArray($result); $this->assertNotEmpty($result); $this->assertEquals(10, \count($result)); $this->assertEquals('Test', $result[9]); } public function testEmptyCollection() { $client = $this->getClientForAuthenticatedUser(User::ROLE_USER); $this->importTagFixtures(); $query = ['name' => 'nothing']; $this->assertAccessIsGranted($client, '/api/tags', 'GET', $query); $result = json_decode($client->getResponse()->getContent(), true); $this->assertIsArray($result); $this->assertEmpty($result); $this->assertEquals(0, \count($result)); } public function testPostAction() { $client = $this->getClientForAuthenticatedUser(User::ROLE_ADMIN); $this->importTagFixtures(); $data = [ 'name' => 'foo', 'color' => '#00ff00' ]; $this->request($client, '/api/tags', 'POST', [], json_encode($data)); $this->assertTrue($client->getResponse()->isSuccessful()); $result = json_decode($client->getResponse()->getContent(), true); $this->assertIsArray($result); self::assertApiResponseTypeStructure('TagEntity', $result); $this->assertNotEmpty($result['id']); self::assertEquals('#00ff00', $result['color']); } public function testPostActionWithValidationErrors() { $client = $this->getClientForAuthenticatedUser(User::ROLE_ADMIN); $this->importTagFixtures(); $data = [ 'name' => '1', 'color' => '11231231231', ]; $this->request($client, '/api/tags', 'POST', [], json_encode($data)); $response = $client->getResponse(); $this->assertEquals(400, $response->getStatusCode()); $this->assertApiCallValidationError($response, ['name', 'color']); } public function testPostActionWithInvalidUser() { $client = $this->getClientForAuthenticatedUser(User::ROLE_USER); $this->importTagFixtures(); $data = [ 'name' => 'foo', ]; $this->request($client, '/api/tags', 'POST', [], json_encode($data)); $response = $client->getResponse(); $this->assertFalse($response->isSuccessful()); $this->assertEquals(Response::HTTP_FORBIDDEN, $response->getStatusCode()); $json = json_decode($response->getContent(), true); $this->assertEquals('User cannot create tags', $json['message']); } public function testPartOfEntries() { $client = $this->getClientForAuthenticatedUser(User::ROLE_USER); $this->importTagFixtures(); $query = ['name' => 'in']; $this->assertAccessIsGranted($client, '/api/tags', 'GET', $query); $result = json_decode($client->getResponse()->getContent(), true); $this->assertIsArray($result); $this->assertNotEmpty($result); $this->assertEquals(3, \count($result)); $this->assertEquals('Administration', $result[0]); $this->assertEquals('Bug Fixing', $result[1]); $this->assertEquals('Marketing', $result[2]); } public function testDeleteAction() { $client = $this->getClientForAuthenticatedUser(User::ROLE_ADMIN); $tags = $this->importTagFixtures(); $id = $tags[0]->getId(); $this->request($client, '/api/tags/' . $id, 'DELETE'); $this->assertTrue($client->getResponse()->isSuccessful()); $this->assertEquals(Response::HTTP_NO_CONTENT, $client->getResponse()->getStatusCode()); $this->assertEmpty($client->getResponse()->getContent()); $this->assertAccessIsGranted($client, '/api/tags'); $result = json_decode($client->getResponse()->getContent(), true); $this->assertEquals(9, \count($result)); } public function testDeleteActionWithUnknownTimesheet() { $this->assertEntityNotFoundForDelete(User::ROLE_ADMIN, '/api/tags/' . PHP_INT_MAX); } } Save