From 99859083e53912612b56b4b8713a971c20dab3ef Mon Sep 17 00:00:00 2001 From: Honza Dvorsky Date: Tue, 23 Jul 2024 12:17:22 +0200 Subject: [PATCH] Correctly handle path params with a hyphen in the name (#602) ### Motivation Fixes #601, check out the issue for details. ### Modifications Adds hyphen to the regular expression that parses out params from the URL template. ### Result Correctly handle path params with hyphens in the name. ### Test Plan Added a unit test. --- .../Operations/OperationDescription.swift | 2 +- .../SnippetBasedReferenceTests.swift | 60 +++++++++++++++++++ 2 files changed, 61 insertions(+), 1 deletion(-) diff --git a/Sources/_OpenAPIGeneratorCore/Translator/Operations/OperationDescription.swift b/Sources/_OpenAPIGeneratorCore/Translator/Operations/OperationDescription.swift index 42ff9989..aea727dc 100644 --- a/Sources/_OpenAPIGeneratorCore/Translator/Operations/OperationDescription.swift +++ b/Sources/_OpenAPIGeneratorCore/Translator/Operations/OperationDescription.swift @@ -248,7 +248,7 @@ extension OperationDescription { /// The regular expression for parsing subcomponents of path components. /// /// Either a parameter `{foo}` or a constant value `foo`. - private static let pathParameterRegex = try! NSRegularExpression(pattern: #"(\{[a-zA-Z0-9_]+\})|([^{}]+)"#) + private static let pathParameterRegex = try! NSRegularExpression(pattern: #"(\{[a-zA-Z0-9_\-\.]+\})|([^{}]+)"#) /// Returns a string that contains the template to be generated for /// the client that fills in path parameters, and an array expression diff --git a/Tests/OpenAPIGeneratorReferenceTests/SnippetBasedReferenceTests.swift b/Tests/OpenAPIGeneratorReferenceTests/SnippetBasedReferenceTests.swift index a362df37..0196c5ee 100644 --- a/Tests/OpenAPIGeneratorReferenceTests/SnippetBasedReferenceTests.swift +++ b/Tests/OpenAPIGeneratorReferenceTests/SnippetBasedReferenceTests.swift @@ -2605,6 +2605,7 @@ final class SnippetBasedReferenceTests: XCTestCase { """ ) } + func testRequestWithPathParams() throws { try self.assertRequestInTypesClientServerTranslation( """ @@ -2696,6 +2697,65 @@ final class SnippetBasedReferenceTests: XCTestCase { ) } + func testRequestWithPathParamWithHyphenAndPeriod() throws { + try self.assertRequestInTypesClientServerTranslation( + """ + /foo/{p.a-b}: + get: + parameters: + - name: p.a-b + in: path + required: true + schema: + type: string + operationId: getFoo + responses: + default: + description: Response + """, + types: """ + public struct Input: Sendable, Hashable { + public struct Path: Sendable, Hashable { + public var p_period_a_hyphen_b: Swift.String + public init(p_period_a_hyphen_b: Swift.String) { + self.p_period_a_hyphen_b = p_period_a_hyphen_b + } + } + public var path: Operations.getFoo.Input.Path + public init(path: Operations.getFoo.Input.Path) { + self.path = path + } + } + """, + client: """ + { input in + let path = try converter.renderedPath( + template: "/foo/{}", + parameters: [ + input.path.p_period_a_hyphen_b + ] + ) + var request: HTTPTypes.HTTPRequest = .init( + soar_path: path, + method: .get + ) + suppressMutabilityWarning(&request) + return (request, nil) + } + """, + server: """ + { request, requestBody, metadata in + let path: Operations.getFoo.Input.Path = .init(p_period_a_hyphen_b: try converter.getPathParameterAsURI( + in: metadata.pathParameters, + name: "p.a-b", + as: Swift.String.self + )) + return Operations.getFoo.Input(path: path) + } + """ + ) + } + func testRequestRequiredBodyPrimitiveSchema() throws { try self.assertRequestInTypesClientServerTranslation( """