From 6ff3176aae598ead11894df46088c446e5637aba Mon Sep 17 00:00:00 2001
From: Irvine Sunday <40403681+irvinesunday@users.noreply.github.com>
Date: Wed, 7 Sep 2022 18:50:57 +0300
Subject: [PATCH] Appends `format` property value to root schema if contained
in `anyOf`, `oneOf` or `allOf` when serializing as v2 (#1001)
* Retrieve format from schema composition properties when serializing as V2
* Update tests
* Check for format nullability or empty
* Bump up lib. version
* PR review comments: validate nullability and empty
---
.../Microsoft.OpenApi.csproj | 2 +-
src/Microsoft.OpenApi/Models/OpenApiSchema.cs | 18 +++++++--
.../Models/OpenApiParameterTests.cs | 37 ++++++++++++++++++-
3 files changed, 51 insertions(+), 6 deletions(-)
diff --git a/src/Microsoft.OpenApi/Microsoft.OpenApi.csproj b/src/Microsoft.OpenApi/Microsoft.OpenApi.csproj
index f07012b5d..fa8bee8bf 100644
--- a/src/Microsoft.OpenApi/Microsoft.OpenApi.csproj
+++ b/src/Microsoft.OpenApi/Microsoft.OpenApi.csproj
@@ -11,7 +11,7 @@
Microsoft
Microsoft.OpenApi
Microsoft.OpenApi
- 1.4.0
+ 1.4.1
.NET models with JSON and YAML writers for OpenAPI specification
© Microsoft Corporation. All rights reserved.
OpenAPI .NET
diff --git a/src/Microsoft.OpenApi/Models/OpenApiSchema.cs b/src/Microsoft.OpenApi/Models/OpenApiSchema.cs
index 8734c19a2..6019d7362 100644
--- a/src/Microsoft.OpenApi/Models/OpenApiSchema.cs
+++ b/src/Microsoft.OpenApi/Models/OpenApiSchema.cs
@@ -1,4 +1,4 @@
-// Copyright (c) Microsoft Corporation. All rights reserved.
+// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT license.
using System.Collections.Generic;
@@ -566,6 +566,13 @@ internal void WriteAsItemsProperties(IOpenApiWriter writer)
writer.WriteProperty(OpenApiConstants.Type, Type);
// format
+ if (string.IsNullOrEmpty(Format))
+ {
+ Format = AllOf?.FirstOrDefault(static x => !string.IsNullOrEmpty(x.Format))?.Format ??
+ AnyOf?.FirstOrDefault(static x => !string.IsNullOrEmpty(x.Format))?.Format ??
+ OneOf?.FirstOrDefault(static x => !string.IsNullOrEmpty(x.Format))?.Format;
+ }
+
writer.WriteProperty(OpenApiConstants.Format, Format);
// items
@@ -630,9 +637,12 @@ internal void WriteAsSchemaProperties(
}
// format
- Format ??= AllOf?.FirstOrDefault(static x => x.Format != null)?.Format ??
- AnyOf?.FirstOrDefault(static x => x.Format != null)?.Format ??
- OneOf?.FirstOrDefault(static x => x.Format != null)?.Format;
+ if (string.IsNullOrEmpty(Format))
+ {
+ Format = AllOf?.FirstOrDefault(static x => !string.IsNullOrEmpty(x.Format))?.Format ??
+ AnyOf?.FirstOrDefault(static x => !string.IsNullOrEmpty(x.Format))?.Format ??
+ OneOf?.FirstOrDefault(static x => !string.IsNullOrEmpty(x.Format))?.Format;
+ }
writer.WriteProperty(OpenApiConstants.Format, Format);
diff --git a/test/Microsoft.OpenApi.Tests/Models/OpenApiParameterTests.cs b/test/Microsoft.OpenApi.Tests/Models/OpenApiParameterTests.cs
index 6db019be7..cfcc56d15 100644
--- a/test/Microsoft.OpenApi.Tests/Models/OpenApiParameterTests.cs
+++ b/test/Microsoft.OpenApi.Tests/Models/OpenApiParameterTests.cs
@@ -50,7 +50,12 @@ public class OpenApiParameterTests
Schema = new OpenApiSchema
{
Title = "title2",
- Description = "description2"
+ Description = "description2",
+ OneOf = new List
+ {
+ new OpenApiSchema { Type = "number", Format = "double" },
+ new OpenApiSchema { Type = "string" }
+ }
},
Examples = new Dictionary
{
@@ -234,6 +239,15 @@ public void SerializeAdvancedParameterAsV3JsonWorks()
""explode"": true,
""schema"": {
""title"": ""title2"",
+ ""oneOf"": [
+ {
+ ""type"": ""number"",
+ ""format"": ""double""
+ },
+ {
+ ""type"": ""string""
+ }
+ ],
""description"": ""description2""
},
""examples"": {
@@ -253,6 +267,27 @@ public void SerializeAdvancedParameterAsV3JsonWorks()
actual.Should().Be(expected);
}
+ [Fact]
+ public void SerializeAdvancedParameterAsV2JsonWorks()
+ {
+ // Arrange
+ var expected = @"{
+ ""in"": ""path"",
+ ""name"": ""name1"",
+ ""description"": ""description1"",
+ ""required"": true,
+ ""format"": ""double""
+}";
+
+ // Act
+ var actual = AdvancedPathParameterWithSchema.SerializeAsJson(OpenApiSpecVersion.OpenApi2_0);
+
+ // Assert
+ actual = actual.MakeLineBreaksEnvironmentNeutral();
+ expected = expected.MakeLineBreaksEnvironmentNeutral();
+ actual.Should().Be(expected);
+ }
+
[Theory]
[InlineData(true)]
[InlineData(false)]