From 6269871e0919239b0d290632e84c008893078af7 Mon Sep 17 00:00:00 2001 From: soyuka Date: Mon, 14 Oct 2024 11:42:58 +0200 Subject: [PATCH] fix(symfony): fetch api-platform/symfony version debug bar fixes #6709 --- .../DataCollector/RequestDataCollector.php | 29 +++++++++++++++++-- .../RequestDataCollectorTest.php | 7 ++++- 2 files changed, 32 insertions(+), 4 deletions(-) diff --git a/src/Symfony/Bundle/DataCollector/RequestDataCollector.php b/src/Symfony/Bundle/DataCollector/RequestDataCollector.php index ddde1871a0e..f409b5cd362 100644 --- a/src/Symfony/Bundle/DataCollector/RequestDataCollector.php +++ b/src/Symfony/Bundle/DataCollector/RequestDataCollector.php @@ -16,6 +16,7 @@ use ApiPlatform\Metadata\ApiResource; use ApiPlatform\Metadata\Resource\Factory\ResourceMetadataCollectionFactoryInterface; use ApiPlatform\State\Util\RequestAttributesExtractor; +use Composer\InstalledVersions; use PackageVersions\Versions; use Psr\Container\ContainerInterface; use Symfony\Component\HttpFoundation\Request; @@ -67,16 +68,38 @@ private function setFilters(ApiResource $resourceMetadata, int $index, array &$f } } + // TODO: 4.1 remove Versions as its deprecated public function getVersion(): ?string { + if (class_exists(InstalledVersions::class)) { + return InstalledVersions::getPrettyVersion('api-platform/symfony') ?? InstalledVersions::getPrettyVersion('api-platform/core'); + } + if (!class_exists(Versions::class)) { return null; } - $version = Versions::getVersion('api-platform/core'); - preg_match('/^v(.*?)@/', (string) $version, $output); + try { + $version = strtok(Versions::getVersion('api-platform/symfony'), '@'); + } catch (\OutOfBoundsException) { + $version = false; + } + + if (false === $version) { + try { + $version = strtok(Versions::getVersion('api-platform/core'), '@'); + } catch (\OutOfBoundsException) { + $version = false; + } + } + + if (false === $version) { + return null; + } + + preg_match('/^v(.*?)$/', $version, $output); - return $output[1] ?? strtok($version, '@'); + return $output[1] ?? $version; } /** diff --git a/tests/Symfony/Bundle/DataCollector/RequestDataCollectorTest.php b/tests/Symfony/Bundle/DataCollector/RequestDataCollectorTest.php index c9af7f056eb..9a5a35a00f8 100644 --- a/tests/Symfony/Bundle/DataCollector/RequestDataCollectorTest.php +++ b/tests/Symfony/Bundle/DataCollector/RequestDataCollectorTest.php @@ -20,6 +20,7 @@ use ApiPlatform\Metadata\Resource\ResourceMetadataCollection; use ApiPlatform\Symfony\Bundle\DataCollector\RequestDataCollector; use ApiPlatform\Tests\Fixtures\DummyEntity; +use Composer\InstalledVersions; use PackageVersions\Versions; use PHPUnit\Framework\MockObject\MockObject; use PHPUnit\Framework\TestCase; @@ -163,7 +164,11 @@ public function testVersionCollection(): void $this->response ); - $this->assertSame(null !== $dataCollector->getVersion(), class_exists(Versions::class)); + if (class_exists(InstalledVersions::class)) { + $this->assertTrue(null !== $dataCollector->getVersion()); + } else { + $this->assertSame(null !== $dataCollector->getVersion(), class_exists(Versions::class)); + } } public function testWithPreviousData(): void