mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
[5.2.x] Updated the release process documentation to reflect the current process.
Backport of 0ba35a4948
from main.
This commit is contained in:
@@ -184,54 +184,68 @@ Release process
|
||||
Django uses a time-based release schedule, with feature releases every eight
|
||||
months or so.
|
||||
|
||||
After each feature release, the release manager will announce a timeline for
|
||||
the next feature release.
|
||||
After each feature release, the release manager will publish a timeline for the
|
||||
next feature release. The timeline for an upcoming feature release can be found
|
||||
in the corresponding wiki roadmap page, e.g.
|
||||
https://code.djangoproject.com/wiki/Version6.0Roadmap.
|
||||
|
||||
Release cycle
|
||||
-------------
|
||||
Feature release schedule and stages
|
||||
-----------------------------------
|
||||
|
||||
Each release cycle consists of three parts:
|
||||
Active development / Pre-feature freeze
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
Phase one: feature proposal
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
Work begins on the feature release ``A.B`` after the feature freeze of the
|
||||
previous release, i.e. when the ``stable/A.B-1.x`` branch is forked.
|
||||
|
||||
The first phase of the release process will include figuring out what major
|
||||
features to include in the next version. This should include a good deal of
|
||||
preliminary work on those features -- working code trumps grand design.
|
||||
You can find the current branch under active development in the
|
||||
`Django release process
|
||||
<https://code.djangoproject.com/#Djangoreleaseprocess>`_ on Trac.
|
||||
|
||||
Major features for an upcoming release will be added to the wiki roadmap page,
|
||||
e.g. https://code.djangoproject.com/wiki/Version1.11Roadmap.
|
||||
Feature freeze / Alpha release
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
Phase two: development
|
||||
~~~~~~~~~~~~~~~~~~~~~~
|
||||
All major and minor features, including deprecations and breaking changes, must
|
||||
be merged by the feature freeze. Any features not done by this point will be
|
||||
deferred to the next feature release.
|
||||
|
||||
The second part of the release schedule is the "heads-down" working period.
|
||||
Using the roadmap produced at the end of phase one, we'll all work very hard to
|
||||
get everything on it done.
|
||||
At this point, the ``stable/A.B.x`` branch will be forked from ``main``.
|
||||
|
||||
At the end of phase two, any unfinished features will be postponed until the
|
||||
next release.
|
||||
Non-release blocking bug fix freeze / Beta release
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
Phase two will culminate with an alpha release. At this point, the
|
||||
``stable/A.B.x`` branch will be forked from ``main``.
|
||||
After the alpha, all bug fixes merged in ``main`` are also backported to
|
||||
``stable/A.B.x``. Refactors are backported at the discretion of the merger.
|
||||
Mergers will be more and more conservative with backports, to avoid introducing
|
||||
regressions.
|
||||
|
||||
Phase three: bugfixes
|
||||
~~~~~~~~~~~~~~~~~~~~~
|
||||
In parallel to this phase, ``main`` can continue to receive new features, to be
|
||||
released in the ``A.B+1`` cycle.
|
||||
|
||||
The last part of a release cycle is spent fixing bugs -- no new features will
|
||||
be accepted during this time. We'll try to release a beta release one month
|
||||
after the alpha and a release candidate one month after the beta.
|
||||
Translation string freeze / Release candidate release
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
If there is still a consistent stream of release blockers coming in at the
|
||||
planned release candidate date, a beta 2 will be released to encourage further
|
||||
testing and the release candidate date will be pushed out ~1 month.
|
||||
|
||||
The release candidate marks the string freeze, and it happens at least two
|
||||
weeks before the final release. After this point, new translatable strings
|
||||
must not be added.
|
||||
weeks before the final release. Translators can then submit updated
|
||||
translations for inclusion in the final release. After this point, new
|
||||
translatable strings must not be added.
|
||||
|
||||
During this phase, mergers will be more and more conservative with backports,
|
||||
to avoid introducing regressions. After the release candidate, only release
|
||||
blockers and documentation fixes should be backported.
|
||||
After the release candidate, only release blockers and documentation fixes are
|
||||
backported.
|
||||
|
||||
In parallel to this phase, ``main`` can receive new features, to be released
|
||||
in the ``A.B+1`` cycle.
|
||||
Final release
|
||||
~~~~~~~~~~~~~
|
||||
|
||||
Ideally, the final release will ship two weeks after the last release
|
||||
candidate.
|
||||
|
||||
If there are major bugs still being found 2 weeks after the release candidate,
|
||||
there will be a decision on how to proceed (likely another release candidate
|
||||
would be issued and the final release date will be pushed out).
|
||||
|
||||
Bug-fix releases
|
||||
----------------
|
||||
|
Reference in New Issue
Block a user