Files
Mangarr/tests/Domain/Scraping/Adapter/InMemorySourceRepository.php
ext.jeremy.guillot@maxicoffee.domains 5ed303612a feat: migrer vers Symfony 8, PHP 8.4 et les dépendances majeures associées
- 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)
2026-03-26 17:55:12 +01:00

95 lines
2.3 KiB
PHP

<?php
namespace App\Tests\Domain\Scraping\Adapter;
use App\Domain\Scraping\Domain\Contract\Repository\SourceRepositoryInterface;
use App\Domain\Scraping\Domain\Model\Source;
use App\Domain\Scraping\Domain\Model\ValueObject\SourceId;
class InMemorySourceRepository implements SourceRepositoryInterface
{
private array $sources = [];
public function __construct()
{
// Ajoute une source par défaut pour les tests
$this->sources['test-source'] = new Source(
new SourceId('test-source'),
'Test Source',
'A test source',
'https://example.com',
[
'imageSelector' => 'img.manga-image',
'nextPageSelector' => null,
'chapterUrlFormat' => 'https://example.com/manga/{slug}/chapter-{chapterNumber}',
'scrapingType' => 'html',
'chapterSelector' => '.chapter-item',
],
true,
new \DateTimeImmutable(),
new \DateTimeImmutable()
);
}
public function getById(string $id): ?Source
{
return $this->sources[$id] ?? null;
}
/**
* @return Source[]
*/
public function getAll(): array
{
return array_values($this->sources);
}
public function save(Source $source): void
{
$this->sources[$source->getId()->getValue()] = $source;
}
public function validateSourcesExist(array $sourceIds): bool
{
foreach ($sourceIds as $sourceId) {
$source = $this->sources[$sourceId] ?? null;
if (!$source || !$source->isActive()) {
return false;
}
}
return true;
}
/**
* @return Source[]
*/
public function getByIds(array $sourceIds): array
{
$sources = [];
foreach ($sourceIds as $sourceId) {
if (isset($this->sources[$sourceId])) {
$sources[] = $this->sources[$sourceId];
}
}
return $sources;
}
/**
* @return Source[]
*/
public function getAllActive(): array
{
return array_filter(
array_values($this->sources),
fn (Source $source) => $source->isActive()
);
}
public function clear(): void
{
$this->sources = [];
}
}