From 26998cd0a50acae9186e2fa9ed28388cebf1b7c9 Mon Sep 17 00:00:00 2001 From: DjordyKoert Date: Fri, 5 Jan 2024 13:11:09 +0100 Subject: [PATCH] fix: describe nullable enums with allOf --- PropertyDescriber/ObjectPropertyDescriber.php | 12 +++++++-- Tests/Functional/Entity/Article81.php | 1 + Tests/Functional/FunctionalTest.php | 26 +++++++++++++++++++ 3 files changed, 37 insertions(+), 2 deletions(-) diff --git a/PropertyDescriber/ObjectPropertyDescriber.php b/PropertyDescriber/ObjectPropertyDescriber.php index db9ea2bb0..8a8ca044b 100644 --- a/PropertyDescriber/ObjectPropertyDescriber.php +++ b/PropertyDescriber/ObjectPropertyDescriber.php @@ -38,9 +38,17 @@ public function describe(array $types, OA\Schema $property, array $groups = null ); // ignore nullable field if ($types[0]->isNullable()) { - $weakContext = Util::createWeakContext($property->_context); $property->nullable = true; - $property->oneOf = [new OA\Schema(['ref' => $this->modelRegistry->register(new Model($type, $groups)), '_context' => $weakContext])]; + + $weakContext = Util::createWeakContext($property->_context); + $schemas = [new OA\Schema(['ref' => $this->modelRegistry->register(new Model($type, $groups)), '_context' => $weakContext])]; + + // All of is needed for enums to make sure + if (function_exists('enum_exists') && enum_exists($type->getClassName())) { + $property->allOf = $schemas; + } else { + $property->oneOf = $schemas; + } return; } diff --git a/Tests/Functional/Entity/Article81.php b/Tests/Functional/Entity/Article81.php index 8a483cd79..e35a2f47c 100644 --- a/Tests/Functional/Entity/Article81.php +++ b/Tests/Functional/Entity/Article81.php @@ -9,6 +9,7 @@ public function __construct( public readonly ArticleType81 $type, public readonly ArticleType81IntBacked $intBackedType, public readonly ArticleType81NotBacked $notBackedType, + public readonly ?ArticleType81 $nullableType, ) { } } diff --git a/Tests/Functional/FunctionalTest.php b/Tests/Functional/FunctionalTest.php index 452697b90..ca828634b 100644 --- a/Tests/Functional/FunctionalTest.php +++ b/Tests/Functional/FunctionalTest.php @@ -744,6 +744,32 @@ public function testEnumSupport() $this->assertSame('integer', $model->type); $this->assertCount(2, $model->enum); + + $this->assertEquals([ + 'type' => 'object', + 'properties' => [ + 'id' => [ + 'type' => 'integer', + ], + 'type' => [ + '$ref' => '#/components/schemas/ArticleType81', + ], + 'intBackedType' => [ + '$ref' => '#/components/schemas/ArticleType81IntBacked', + ], + 'notBackedType' => [ + '$ref' => '#/components/schemas/ArticleType81NotBacked', + ], + 'nullableType' => [ + 'nullable' => true, + 'allOf' => [ + ['$ref' => '#/components/schemas/ArticleType81'], + ] + ], + ], + 'required' => ['id', 'type', 'intBackedType', 'notBackedType'], + 'schema' => 'Article81', + ], json_decode($this->getModel('Article81')->toJson(), true)); } public function testEntitiesWithOverriddenSchemaTypeDoNotReadOtherProperties()