-
Notifications
You must be signed in to change notification settings - Fork 221
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
Kiota should send properties in OAS declaration order, not alphabetic order #4680
Comments
Hi @bkoelman
|
The declaration order in OAS is already deterministic. All other code generators I've tried respect the declaration order. [
{ "type": "user", "id": "1", "firstName": "John", "lastName": "Doe", "age": 25 },
{ "type": "order", "id": "1", "productName": "Laptop", "quantity": 1, "price": 1199.99, "units": "dollars" },
{ "type": "order", "id": "2", "productName": "Printer", "quantity": 1, "price": 349.99, "units": "dollars" }
] is much easier to read than: [
{ "age": 25, "firstName": "John", "id": "1", "lastName": "Doe", "type": "user" },
{ "id": "1", "price": 1199.99, "productName": "Laptop", "quantity": 1, "type": "order", "units": "dollars" },
{ "id": "2", "price": 349.99, "productName": "Printer", "quantity": 1, "type": "order", "units": "dollars" }
] Lastly, specific implementations may depend on the ordering. Why else would System.Text.Json and Newtonsoft provide ways to control the order, other than to improve readability? |
Thanks for the additional information.
This sounds like a bad design of the API itself that should be addressed in the API instead of pushing a constraint on clients. Do you have example scenarios that cannot be achieved through any other way than a specific ordering of the properties? |
Not at the moment, but years ago I ran into that with XML more than once: Large commercial enterprise systems that we couldn't change because they were provided by external vendors, or because the source code got lost over time (yes, that happens, and more often than you'd think, even today). Or 3rd party external systems written in PHP, that didn't rely on an XML DOM parser, because at the time there wasn't one built-in yet. We had to work around these problems because getting the external systems changed was too expensive. I agree that an implementation that depends on the order is a bad design, however, sometimes it's out of our control. But my primary concern is readability, as my sample shows. |
Thanks for the additional information. As for the readability aspect, is it because you want the discriminator property to be first? or am I missing something here? |
It's unrelated to discriminators, it's about preserving the declaration order. A model that defines first name, middle name and last name (in that order) should not be hussled. |
I understand you have a specific opinion of how things should be, however between the JSON spec that explicitly calls out the unordering, and lack of additional evidence/scenarios, it's only an opinion. |
That's ridiculous. SQL columns are unordered in SELECT, yet their order is preserved in EF Core queries. C# methods are unordered, yet their order is preserved in IL (MetadataToken). Not because it's a technical requirement, but because it improves usability and readability. Even I can understand this is low priority, but closing this because your personal opinion goes against what's common in most other tools, and ignoring all motivation, is just disrespectful. You're apparently not very experienced with developer expectations, nor managing an open source project. It would make more sense to leave this open for others to upvote. I've proven you wrong on nullability before, which is now the most updated issue. Having some faith in what users care about would avoid a lot of frustration. This recurring attitude of "I know better than the rest of the world" makes me eager to abandon kiota, and I'm pretty sure more people feel that way. |
We have countless instances of issues being left open for upvote/future consideration in this repo. (see v2 or v3 or backlog milestones for examples, or even past versions). This includes multiple of your own issues At some point, the sheer management of issues being left open becomes a challenge in itself, this is why I drive the conversations to demonstrate tangible additional values. You've had multiple opportunities to demonstrate that "if we invest in making sure properties are ordered in the same way they are in the description, we unblock this scenario, which is likely to benefit a broad base of users", and you haven't. |
@bkoelman The JSON specification specifications states https://datatracker.ietf.org/doc/html/rfc8259#section-4
As Kiota is intended to support any JSON parsing library, taking dependencies on the behaviour of some libraries would impact interoperability. As far as developer experience goes, I've yet to see an autocomplete experience that lists members of an object in declared order. Using alphabetical ordering is quite common when selecting properties. The OpenAPI.NET library that Kiota is based upon makes no attempt to preserve document content that is outside of the OpenAPI semantics. e.g. map ordering, whitespace, Therefore it would make it challenging to consistently carry through this information into Kiota and project it into source code. It was not a design objective of Kiota use non-significant formatting of the source OpenAPI as part of code generation. I have not seen strong reasoning in this thread to suggest revisiting that goal. I do think there is value in having a deterministic order of the properties. I would be open to considering using semantics like required/readonly/etc to suggest ordering, but attempting to insult community members doesn't seem like the right approach to make that case. |
I appreciate the effort to act and decide on issues early, instead of leaving them lingering. Exceptions aside, the large amount of open issues reflects the poor quality of kiota. Because most are bug reports, or clumsy limitations that make using kiota a pain (from a consumer perspective). It sounds like you're doing me a favor by not closing my bug reports? When the goal is building a flourishing community, it should be the other way around: be grateful for opening them, acknowledging that other people are giving up their free time to provide an opportunity to build a better product, even when the team currently doesn't have time for that. Having many open bugs reflects the product is popular, which may give you leverage in allocating more resources to the team. That, and not bothering to test with the provided repro steps, and closing issues as completed without actually fixing the problem (taking note isn't enough; taking responsibility means reopening, and converting it to an umbrella issue that lists other issues it depends on), is what I meant with being unexperienced in managing an open source project.
I don't see why. GitHub has great capabilities to manage large amounts of issues, by using tags, milestones, projects, advanced issue filters, etc. Runtime has 5k open issues, aspnetcore has 3k open issues; perhaps ask there on how to manage them?
I've given several motivations, which you haven't responded to. You're supposed to explain why your point of view is the better solution, and what the downsides are in my point of view. Just dismissing them isn't having a discussion.
Neither does the spec recommend to order them alphabetically, which is what kiota does. I'm just asking to not sort them, I have no idea what kind of investment you're referring to. Sorting the list of schemas is fine, but the model properties reflect something functional that users care about. It matters in reading logged requests and responses. Autocomplete is a lookup tool that has its own logic to sort, based on the most-likely match. The declaration order is irrelevant in that case, but that was never my point.
I'm not concerned about whitespace, but OpenAPI.NET doesn't take explicit steps to change the ordering, which is nice. I'd be fine if kiota worked similarly.
Why would this tradeoff be different for kiota than for OpenAPI.NET?
I don't see the advantage of that. I'd consider that unintuitive.
That's not my intent. In being a fully-remote worker for years I've learned to always assume best intent, asking for clarification instead of making assumptions. But also to reach out if things aren't right. As expressed above, there wasn't much of a discussion. Perhaps some of you are just too overworked, but feedback and concerns are often dismissed without explanation, which is demotivating and disrespectful. These and other concerns came up in #4349, but I'm not seeing a change in attitude. There's an underlying sentiment of disliking feedback and not being interested in what matters to users, despite saying otherwise. |
Here's evidence that users care about the order: dotnet/runtime#102932:
Another reason is performance: in System.Text.Json, a |
This should be re-opened. For anyone else who wasted a crap-ton of time on this stupidity, the solution is this: o.JsonSerializerOptions.AllowOutOfOrderMetadataProperties = true; as of .net 9 or the relevant package upgrades. As for the attitude of the project dev here closing the issue, it really boggles the mind. .NET has a general paradigm that metadata properties need to be passed in first, including $type. The spec at play here is not just the OAS spec, but the .NET API paradigm. Both need to be considered, along with of course the user base. |
What are you generating using Kiota, clients or plugins?
API Client/SDK
In what context or format are you using Kiota?
Nuget tool
Client library/SDK language
Csharp
Describe the bug
My OAS file lists properties (in component schema) in an intentional order: type, id, firstName, lastName, age. While the last three vary per model, the first two are always present. Kiota ignores that and uses alphabetic order instead: age, firstName, id, lastName, type. This makes the payload harder to read, test, and debug.
Expected behavior
Preserve declaration order. In the case of inheritance, fields from base types come first.
How to reproduce
Open API description file
No response
Kiota Version
1.14.0
Latest Kiota version known to work for scenario above? (Not required)
No response
Known Workarounds
None
Configuration
No response
Debug output
No response
Other information
No response
The text was updated successfully, but these errors were encountered: