-
Notifications
You must be signed in to change notification settings - Fork 70
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
[PROPOSAL] Simplify OpenSearch distribution branching strategy #251
Comments
This is a great proposal, as the amount of backport PRs we did in 2.x is huge. Will we continue releasing patch releases often such as 3.1.1 after 3.1 before 3.2? Feels like we want that to be reserved to urgent high severity security issues and just do 3.1, 3.2, 3.3, etc. And we won't need a 3.x branch. |
Patches of the current minor version (e.g. 3.1.1) only happen for high severity issues. If a 3.1.1 release is necessary we would cherry pick the critical fixes on to the
That's correct. With this proposal we track two releases which means only two active branches: |
I have a very minor preference for renaming At the end of the day, it wouldn't change anything functionally. It would just feel a little closer to "Developing directly on As I said -- it's a very minor preference. If we decide to keep the name of the branch as |
I am on the same page with Andrew's proposal. Overall it should simplify the process not only on code developer side, but also on infra and automation as we do not need to maintain a specific Thanks. |
This would be very surprising to anyone coming to the project and would make the main branch a moving target for dozens of repos. |
I don't understand the second clause. I'm suggesting that instead of having a branch named |
@msfroh I think @dblock is saying it would be surprising that the default branch would be a moving target, because it would change with every major version. The convention is that the name of the default branch is fixed ( |
@andrross thanks, you said exactly what I was thinking |
@msfroh I think there is value in making it obvious which version number is associated with main and I think it breaks 'standard' convention to remap HEAD to a version'ed branch instead of main as @andrross points out. Cheap alternative, what would you think of a small piece of automation that kept a @andrross Thanks starting this discussion - I'm in full support of creating a 3.0.0 release. In conjunction with this major release revisiting the release methodology and messaging might be a good exercise, as once upon a time we did |
I don't think that would be of much benefit to anyone. If I cared enough, I could create a branch named |
Hi! I'm here to stir the pot! OK, seriously. I don't want to cause drama, and I'm generally in agreement with this proposal, but the timing of this proposal is really bad. I don't think there's really been enough time to discuss it (it's been open 3 weeks but mostly over the holidays) and we're looking at locking in a 3.0.0 release schedule this week in #252. This is a pretty significant change and a pretty big blast radius of impacted downstream dependencies. My general thoughts are that we need to maintain the existing status quo, or have much more frequent major version upgrades. And the latter choice has multiple other impacts that I think need a lot more discussion. |
What/Why
What are you proposing?
We should change the branching strategy used across the OpenSearch Project to track two releases instead of three. We should make this change when we do the next major version release (3.0) of the distribution.
This change applies to all repositories that are part of the OpenSearch distribution (core, dashboards, plugins, etc). Some repositories, such as clients, have independent release cycles and are not impacted by this change.
Background
Currently, we track three releases in parallel:
main
branch2.x
branch1.3
branchThis strategy optimizes for being able to incubate and develop breaking changes for the next major release for an extended period of time, as that code would be on the main development branch. The cost of this strategy is that all non-breaking changes intended for the next minor release require an extra step of backporting to the 2.x branch. The previous 2.5+ years have shown us that we have incubated very few breaking changes on the main branch for an extended period. While we have automation that makes backports to the 2.x branch very low effort for the majority of changes, it is not perfect (e.g. automation hits conflicts requiring manual resolution, flaky tests may fail, it takes time even when everything works perfectly). I believe the cost of these paper cuts, multiplied by thousands of changes across scores of repos, outweigh the benefits of the current approach. I also have no reason to believe things would be different for the 3.x→4.0 cycle than it was for the 2.x→3.0 cycle.
Proposal
The proposal is to track only two releases in parallel. After the 3.0 release, we will have the following branches:
main
tracking the 3.x version (the next minor release)2.<last>.x
tracking the next maintenance release of the 2.<last> versionAt the time of a minor release, we will cut a release branch (e.g.
3.1
) from themain
branch. Development for the following minor release will continue onmain
and the 3.1 version will be built from the3.1
branch.At the time of a maintenance release, we will cut a release branch (e.g.
2.19.1
) from the2.19.x
branch. The maintenance release will then be built from the2.19.1
branch.What users have asked for this feature?
This is a change to development and will not impact users. Developers frequently complain about friction introduced by backports.
What problems are you trying to solve?
This proposal is an attempt to reduce development friction by optimizing for what we routinely do (develop new features in a backward compatible way targeted toward the next minor release) at the expense of what we do not do (incubate breaking changes for an extended period in a snapshot build of the next major release).
What is the developer experience going to be?
The vast majority of code changes are intended to be released in the next minor version. With this proposal, such changes will require only one PR to commit the change to the
main
branch. This is in contrast to the procedure today, which requires committing the change tomain
and triggering a backport to the2.x
branch.Are there any security considerations?
No.
Are there any breaking changes to the API
No.
Why should it be built? Any reason not to?
We should do this to improve the developer experience across dozens of repos.
The downside is that we will have no dedicated place to stage future 4.0 changes or routinely build 4.0 snapshot distributions. If someone wants to incubate a breaking change they would need to create a separate branch and regularly rebase it against main. We would have no automated mechanism to build a complete 4.0 distribution containing breaking changes in multiple components.
What will it take to execute?
This is a change in branching convention that will have to be coordinated across all repos that are part of the distribution. Some release tooling in opensearch-build may need to be updated to handle the new convention.
The text was updated successfully, but these errors were encountered: