-
Notifications
You must be signed in to change notification settings - Fork 128
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Generator] Add support of deepObject style in query params #659
base: main
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
|
@@ -2514,6 +2514,18 @@ final class SnippetBasedReferenceTests: XCTestCase { | |||||
type: array | ||||||
items: | ||||||
type: string | ||||||
- name: sort | ||||||
in: query | ||||||
required: true | ||||||
style: deepObject | ||||||
explode: true | ||||||
schema: | ||||||
type: object | ||||||
properties: | ||||||
option1: | ||||||
type: string | ||||||
option2: | ||||||
type: string | ||||||
responses: | ||||||
default: | ||||||
description: Response | ||||||
|
@@ -2524,18 +2536,36 @@ final class SnippetBasedReferenceTests: XCTestCase { | |||||
public var single: Swift.String? | ||||||
public var manyExploded: [Swift.String]? | ||||||
public var manyUnexploded: [Swift.String]? | ||||||
public struct sortPayload: Codable, Hashable, Sendable { | ||||||
public var option1: Swift.String? | ||||||
public var option2: Swift.String? | ||||||
public init( | ||||||
option1: Swift.String? = nil, | ||||||
option2: Swift.String? = nil | ||||||
) { | ||||||
self.option1 = option1 | ||||||
self.option2 = option2 | ||||||
} | ||||||
public enum CodingKeys: String, CodingKey { | ||||||
case option1 | ||||||
case option2 | ||||||
} | ||||||
} | ||||||
public var sort: Operations.get_sol_foo.Input.Query.sortPayload | ||||||
public init( | ||||||
single: Swift.String? = nil, | ||||||
manyExploded: [Swift.String]? = nil, | ||||||
manyUnexploded: [Swift.String]? = nil | ||||||
manyUnexploded: [Swift.String]? = nil, | ||||||
sort: Operations.get_sol_foo.Input.Query.sortPayload | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
This should end up being defaulted to nil as well. It's possible it'll require improvements in inspecting the nested object and whether it can be initialized with There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. That parameter has There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Oh that's interesting! What does it mean for a query parameter of type object to be required, when all properties are optional? On the wire, it won't look any different to the whole parameter being optional. Maybe we should just change the sample to have an optional parameter? I think that's more common. Alternatively, make one of the properties required. Either is fine. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Right, that's interesting. Updating the sample to have an optional parameter would resolve the issues you highlighted in the review with this test. What if all the properties of the object have default values though? I tried getting an idea of what it would look like by updating the tests but I can get any default value to show in the generated swift types. |
||||||
) { | ||||||
self.single = single | ||||||
self.manyExploded = manyExploded | ||||||
self.manyUnexploded = manyUnexploded | ||||||
self.sort = sort | ||||||
} | ||||||
} | ||||||
public var query: Operations.get_sol_foo.Input.Query | ||||||
public init(query: Operations.get_sol_foo.Input.Query = .init()) { | ||||||
public init(query: Operations.get_sol_foo.Input.Query) { | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
Yeah this should not go away, since all the query items are still optional, so it should be possible to init the Input with just |
||||||
self.query = query | ||||||
} | ||||||
} | ||||||
|
@@ -2572,6 +2602,13 @@ final class SnippetBasedReferenceTests: XCTestCase { | |||||
name: "manyUnexploded", | ||||||
value: input.query.manyUnexploded | ||||||
) | ||||||
try converter.setQueryItemAsURI( | ||||||
in: &request, | ||||||
style: .deepObject, | ||||||
explode: true, | ||||||
name: "sort", | ||||||
value: input.query.sort | ||||||
) | ||||||
return (request, nil) | ||||||
} | ||||||
""", | ||||||
|
@@ -2598,6 +2635,13 @@ final class SnippetBasedReferenceTests: XCTestCase { | |||||
explode: false, | ||||||
name: "manyUnexploded", | ||||||
as: [Swift.String].self | ||||||
), | ||||||
sort: try converter.getRequiredQueryItemAsURI( | ||||||
in: request.soar_query, | ||||||
style: .deepObject, | ||||||
explode: true, | ||||||
name: "sort", | ||||||
as: Operations.get_sol_foo.Input.Query.sortPayload.self | ||||||
) | ||||||
) | ||||||
return Operations.get_sol_foo.Input(query: query) | ||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
style: deepObject + explode: true is supported, but not with explode: false, so let's catch it here and provide a descriptive error.
See in the runtime changes that we only support explode: true: https://github.com/apple/swift-openapi-runtime/pull/100/files#diff-a382c8525d6209dfbc3e90daaf0262692d9df73f1b7a914b9eebe143f04c287dR76