From 4562bb9929c5bf25f7c8eebfe3f802f98667e9a5 Mon Sep 17 00:00:00 2001 From: DerManoMann Date: Tue, 16 Jul 2024 11:32:13 +1200 Subject: [PATCH 1/2] Refactor test to use processor config --- tests/OpenApiTestCase.php | 3 ++- tests/Processors/CleanUnusedComponentsTest.php | 15 +++++++-------- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/tests/OpenApiTestCase.php b/tests/OpenApiTestCase.php index 7b75819da..9980ba0aa 100644 --- a/tests/OpenApiTestCase.php +++ b/tests/OpenApiTestCase.php @@ -241,11 +241,12 @@ public static function processors(array $strip = []): array return $processors; } - public function analysisFromFixtures(array $files, array $processors = [], ?AnalyserInterface $analyzer = null): Analysis + public function analysisFromFixtures(array $files, array $processors = [], ?AnalyserInterface $analyzer = null, array $config = []): Analysis { $analysis = new Analysis([], $this->getContext()); (new Generator($this->getTrackingLogger())) + ->setConfig($config) ->setAnalyser($analyzer ?: $this->getAnalyzer()) ->setProcessorPipeline(new Pipeline($processors)) ->generate($this->fixtures($files), $analysis, false); diff --git a/tests/Processors/CleanUnusedComponentsTest.php b/tests/Processors/CleanUnusedComponentsTest.php index bcc0fcb69..ab3caa6c1 100644 --- a/tests/Processors/CleanUnusedComponentsTest.php +++ b/tests/Processors/CleanUnusedComponentsTest.php @@ -7,29 +7,28 @@ namespace OpenApi\Tests\Processors; use OpenApi\Generator; -use OpenApi\Processors\CleanUnusedComponents; use OpenApi\Tests\OpenApiTestCase; class CleanUnusedComponentsTest extends OpenApiTestCase { public static function countCases(): iterable { - $defaultProcessors = static::processors([CleanUnusedComponents::class]); + $configEnable = ['cleanUnusedComponents' => ['enabled' => true]]; return [ - 'var-default' => [$defaultProcessors, 'UsingVar.php', 2, 5], - 'var-clean' => [array_merge($defaultProcessors, [new CleanUnusedComponents(true)]), 'UsingVar.php', 0, 2], - 'unreferenced-default' => [$defaultProcessors, 'Unreferenced.php', 2, 11], - 'unreferenced-clean' => [array_merge($defaultProcessors, [new CleanUnusedComponents(true)]), 'Unreferenced.php', 0, 5], + 'var-default' => [[], 'UsingVar.php', 2, 5], + 'var-clean' => [$configEnable, 'UsingVar.php', 0, 2], + 'unreferenced-default' => [[], 'Unreferenced.php', 2, 11], + 'unreferenced-clean' => [$configEnable, 'Unreferenced.php', 0, 5], ]; } /** * @dataProvider countCases */ - public function testCounts(array $processors, string $fixture, int $expectedSchemaCount, int $expectedAnnotationCount): void + public function testCounts(array $config, string $fixture, int $expectedSchemaCount, int $expectedAnnotationCount): void { - $analysis = $this->analysisFromFixtures([$fixture], $processors); + $analysis = $this->analysisFromFixtures([$fixture], static::processors(), null, $config); if ($expectedSchemaCount === 0) { $this->assertTrue(Generator::isDefault($analysis->openapi->components->schemas)); From 525f99f5ff0141bdbaf10112b58bb3e136517359 Mon Sep 17 00:00:00 2001 From: DerManoMann Date: Tue, 16 Jul 2024 11:32:34 +1200 Subject: [PATCH 2/2] Make `AugmentTags` the last processor --- src/Generator.php | 2 +- tests/Fixtures/SurplusTag.php | 25 +++++++++++++++++++++++++ tests/Processors/AugmentTagsTest.php | 28 ++++++++++++++++++++++++++++ 3 files changed, 54 insertions(+), 1 deletion(-) create mode 100644 tests/Fixtures/SurplusTag.php create mode 100644 tests/Processors/AugmentTagsTest.php diff --git a/src/Generator.php b/src/Generator.php index 16d61acd0..ab804aaf4 100644 --- a/src/Generator.php +++ b/src/Generator.php @@ -275,10 +275,10 @@ public function getProcessorPipeline(): Pipeline new Processors\MergeJsonContent(), new Processors\MergeXmlContent(), new Processors\OperationId(), - new Processors\AugmentTags(), new Processors\CleanUnmerged(), new Processors\PathFilter(), new Processors\CleanUnusedComponents(), + new Processors\AugmentTags(), ]); } diff --git a/tests/Fixtures/SurplusTag.php b/tests/Fixtures/SurplusTag.php new file mode 100644 index 000000000..0ac32cc63 --- /dev/null +++ b/tests/Fixtures/SurplusTag.php @@ -0,0 +1,25 @@ +skipLegacy(); + + $config = [ + 'pathFilter' => ['paths' => ['#^/hello/#']], + 'cleanUnusedComponents' => ['enabled' => true], + ]; + $analysis = $this->analysisFromFixtures(['SurplusTag.php'], static::processors(), null, $config); + + $this->assertCount(1, $analysis->openapi->tags); + } +}