Open source projects can use a variety of different models for deciding when to put out a release. Some projects release on a set schedule. Others decide on what the next release should contain and release whenever that is ready. Some just wake up one day and decide it’s time to release. And other projects go for a rolling release model, avoiding the question entirely.
For Fedora, we go with a schedule-based approach. Releasing twice a year means we can give our contributors time to implement large changes while still keeping on the leading edge. Targeting releases for the end of April and the end of October gives everyone predictability: contributors, users, upstreams, and downstreams.
But it’s not enough to release whatever’s ready on the scheduled date. We want to make sure that we’re releasing quality software. Over the years, the Fedora community has developed a set of processes to help ensure we can meet both our time and and quality targets.
Changes process
Meeting our goals starts months before the release. Contributors propose changes through our Changes process, which ensures that the community has a chance to provide input and be aware of impacts. For changes with a broad impact (called “system-wide changes”), we require a contingency plan that describes how to back out the change if it’s broken or won’t be ready in time. In addition, the change process includes providing steps for testing. This helps make sure we can properly verify the results of a change.
Change proposals are due 2-3 months before the beta release date. This gives the community time to evaluate the impact of the change and make adjustments necessary. For example, a new compiler release might require other package maintainers to fix bugs exposed by the new compiler or to make changes that take advantage of new capabilities.
A few weeks before the beta and final releases, we enter a code freeze. This ensures a stable target for testing. Bugs identified as blockers and non-blocking bugs that are granted a freeze exception are updated in the repo, but everything else must wait. The freeze lasts until the release.
Blocker and freeze exception process
In a project as large as Fedora, it’s impossible to test every possible combination of packages and configurations. So we have a set of test cases that we run to make sure the key features are covered.
As much as we’d like to ship with zero bugs, if we waited until we reached that state, there’d never be another Fedora release again. Instead, we’ve defined release criteria that define what bugs can block the release. We have basic release criteria that apply to all release milestones, and then separate, cumulative criteria for beta and final releases. With beta releases, we’re generally a little more forgiving of rough edges. For a final release, it needs to pass all of beta’s criteria, plus some more that help make it a better user experience.
The week before a scheduled release, we hold a “go/no go meeting“. During this meeting, the QA team, release engineering team, and the Fedora Engineering Steering Committee (FESCo) decide whether or not we will ship the release. As part of the decision process, we conduct a final review of blocker bugs. If any accepted blockers remain, we push the release back to a later date.
Some bugs aren’t severe enough to block the release, but we still would like to get them fixed before the release. This is particularly true of bugs that affect the live image experience. In that case, we grant an exception for updates that fix those bugs.
How you can help
In all my years as a Fedora contributor, I’ve never heard the QA team say “we don’t need any more help.” Contributing to the pre-release testing processes can be a great way to make your first Fedora contribution.
The Blocker Review meetings happen most Mondays in #fedora-blocker-review on IRC. All members of the Fedora community are welcome to participate in the discussion and voting. One particularly useful contribution is to look at the proposed blockers and see if you can reproduce them. Knowing if a bug is widespread or not is important to the blocker decision.
In addition, the QA team conducts test days and test weeks focused on various parts of the distribution: the kernel, GNOME, etc. Test days are announced on Fedora Magazine.
There are plenty of other ways to contribute to the QA process. The Fedora wiki has a list of tasks and how to contact the QA team. The Fedora 32 Beta release is a few weeks away, so now’s a great time to get started!
David
sounds great indeed, However I noticed that some packages didn’t update to their last version since years now, for exemple csync2 which is in version 2.2 and uses sqlite3 but rather the rpm of Fedora 30 and 31 is in version 1.34 using sqlite2, messing and breaking its use after update from Fedora 29 since sqlite3 took precedence after this version.
hammerhead corvette
Is it possible to run this in a container?
Scott Dowdle
Greetings,
I’d recommend you file a bug on csync2 if there isn’t one already. There is no comprehensive plan to update everything single package… as different packages are done by different packagers… who might be at different stages of their interest. There is a process to determine when a packager as become unresponsive and then their package is either transferred to a different packager or in the worst case scenario, the package is marked as abandoned and eventually gets dropped it it is deemed necessary. That package lifecycle is vary similar across many distributions.
Moritz
Bugs already exist for csync, e.g. #1124033. Maintainers can get lazy, and I finf it quite a bit of a hassle going through the red tape.
If it’s just for personal use, I try to build my preferred version in a COPR. That said, for csync2, there are two COPRs with csync-2.0 and sqlite3 support. Alas, they only build for EPEL/RHEL so far, but either you can ask the maintainers to also create builds for F3x+, or I can build them for you.
https://copr.fedorainfracloud.org/coprs/fzipi/csync2/
https://copr.fedorainfracloud.org/coprs/rabiny/csync2/
Adding COPRs to your installation is a breeze, BTW.