Skip to content
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

Consider removal of deprecated elements as compatible #371

Open
kubamarchwicki opened this issue May 5, 2022 · 4 comments
Open

Consider removal of deprecated elements as compatible #371

kubamarchwicki opened this issue May 5, 2022 · 4 comments

Comments

@kubamarchwicki
Copy link
Contributor

I'm using openapi-diff quite successfully to avoid accidental changes in the API (and therefore introducing a breaking change). We use it as a part of our pipeline.

The current struggle is: that sometimes one wants to introduce a breaking change (like the removal of obsolete API).
My initial idea would float around a two-step process:

  • marking an element ad deprecated (keeping compatibility)
  • removing the deprecated element

To do that, when processing the list of ChangedOpenApi#getChangedElements I'd need to know if the particular element is deprecatable and decide if the change is incompatible or not.

That looks to me like another SPI but I'm not sure if it's the direction. I know it's currently not possible and I'm not even sure if the direction of my thought even makes sense.

@crisarmen

This comment was marked as spam.

@rashvirgo
Copy link

+1
I was also looking for the same feature as requested by @kubamarchwicki. Any direction would be appreciated here. Thanks

@joschi
Copy link
Contributor

joschi commented Feb 25, 2023

@kubamarchwicki Thanks for reporting this.

Strictly speaking, removing any previously available element is a breaking change, even if it was deprecated before.

BUT I think together with the option to allow breaking changes if the major version of the API has been bumped described in #460, this might make sense.

What do you think?

@kubamarchwicki
Copy link
Contributor Author

Totally. One way or another - to clean up the API is good.

From my own personal standpoint, we've treated openapi-diff as an intermediary step to contract testing based approach. We moved from schema based verification to usages based tests - which allowed us to more efficiently work with the api.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants