17. Development Cycle¶
The responsibilities of a core developer shift based on what kind of branch of Python a developer is working on and what stage the branch is in.
To clarify terminology, Python uses a
for production-ready releases. So for Python 3.1.2 final, that is a major
version of 3, a minor version of 1, and a micro version of 2.
- new major versions are exceptional; they only come when strongly incompatible changes are deemed necessary, and are planned very long in advance;
- new minor versions are feature releases; they get released roughly every 18 months, from the current in-development branch;
- new micro versions are bugfix releases; they get released roughly every 6 months, although they can come more often if necessary; they are prepared in maintenance branches.
There is a branch for each feature version, whether released or not (e.g. 2.7, 3.6). Development is handled separately for Python 2 and Python 3: no merging happens between 2.x and 3.x branches.
In each of the 2.x and 3.x realms, the branch for a feature version is always a
descendant of the previous feature version: for example, the
3.6 branch is a
descendant of the
Therefore, each change should be made first in the oldest branch to which it
applies and forward-ported as appropriate: if a bug must be fixed in both Python
3.6 and 3.7, first fix it in
3.6 and then merge
(which holds the future 3.7).
17.1.1. In-development (main) branch¶
default branch is the branch for the next feature release; it is
under active development for all kinds of changes: new features, semantic
changes, performance improvements, bug fixes. As the name indicates, it
is the branch checked out by default by Mercurial.
At some point during the life-cycle of a release, a new maintenance branch is created to host all bug fixing activity for further micro versions (3.3.1, 3.3.2, etc.).
For versions 3.4 and before, this was conventionally done when the final release was cut (for example, 3.4.0 final).
Starting with the 3.5 release, we create the release maintenance branch (e.g. 3.5) at the time we enter beta (3.5.0 beta 1). This allows feature development for the release 3.n+1 to occur within the default branch alongside the beta and release candidate stabilization periods for release 3.n.
17.1.2. Maintenance branches¶
A branch for a previous feature release, currently being maintained for bug fixes. There are usually two maintenance branches at any given time: one for Python 3.x and one for Python 2.x. At some point in the future, Python 2.x will be closed for bug fixes and there will be only one maintenance branch left.
The only changes allowed to occur in a maintenance branch without debate are bug fixes. Also, a general rule for maintenance branches is that compatibility must not be broken at any point between sibling minor releases (3.5.1, 3.5.2, etc.). For both rules, only rare exceptions are accepted and must be discussed first.
Sometime after a new maintenance branch is created (after a new minor version is released), the old maintenance branch on that major version will go into security mode, usually after one last maintenance release at the discretion of the release manager. For example, the 3.4 maintenance branch was put into security mode after the 3.4.4 final maintenance release following the release of 3.5.1.
17.1.3. Security branches¶
A branch less than 5 years old but no longer in maintenance mode.
The only changes made to a security branch are those fixing issues exploitable by attackers such as crashes, privilege escalation and, optionally, other issues such as denial of service attacks. Any other changes are not considered a security risk and thus not backported to a security branch. You should also consider fixing hard-failing tests in open security branches since it is important to be able to run the tests successfully before releasing.
Commits to security branches are to be coordinated with the release manager for the corresponding feature version, as listed below in the Summary. Any release made from a security branch is source-only and done only when actual security patches have been applied to the branch.
There are 7 open branches right now in the Mercurial repository:
defaultbranch holds the future 3.7 version and descends from
3.6(RM: Ned Deily)
3.6branch holds bug fixes for 3.6.0 and future 3.6.x maintenance releases and descends from
3.5(RM: Ned Deily)
3.5branch holds bug fixes for future 3.5.x maintenance releases and descends from
3.4(RM: Larry Hastings)
3.4branch holds security fixes for future 3.4.x security releases and descends from
3.3(RM: Larry Hastings)
3.3branch holds security fixes for future 3.3.x security releases until September 2017 and descends from
3.2(RM: Georg Brandl)
3.2branch holds security fixes for future 3.2.x security releases until February 2016 (RM: Georg Brandl)
2.7branch holds bug fixes for future 2.7.x maintenance releases and descends from
2.6(RM: Benjamin Peterson)
See also the Status of Python branches.
Based on what stage the in-development version of Python is in, the responsibilities of a core developer change in regards to commits to the VCS.
The branch is in this stage when no official release has been done since the latest final release. There are no special restrictions placed on commits, although the usual advice applies (getting patches reviewed, avoiding breaking the buildbots).
Alpha releases typically serve as a reminder to core developers that they need to start getting in changes that change semantics or add something to Python as such things should not be added during a Beta. Otherwise no new restrictions are in place while in alpha.
After a first beta release is published, no new features are accepted. Only bug fixes can now be committed. This is when core developers should concentrate on the task of fixing regressions and other new issues filed by users who have downloaded the alpha and beta releases.
Being in beta can be viewed much like being in RC but without the extra overhead of needing commit reviews.
Please see the note in the In-development (main) branch section above for new information about the creation of the 3.5 maintenance branch during beta.
17.2.4. Release Candidate (RC)¶
A branch preparing for an RC release can only have bugfixes applied that have been reviewed by other core developers. Generally, these issues must be severe enough (e.g. crashes) that they deserve fixing before the final release. All other issues should be deferred to the next development cycle, since stability is the strongest concern at this point.
You cannot skip the peer review during an RC, no matter how small! Even if it is a simple copy-and-paste change, everything requires peer review from a core developer.