- PHP 8.3 → 8.4 (Dockerfile + composer.json) - Symfony 7.0 → 8.0 (tous les composants symfony/*) - API Platform 3.x → 4.x : migration openapiContext → openapi: new Operation(...) - Doctrine DBAL 3 → 4 : suppression use_savepoints, replace prepare/executeQuery - Doctrine ORM 2.x → 3.x : ClassMetadataInfo → ClassMetadata, setParameters → setParameter - Doctrine Bundle 2.x → 3.x, Fixtures Bundle 3.x → 4.x - zenstruck/foundry 1.x → 2.x : ModelFactory → PersistentObjectFactory, getDefaults → defaults - phpmd/phpmd 2.x → 3.x-dev (seule version supportant Symfony 8) - phparkitect 0.3 → 0.8 : NotDependsOnTheseNamespaces prend un array - symfony/mercure-bundle 0.3 → 0.4, symfony/monolog-bundle 3 → 4 - Suppression de runtime/frankenphp-symfony (intégré nativement dans symfony/runtime 8) - worker.Caddyfile : suppression de APP_RUNTIME (détection automatique Symfony 8) - Routes errors.xml/wdt.xml/profiler.xml → .php (Symfony 8 supprime le XML) - Types::ARRAY → Types::JSON dans Entity/Manga.php (DBAL 4 retire array type) - Suppression de src/Schedule.php (doublon vide avec MonitoringSchedule) - Tests : hydra:Collection → Collection, hydra:member → member (API Platform 4)
60 lines
1.9 KiB
PHP
60 lines
1.9 KiB
PHP
<?php
|
|
|
|
namespace App\Tests\Domain\Manga\Application\QueryHandler;
|
|
|
|
use App\Domain\Manga\Application\Query\SearchManga;
|
|
use App\Domain\Manga\Application\QueryHandler\SearchMangaHandler;
|
|
use App\Domain\Manga\Domain\Model\Manga;
|
|
use App\Domain\Manga\Domain\Model\ValueObject\ExternalId;
|
|
use App\Domain\Manga\Domain\Model\ValueObject\MangaId;
|
|
use App\Domain\Manga\Domain\Model\ValueObject\MangaSlug;
|
|
use App\Domain\Manga\Domain\Model\ValueObject\MangaTitle;
|
|
use App\Tests\Domain\Manga\Adapter\InMemoryMangaProvider;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
class SearchMangaHandlerTest extends TestCase
|
|
{
|
|
public function testHandleReturnsEmptyResultWhenNoMatches(): void
|
|
{
|
|
// Arrange
|
|
$provider = new InMemoryMangaProvider([]);
|
|
$handler = new SearchMangaHandler($provider);
|
|
|
|
// Act
|
|
$response = $handler->handle(new SearchManga('One Piece'));
|
|
|
|
// Assert
|
|
$this->assertEmpty($response->items);
|
|
}
|
|
|
|
public function testHandleReturnsMangaSearchResults(): void
|
|
{
|
|
// Arrange
|
|
$manga = new Manga(
|
|
new MangaId('123'),
|
|
new MangaTitle('One Piece'),
|
|
new MangaSlug('one-piece'),
|
|
'Description test',
|
|
'Eiichiro Oda',
|
|
1997,
|
|
['action', 'adventure'],
|
|
'ongoing',
|
|
new ExternalId('external-123'),
|
|
'http://example.com/image.jpg',
|
|
4.5
|
|
);
|
|
|
|
$provider = new InMemoryMangaProvider([$manga]);
|
|
$handler = new SearchMangaHandler($provider);
|
|
|
|
// Act
|
|
$response = $handler->handle(new SearchManga('One Piece'));
|
|
|
|
// Assert
|
|
$this->assertCount(1, $response->items);
|
|
$this->assertEquals('external-123', $response->items[0]->externalId);
|
|
$this->assertEquals('One Piece', $response->items[0]->title);
|
|
$this->assertEquals('one-piece', $response->items[0]->slug);
|
|
}
|
|
}
|