mirror of
https://github.com/kevinpapst/kimai2.git
synced 2025-01-11 03:48:10 +00:00
127 lines
4.1 KiB
PHP
127 lines
4.1 KiB
PHP
<?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\Invoice;
|
|
use App\Entity\User;
|
|
use App\Tests\DataFixtures\InvoiceFixtures;
|
|
|
|
/**
|
|
* @group integration
|
|
*/
|
|
class InvoiceControllerTest extends APIControllerBaseTestCase
|
|
{
|
|
/**
|
|
* @return Invoice[]
|
|
*/
|
|
protected function importInvoiceFixtures(int $amount, ?array $status = null): array
|
|
{
|
|
$fixture = new InvoiceFixtures();
|
|
$fixture->setAmount($amount);
|
|
if (\is_array($status)) {
|
|
$fixture->setStatus($status);
|
|
}
|
|
|
|
return $this->importFixture($fixture);
|
|
}
|
|
|
|
public function testIsSecure(): void
|
|
{
|
|
$this->assertUrlIsSecured('/api/invoices');
|
|
}
|
|
|
|
public function testGetCollection(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser(User::ROLE_TEAMLEAD);
|
|
$this->importInvoiceFixtures(10);
|
|
|
|
$this->assertAccessIsGranted($client, '/api/invoices');
|
|
|
|
$content = $client->getResponse()->getContent();
|
|
self::assertIsString($content);
|
|
$result = json_decode($content, true);
|
|
|
|
self::assertIsArray($result);
|
|
self::assertNotEmpty($result);
|
|
self::assertEquals(10, \count($result));
|
|
self::assertIsArray($result[0]);
|
|
self::assertApiResponseTypeStructure('InvoiceCollection', $result[0]);
|
|
}
|
|
|
|
public function testGetCollectionWithQuery(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser(User::ROLE_TEAMLEAD);
|
|
$this->importInvoiceFixtures(5, [Invoice::STATUS_PENDING]);
|
|
$this->importInvoiceFixtures(2, [Invoice::STATUS_NEW]);
|
|
$this->importInvoiceFixtures(7, [Invoice::STATUS_PAID]);
|
|
$this->importInvoiceFixtures(1, [Invoice::STATUS_CANCELED]);
|
|
|
|
$query = ['order' => 'ASC', 'orderBy' => 'name', 'status' => [Invoice::STATUS_PAID]];
|
|
$this->assertAccessIsGranted($client, '/api/invoices', 'GET', $query);
|
|
|
|
$content = $client->getResponse()->getContent();
|
|
self::assertIsString($content);
|
|
$result = json_decode($content, true);
|
|
|
|
self::assertIsArray($result);
|
|
self::assertNotEmpty($result);
|
|
self::assertEquals(7, \count($result));
|
|
self::assertIsArray($result[0]);
|
|
self::assertApiResponseTypeStructure('InvoiceCollection', $result[0]);
|
|
}
|
|
|
|
public function testGetCollectionWithPagination(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser(User::ROLE_TEAMLEAD);
|
|
$this->importInvoiceFixtures(20);
|
|
|
|
$query = ['page' => 2, 'size' => 4];
|
|
$this->assertAccessIsGranted($client, '/api/invoices', 'GET', $query);
|
|
|
|
$content = $client->getResponse()->getContent();
|
|
self::assertIsString($content);
|
|
$result = json_decode($content, true);
|
|
|
|
self::assertIsArray($result);
|
|
self::assertNotEmpty($result);
|
|
self::assertEquals(4, \count($result));
|
|
$this->assertPagination($client->getResponse(), 2, 4, 5, 20);
|
|
self::assertIsArray($result[0]);
|
|
self::assertApiResponseTypeStructure('InvoiceCollection', $result[0]);
|
|
}
|
|
|
|
public function testGetEntityIsSecure(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser();
|
|
$invoices = $this->importInvoiceFixtures(1);
|
|
|
|
$this->assertApiAccessDenied($client, '/api/invoices/' . $invoices[0]->getId());
|
|
}
|
|
|
|
public function testGetEntity(): void
|
|
{
|
|
$client = $this->getClientForAuthenticatedUser(User::ROLE_ADMIN);
|
|
$invoices = $this->importInvoiceFixtures(1);
|
|
|
|
$this->assertAccessIsGranted($client, '/api/invoices/' . $invoices[0]->getId());
|
|
|
|
$content = $client->getResponse()->getContent();
|
|
self::assertIsString($content);
|
|
$result = json_decode($content, true);
|
|
|
|
self::assertIsArray($result);
|
|
self::assertApiResponseTypeStructure('Invoice', $result);
|
|
}
|
|
|
|
public function testNotFound(): void
|
|
{
|
|
$this->assertEntityNotFound(User::ROLE_USER, '/api/invoices/' . PHP_INT_MAX);
|
|
}
|
|
}
|