-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
Add a document describing release cycle and backporting criteria. #18636
Changes from 6 commits
1d4ab1e
efcdefa
09eea23
6d0072b
f41f46a
4f80ed7
8a4d117
a189999
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 |
---|---|---|
@@ -0,0 +1,168 @@ | ||
# Scala LTS maintenance and release cycle | ||
|
||
## Scala LTS and Scala Next | ||
|
||
Since Scala 3.3.0, there are always two versions of Scala 3 being developed at the same time: Scala Next and Scala LTS. | ||
|
||
Scala Next continues all practices since before the 3.3.0. It maintains backward output (TASTy and binary) compatibility between all versions and forward output compatibility between patch releases of the same minor version. This version is being actively developed on the `main` branch. All new bug fixes and features will be merged to that version, i.e., to the `main` branch. | ||
|
||
Scala LTS is a selected minor version (currently 3.3) that, unlike all other minor versions, has patch releases even though there is a newer minor version. Aside from our standard output compatibility guarantees, it is intended to preserve backward source compatibility. As no new features and bugfixes (with the rare exception of LTS-only hotfixes) will be developed for LTS, but instead, selected changes from the Next branch will be backported, there is no development branch for Scala LTS. All changes are merged to release branches instead. The commit marked with a full release tag for any version is the base for the release branch for the next version. | ||
|
||
## What should be backported? | ||
|
||
The decision of what changes merged to the `main` branch should be backported is taken according to the following flowchart: | ||
|
||
```mermaid | ||
flowchart TB | ||
start(["PR relevant for LTS was merged to main branch"]) | ||
--> | ||
cve{"Is this | ||
a fix for a CVE?"} | ||
Kordyjan marked this conversation as resolved.
Show resolved
Hide resolved
|
||
-- yes --> ocb | ||
|
||
subgraph "CVE" | ||
ocb{"Does it cause | ||
any new failures | ||
in the full CB?"} | ||
|
||
-- yes --> | ||
regFix[\"Try to provide | ||
a followup fix for | ||
a regressions"/] | ||
|
||
-- failure --> | ||
debate[\"Possible workarounds | ||
for new regressions are discussed | ||
by the compiler team"/] | ||
|
||
regFix -- success --> ocb | ||
end | ||
ocb -- no --> acc | ||
debate -->|"decision on | ||
the recommended | ||
workarounds"| acc | ||
|
||
cve -- no --> | ||
incompat{"Does the fix | ||
break forward | ||
compatibiliy?"} | ||
-- yes --> reject | ||
|
||
incompat -- no --> | ||
|
||
regression{"Is this a fix for | ||
a regression present | ||
also in LTS?"} | ||
-- yes --> | ||
|
||
regIsLTS{"Was the last version | ||
affected by | ||
the regression released | ||
before 3.3.0?"} | ||
-- yes --> ocbReg | ||
|
||
subgraph "LTS Regression" | ||
ocbReg{"Does it cause | ||
any new failures | ||
in the full CB?"} | ||
|
||
-- yes --> | ||
regFixReg[\"Try to provide | ||
a followup fix for | ||
a regressions"/] | ||
|
||
-- failure --> | ||
debateReg[\"Impact of both new and old regression | ||
and possible workarounds | ||
are discussed by the compiler team."/] | ||
|
||
regFixReg -- success --> ocbReg | ||
end | ||
ocbReg -- no --> acc | ||
debateReg -->|"decision on | ||
the recommended | ||
workarounds for | ||
the new regression"| acc | ||
debateReg -->|"decision on | ||
the recommended | ||
workarounds for | ||
the old regression"| reject | ||
|
||
regression -- no --> types | ||
regIsLTS -- no --> types | ||
types{"Can the fix | ||
change types | ||
in any correct | ||
Scala 3 code?"} | ||
-- yes --> request | ||
types -- no --> ocbOther | ||
|
||
request{"Is backport | ||
of the fix | ||
heavily requested?"} | ||
-- yes --> debateReq | ||
request -- no --> reject | ||
|
||
debateReq[\"Possibility of | ||
the backport is discussed | ||
by the compiler team"/] | ||
--> |"backport is rejected"| reject | ||
debateReq --> |"backport is accepted"| ocbOther | ||
|
||
subgraph "Other Fixes" | ||
ocbOther{"Does it cause | ||
any new failures | ||
in the full CB?"} | ||
|
||
-- yes --> | ||
regFixOther[\"Try to provide | ||
a followup fix for | ||
a regressions"/] | ||
-- success --> ocbOther | ||
|
||
ocbOther -- no --> | ||
lint{"Does it introduce | ||
any new warnings | ||
behind flags?"} | ||
-- yes --> | ||
lintOcb{"Does it cause any | ||
new failures in the full CB | ||
after forcing a new flag?"} | ||
-- yes --> regFixOther | ||
end | ||
|
||
lint -- no --> acc | ||
lintOcb -- no --> acc | ||
regFixOther -- failure --> reject | ||
|
||
acc(["The PR is backported"]) | ||
reject(["The PR is not backported"]) | ||
``` | ||
|
||
## How should things be backported? | ||
|
||
The backporting process is tracked by [a GitHub Project](https://github.com/orgs/lampepfl/projects/6) in the lampepfl organization. Every PR merged to the `main` branch is automatically added to the `Needs Assessment` column. Those PRs are reviewed by the release officer or other appointed person. They can decide to remove them from the project (backport rejected) or to move them to the `Backporting in progress` column. If the PR with the backport has any differences from the original PR, the person doing the backport will ask the author and reviewers of the original change to review the backport. After merging the backport, the PR will be moved to the `Backport done` column and, after the release, to the `Released` column. | ||
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. This link gives me a 404. Maybe the project is private? If that's intended, I think it would still be nice to disclose that. 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. I can open it in private browser window, so it shouldn't be private now. 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. I can confirm that I do see it now 👍 |
||
|
||
Maintainers can request backporting the entirety or a part of previously rejected PR by adding it to the `Backport requested` column. | ||
|
||
Labels from the `backport:*` are used only for backports that targets versions with already released RCs. They can be used to mark changes on the main that are fixing a critical bug present in the Scala Next RC release or changes that were backported to the future Scala LTS versions that should be also backported to the current RCs. | ||
|
||
## The release cycles | ||
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. At this point you will probably have lost many of the more casual followers of the blog, as the preceding section are flowchart were quite in-depth. I would suggest also including the most important top level takeaways from this section, such as "Scala Next strictly follows a six-week release train model", in the intro to the blog post. I would suggest reviewing the intro and asking yourself, “What if the reader only reads the introduction? Would they be missing anything vital?" |
||
|
||
Two separate lines of the compiler require two intertwined release cycles. | ||
|
||
Scala Next strictly follows a six-week release train model. Every six weeks, a release candidate for the next version is published. During the next six weeks, we may release subsequent RCs containing fixes to critical bugs found in the previous RCs. A bug may be considered critical only if it is a regression; that is, some code that was correctly passing a compilation in any earlier versions of Scala 3 is now either failing compilation, crashing the compiler, or generating incorrect output (bytecode or TASTy). The compiler team decides which regression is considered a critical bug that requires a new RC and which can be fixed in the next release. After six weeks, the clock resets, the last released RC is promoted to a stable release, and the RC for the next version is published. | ||
|
||
If there is less than a week left before the release, and the last RC still contains critical bugs, the compiler team may decide to postpone publishing the stable version. There will always be at least one whole week between publishing the last RC and promoting it to the status of a stable release. This delay doesn't affect the RC-1 date for the next version. It will be released six weeks after the previous version's RC-1. The goal is to ensure that delay in releasing one version doesn't cause future releases to be larger in terms of the number of merged PRs, as it can make regressions inside of them more complex to pinpoint and fix, leading to the accumulation of delays for future versions. | ||
Kordyjan marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
Scala LTS has a more relaxed release model. RC-1 for the next version is published after the stable release of the previous version. Similar to Scala Next, we may release more RCs, fixing bugs. Unlike Scala Next, the bug doesn't need to be considered critical to guarantee the new RC. For Sala LTS, our primary goal is stability, so delays are acceptable. We guarantee that a stable release is at least six weeks after the first RC and at least one week after the last RC. | ||
|
||
The two release cycles are not synchronized in any way, as any synchronization would be broken on any delay in the Scala LTS cycle. | ||
|
||
The compiler team may pause the release cycles for a week or two on occasions such as New Year or a conference that most of the team is attending. | ||
|
||
### What is being released? | ||
|
||
For the Scala LTS, what is released as an RC is always the current head of the release branch for the next release. | ||
|
||
For the Scala Next minor releases RC, by default, it is the head of the `main` branch. Based on the Open Community Build results, the compiler team may decide to base the release on some earlier state of the branch. |
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.