feat: GetMangaList endpoint + tests + test db
This commit is contained in:
parent
073439163b
commit
e3d380eadd
25
tests/Feature/AbstractApiTestCase.php
Normal file
25
tests/Feature/AbstractApiTestCase.php
Normal file
@@ -0,0 +1,25 @@
|
||||
<?php
|
||||
|
||||
namespace App\Tests\Feature;
|
||||
|
||||
use ApiPlatform\Symfony\Bundle\Test\ApiTestCase;
|
||||
use Doctrine\ORM\EntityManagerInterface;
|
||||
use Symfony\Component\DependencyInjection\ContainerInterface;
|
||||
|
||||
abstract class AbstractApiTestCase extends ApiTestCase
|
||||
{
|
||||
protected ?EntityManagerInterface $entityManager;
|
||||
protected ?ContainerInterface $container;
|
||||
|
||||
protected function setUp(): void
|
||||
{
|
||||
parent::setUp();
|
||||
$this->container = static::getContainer();
|
||||
$this->entityManager = $this->container->get(EntityManagerInterface::class);
|
||||
}
|
||||
|
||||
protected function tearDown(): void
|
||||
{
|
||||
parent::tearDown();
|
||||
}
|
||||
}
|
||||
107
tests/Feature/Manga/GetMangaListTest.php
Normal file
107
tests/Feature/Manga/GetMangaListTest.php
Normal file
@@ -0,0 +1,107 @@
|
||||
<?php
|
||||
|
||||
namespace App\Tests\Feature\Manga;
|
||||
|
||||
use App\Entity\Manga;
|
||||
use App\Tests\Feature\AbstractApiTestCase;
|
||||
use Zenstruck\Foundry\Test\ResetDatabase;
|
||||
|
||||
class GetMangaListTest extends AbstractApiTestCase
|
||||
{
|
||||
use ResetDatabase;
|
||||
|
||||
public function testGetEmptyMangaList(): void
|
||||
{
|
||||
// When
|
||||
$client = static::createClient();
|
||||
$response = $client->request('GET', '/api/mangas');
|
||||
|
||||
// Then
|
||||
$this->assertResponseIsSuccessful();
|
||||
$this->assertJsonContains([
|
||||
'total' => 0,
|
||||
'page' => 1,
|
||||
'limit' => 20,
|
||||
'hasNextPage' => false,
|
||||
'hasPreviousPage' => false,
|
||||
'items' => []
|
||||
]);
|
||||
}
|
||||
|
||||
public function testGetMangaListWithPagination(): void
|
||||
{
|
||||
// Given
|
||||
$this->createMangas(25);
|
||||
|
||||
// When
|
||||
$client = static::createClient();
|
||||
$response = $client->request('GET', '/api/mangas', [
|
||||
'query' => [
|
||||
'page' => 2,
|
||||
'limit' => 10
|
||||
]
|
||||
]);
|
||||
|
||||
// Then
|
||||
$this->assertResponseIsSuccessful();
|
||||
$data = $response->toArray();
|
||||
|
||||
$this->assertCount(10, $data['items']);
|
||||
$this->assertEquals(25, $data['total']);
|
||||
$this->assertEquals(2, $data['page']);
|
||||
$this->assertEquals(10, $data['limit']);
|
||||
$this->assertTrue($data['hasNextPage']);
|
||||
$this->assertTrue($data['hasPreviousPage']);
|
||||
}
|
||||
|
||||
public function testGetMangaListWithSorting(): void
|
||||
{
|
||||
// Given
|
||||
$this->createManga('Manga B');
|
||||
$this->createManga('Manga A');
|
||||
$this->createManga('Manga C');
|
||||
|
||||
// When
|
||||
$client = static::createClient();
|
||||
$response = $client->request('GET', '/api/mangas', [
|
||||
'query' => [
|
||||
'sortBy' => 'title',
|
||||
'sortOrder' => 'asc'
|
||||
]
|
||||
]);
|
||||
|
||||
// Then
|
||||
$this->assertResponseIsSuccessful();
|
||||
$data = $response->toArray();
|
||||
|
||||
$this->assertCount(3, $data['items']);
|
||||
$this->assertEquals('Manga A', $data['items'][0]['title']);
|
||||
$this->assertEquals('Manga B', $data['items'][1]['title']);
|
||||
$this->assertEquals('Manga C', $data['items'][2]['title']);
|
||||
}
|
||||
|
||||
private function createMangas(int $count): void
|
||||
{
|
||||
for ($i = 1; $i <= $count; $i++) {
|
||||
$this->createManga("Manga $i");
|
||||
}
|
||||
}
|
||||
|
||||
private function createManga(string $title): void
|
||||
{
|
||||
$manga = new Manga();
|
||||
$manga->setTitle($title)
|
||||
->setSlug(strtolower(str_replace(' ', '-', $title)))
|
||||
->setDescription('Description test')
|
||||
->setAuthor('Author test')
|
||||
->setPublicationYear(2020)
|
||||
->setGenres(['action'])
|
||||
->setStatus('ongoing')
|
||||
->setRating(4.5)
|
||||
->setMonitored(false)
|
||||
;
|
||||
|
||||
$this->entityManager->persist($manga);
|
||||
$this->entityManager->flush();
|
||||
}
|
||||
}
|
||||
@@ -1,18 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace App\Tests\Feature\Scraping;
|
||||
|
||||
use ApiPlatform\Symfony\Bundle\Test\ApiTestCase;
|
||||
|
||||
abstract class AbstractApiTestCase extends ApiTestCase
|
||||
{
|
||||
protected function setUp(): void
|
||||
{
|
||||
parent::setUp();
|
||||
}
|
||||
|
||||
protected function tearDown(): void
|
||||
{
|
||||
parent::tearDown();
|
||||
}
|
||||
}
|
||||
@@ -4,6 +4,7 @@ namespace App\Tests\Feature\Scraping;
|
||||
|
||||
use App\Domain\Scraping\Application\Command\ScrapeChapter;
|
||||
use App\Tests\Domain\Scraping\Adapter\InMemoryMessageBus;
|
||||
use App\Tests\Feature\AbstractApiTestCase;
|
||||
use Symfony\Component\Messenger\MessageBusInterface;
|
||||
|
||||
class ScrapeChapterTest extends AbstractApiTestCase
|
||||
|
||||
Reference in New Issue
Block a user