-
-
Notifications
You must be signed in to change notification settings - Fork 288
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
What do we define as a breaking change? #688
Comments
You made a really good point here. I agree having in mind breaking changes also at tooling level is important. If we go in that direction, we should set obvious boundaries and consider only the tools under AsyncAPI umbrella (Code hosted on github.com/asyncapi) as implementations to check for breaking changes (unless the breaking change is clearly detected earlier). Also, it would be nice if we build some quick tool we can run on CI to check for usages and, at least, list them on the PRs, like possible affected code. Github search is not very powerful for it. |
@jonaslagoni making a property required is also a breaking change. If I use an AsyncAPI 2.2.0 document as the input for an AsyncAPI 2.3.0 tool, and we have made a property required in v2.3.0, it will be a breaking change. I mean, changing Regarding #682, if we're not sure about it, we can always postpone it to v3 now that we're working on it. |
You are right, adapted suggestion! |
Interesting one, as @jonaslagoni mentioned it really depends on context we talk about, spec and tools. But I like what you mentioned @jonaslagoni , about Interesting what you mentioned @smoya about only AsyncAPI tools, I guess you have to stop somewhere, but maybe with @jonaslagoni lists and definitions then wouldn't really matter about the tools, as this kind of change would be breaking anyway. |
Yeah, that's a really good point. I think we must work on defining those rules @jonaslagoni started. Specially after the conversation on asyncapi/spec-json-schemas#146 (comment) |
I think this issue should end up completing as addition document in the repo, guide for codeowners to always consult with when accepting changes. But for the future, we would not only have info that for example making and I would not say what is braking for spec and what for tools. Spec without tools is useless, so it is always about breaking tools really |
This issue has been automatically marked as stale because it has not had recent activity 😴 It will be closed in 120 days if no further activity occurs. To unstale this issue, add a comment with a detailed explanation. There can be many reasons why some specific issue has no activity. The most probable cause is lack of time, not lack of interest. AsyncAPI Initiative is a Linux Foundation project not owned by a single for-profit company. It is a community-driven initiative ruled under open governance model. Let us figure out together how to push this issue forward. Connect with us through one of many communication channels we established here. Thank you for your patience ❤️ |
Contributors are welcome 🙏🏼 |
This issue has been automatically marked as stale because it has not had recent activity 😴 It will be closed in 120 days if no further activity occurs. To unstale this issue, add a comment with a detailed explanation. There can be many reasons why some specific issue has no activity. The most probable cause is lack of time, not lack of interest. AsyncAPI Initiative is a Linux Foundation project not owned by a single for-profit company. It is a community-driven initiative ruled under open governance model. Let us figure out together how to push this issue forward. Connect with us through one of many communication channels we established here. Thank you for your patience ❤️ |
I suggest we extend https://github.com/asyncapi/spec/blob/master/CONTRIBUTING.md with new section called Most of content is already provided
Anyone is welcome to open a PR and drive it until it is merged. /gfi docs |
Hey @derberg, your message doesn't follow the requirements, you can try |
/gfi docs |
I will be happy to open a PR and drive it until it is merged, but I'm kind of confused about what to do. Don't know why I'm confused 😂 |
Hey @Dule-martins, your message doesn't follow the requirements, you can try |
/help |
Hello, @Dule-martins! 👋🏼 I'm Genie from the magic lamp. Looks like somebody needs a hand! 🆘 At the moment the following comments are supported in issues:
|
@Dule-martins 😆 if you feel confused but you do not know why, I'm definitely not gonna be able to help you out 😆 |
@derberg now, I know my issue I don't have clue of what to do and where to do what I need to do. I have been reading comments for days yet still confused kindly help |
@Dule-martins ok, basically ignore all comments except of #688 (comment) that summarizes what has to be done |
Oh! Thanks, Boss ❤️️ |
This issue has been automatically marked as stale because it has not had recent activity 😴 It will be closed in 120 days if no further activity occurs. To unstale this issue, add a comment with a detailed explanation. There can be many reasons why some specific issue has no activity. The most probable cause is lack of time, not lack of interest. AsyncAPI Initiative is a Linux Foundation project not owned by a single for-profit company. It is a community-driven initiative ruled under open governance model. Let us figure out together how to push this issue forward. Connect with us through one of many communication channels we established here. Thank you for your patience ❤️ |
This issue has been automatically marked as stale because it has not had recent activity 😴 It will be closed in 120 days if no further activity occurs. To unstale this issue, add a comment with a detailed explanation. There can be many reasons why some specific issue has no activity. The most probable cause is lack of time, not lack of interest. AsyncAPI Initiative is a Linux Foundation project not owned by a single for-profit company. It is a community-driven initiative ruled under open governance model. Let us figure out together how to push this issue forward. Connect with us through one of many communication channels we established here. Thank you for your patience ❤️ |
🎉 This issue has been resolved in version 3.0.0-next-major-spec.18 🎉 The release is available on GitHub release Your semantic-release bot 📦🚀 |
🎉 This issue has been resolved in version 3.0.0 🎉 The release is available on GitHub release Your semantic-release bot 📦🚀 |
This question emerged when @smoya wanted to make the channels field optional - #661
This change, might not be a breaking change to the spec itself, however, for tooling that relies on the channels being required and always present, it would.
So when should a change in the spec be considered a breaking change?
I see two ways we can do this (and that is assuming we want to stay with semantic releases).
Only focusing on the spec
Agreeing that as long as the spec is backward compatible, it is not a breaking change.
Agreeing what is breaking changes
Agreeing on special cases would probably be possible to minimize breaking changes in tooling and spec.
My immediate thoughts are the following that would be questionable:
Non-breaking changes:
Breaking changes:
Can you think of another possible solution?
The text was updated successfully, but these errors were encountered: