From f6d37bb2fb6747ab5e3b5ff13d4befce91225999 Mon Sep 17 00:00:00 2001 From: "mt.hodaka" Date: Tue, 16 Apr 2024 19:34:59 +0900 Subject: [PATCH] Add test for OperationDescription.responseOutcomes (#554) ### Motivation I couldn't reproduce the issue #530 on my end. However, I noticed that there were no tests, so I would like to add them. ### Modifications Adding tests. ### Result Only adding tests, no change in the behavior of the library. ### Test Plan Added tests are passing. Co-authored-by: Honza Dvorsky --- .../Operations/OperationDescription.swift | 2 +- .../Test_OperationDescription.swift | 69 ++++++++++++++++--- 2 files changed, 62 insertions(+), 9 deletions(-) diff --git a/Sources/_OpenAPIGeneratorCore/Translator/Operations/OperationDescription.swift b/Sources/_OpenAPIGeneratorCore/Translator/Operations/OperationDescription.swift index 8db584f8..42ff9989 100644 --- a/Sources/_OpenAPIGeneratorCore/Translator/Operations/OperationDescription.swift +++ b/Sources/_OpenAPIGeneratorCore/Translator/Operations/OperationDescription.swift @@ -312,7 +312,7 @@ extension OperationDescription { var outcomes = operation.responseOutcomes // if .default is present and not already last if let index = outcomes.firstIndex(where: { $0.status == .default }), index != (outcomes.count - 1) { - //then we move it to be last + // then we move it to be last let defaultResp = outcomes.remove(at: index) outcomes.append(defaultResp) } diff --git a/Tests/OpenAPIGeneratorCoreTests/Translator/Operations/Test_OperationDescription.swift b/Tests/OpenAPIGeneratorCoreTests/Translator/Operations/Test_OperationDescription.swift index 682701a1..a5da80a4 100644 --- a/Tests/OpenAPIGeneratorCoreTests/Translator/Operations/Test_OperationDescription.swift +++ b/Tests/OpenAPIGeneratorCoreTests/Translator/Operations/Test_OperationDescription.swift @@ -30,7 +30,7 @@ final class Test_OperationDescription: Test_Core { get: .init(parameters: [operationLevelParameter], requestBody: .b(.init(content: [:])), responses: [:]), vendorExtensions: [:] ) - let allParameters = try _test(pathItem) + let allParameters = try makeOperationDescription(pathItem)?.allParameters XCTAssertEqual(allParameters, [operationLevelParameter]) } @@ -48,7 +48,7 @@ final class Test_OperationDescription: Test_Core { get: .init(parameters: [operationLevelParameter], requestBody: .b(.init(content: [:])), responses: [:]), vendorExtensions: [:] ) - let allParameters = try _test(pathItem) + let allParameters = try makeOperationDescription(pathItem)?.allParameters XCTAssertEqual(allParameters, [pathLevelParameter, operationLevelParameter]) } @@ -73,25 +73,78 @@ final class Test_OperationDescription: Test_Core { ), vendorExtensions: [:] ) - let allParameters = try _test(pathItem) + let allParameters = try makeOperationDescription(pathItem)?.allParameters XCTAssertEqual(allParameters, [pathLevelParameter, duplicatedParameter, operationLevelParameter]) } - private func _test(_ pathItem: OpenAPI.PathItem) throws -> [UnresolvedParameter] { + func testResponseOutcomes_without_default_response() { + let responses: OpenAPI.Response.Map = [ + .status(code: 200): .b(.init(description: "200")), .status(code: 404): .b(.init(description: "404")), + ] + + let pathItem = OpenAPI.PathItem(get: .init(requestBody: .b(.init(content: [:])), responses: responses)) + let responseOutcomes = makeOperationDescription(pathItem)?.responseOutcomes + + XCTAssertEqual( + responseOutcomes, + [ + OpenAPI.Operation.ResponseOutcome(status: responses[0].key, response: responses[0].value), + OpenAPI.Operation.ResponseOutcome(status: responses[1].key, response: responses[1].value), + ] + ) + } + + func testResponseOutcomes_with_default_response_on_last() { + let responses: OpenAPI.Response.Map = [ + .status(code: 200): .b(.init(description: "200")), .status(code: 404): .b(.init(description: "404")), + .default: .b(.init(description: "default")), + ] + + let pathItem = OpenAPI.PathItem(get: .init(requestBody: .b(.init(content: [:])), responses: responses)) + let responseOutcomes = makeOperationDescription(pathItem)?.responseOutcomes + + XCTAssertEqual( + responseOutcomes, + [ + OpenAPI.Operation.ResponseOutcome(status: responses[0].key, response: responses[0].value), + OpenAPI.Operation.ResponseOutcome(status: responses[1].key, response: responses[1].value), + OpenAPI.Operation.ResponseOutcome(status: responses[2].key, response: responses[2].value), + ] + ) + } + + func testResponseOutcomes_with_default_response_on_first() { + let responses: OpenAPI.Response.Map = [ + .default: .b(.init(description: "default")), .status(code: 200): .b(.init(description: "200")), + .status(code: 404): .b(.init(description: "404")), + ] + + let pathItem = OpenAPI.PathItem(get: .init(requestBody: .b(.init(content: [:])), responses: responses)) + let responseOutcomes = makeOperationDescription(pathItem)?.responseOutcomes + + XCTAssertEqual( + responseOutcomes, + [ + OpenAPI.Operation.ResponseOutcome(status: responses[1].key, response: responses[1].value), + OpenAPI.Operation.ResponseOutcome(status: responses[2].key, response: responses[2].value), + OpenAPI.Operation.ResponseOutcome(status: responses[0].key, response: responses[0].value), + ] + ) + } + + private func makeOperationDescription(_ pathItem: OpenAPI.PathItem) -> OperationDescription? { guard let endpoint = pathItem.endpoints.first else { XCTFail("Unable to retrieve the path item first endpoint.") - return [] + return nil } - let operationDescription = OperationDescription( + return OperationDescription( path: .init(["/test"]), endpoint: endpoint, pathParameters: pathItem.parameters, components: .init(), asSwiftSafeName: { $0 } ) - - return try operationDescription.allParameters } }