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)
This commit is contained in:
ext.jeremy.guillot@maxicoffee.domains
2026-03-26 17:55:12 +01:00
parent 5a0888eb28
commit 5ed303612a
371 changed files with 6194 additions and 4160 deletions

View File

@@ -26,13 +26,14 @@ class MangadexClientTest extends TestCase
);
}
private function mockAuthenticationResponse(): MockObject&ResponseInterface
private function mockAuthenticationResponse(): MockObject&ResponseInterface
{
$authResponse = $this->createMock(ResponseInterface::class);
$authResponse->method('toArray')->willReturn([
'access_token' => 'access_token',
'refresh_token' => 'refresh_token'
'refresh_token' => 'refresh_token',
]);
return $authResponse;
}
@@ -46,11 +47,11 @@ class MangadexClientTest extends TestCase
'POST',
'https://auth.mangadex.org/realms/mangadex/protocol/openid-connect/token',
$this->callback(function ($options) {
return $options['body']['grant_type'] === 'password'
&& $options['body']['username'] === 'username'
&& $options['body']['password'] === 'password'
&& $options['body']['client_id'] === 'client_id'
&& $options['body']['client_secret'] === 'client_secret';
return 'password' === $options['body']['grant_type']
&& 'username' === $options['body']['username']
&& 'password' === $options['body']['password']
&& 'client_id' === $options['body']['client_id']
&& 'client_secret' === $options['body']['client_secret'];
})
)
->willReturn($response);
@@ -76,10 +77,10 @@ class MangadexClientTest extends TestCase
[
'id' => '123',
'attributes' => [
'title' => ['en' => 'Test Manga']
]
]
]
'title' => ['en' => 'Test Manga'],
],
],
],
];
$authResponse = $this->mockAuthenticationResponse();
@@ -93,6 +94,7 @@ class MangadexClientTest extends TestCase
if (str_contains($url, 'auth.mangadex.org')) {
return $authResponse;
}
return $searchResponse;
});
@@ -105,9 +107,9 @@ class MangadexClientTest extends TestCase
$expectedResponse = [
'statistics' => [
'123' => [
'rating' => ['average' => 4.5]
]
]
'rating' => ['average' => 4.5],
],
],
];
$authResponse = $this->mockAuthenticationResponse();
@@ -121,10 +123,11 @@ class MangadexClientTest extends TestCase
if (str_contains($url, 'auth.mangadex.org')) {
return $authResponse;
}
return $ratingsResponse;
});
$result = $this->client->getMangaRatings(['123']);
$this->assertEquals($expectedResponse, $result);
}
}
}