Fixed #23079 -- Added data loss issues to those that will be backported to LTS.
This commit is contained in:
parent
b012122d30
commit
e46801f13d
|
@ -19,9 +19,9 @@ Since version 1.0, Django's release numbering works as follows:
|
||||||
|
|
||||||
* ``C`` is the *minor version* number, which is incremented for bug and
|
* ``C`` is the *minor version* number, which is incremented for bug and
|
||||||
security fixes. A new minor release will be 100% backwards-compatible with
|
security fixes. A new minor release will be 100% backwards-compatible with
|
||||||
the previous minor release. The only exception is when a security issue
|
the previous minor release. The only exception is when a security or data loss
|
||||||
can't be fixed without breaking backwards-compatibility. If this happens,
|
issue can't be fixed without breaking backwards-compatibility. If this
|
||||||
the release notes will provide detailed upgrade instructions.
|
happens, the release notes will provide detailed upgrade instructions.
|
||||||
|
|
||||||
* Before a new major release, we'll make alpha, beta, and release candidate
|
* Before a new major release, we'll make alpha, beta, and release candidate
|
||||||
releases. These are of the form ``A.B alpha/beta/rc N``, which means the
|
releases. These are of the form ``A.B alpha/beta/rc N``, which means the
|
||||||
|
@ -67,8 +67,9 @@ security purposes, please see :doc:`our security policies <security>`.
|
||||||
fix security issues.
|
fix security issues.
|
||||||
|
|
||||||
These releases will be 100% compatible with the associated major release,
|
These releases will be 100% compatible with the associated major release,
|
||||||
unless this is impossible for security reasons. So the answer to "should I
|
unless this is impossible for security reasons or to prevent data loss.
|
||||||
upgrade to the latest minor release?" will always be "yes."
|
So the answer to "should I upgrade to the latest minor release?" will always
|
||||||
|
be "yes."
|
||||||
|
|
||||||
.. _backwards-compatibility-policy:
|
.. _backwards-compatibility-policy:
|
||||||
|
|
||||||
|
@ -87,7 +88,7 @@ varying levels:
|
||||||
|
|
||||||
* Security issues.
|
* Security issues.
|
||||||
|
|
||||||
* Data-loss bugs.
|
* Data loss bugs.
|
||||||
|
|
||||||
* Crashing bugs.
|
* Crashing bugs.
|
||||||
|
|
||||||
|
@ -97,11 +98,8 @@ varying levels:
|
||||||
for bugs that would have prevented a release in the first place (release
|
for bugs that would have prevented a release in the first place (release
|
||||||
blockers).
|
blockers).
|
||||||
|
|
||||||
* Security fixes will be applied to the current master, the previous two major
|
* Security fixes and data loss bugs will be applied to the current master, the
|
||||||
releases, and the current :ref:`LTS release <lts-releases>`.
|
last two major releases, and the current :ref:`LTS release <lts-releases>`.
|
||||||
|
|
||||||
* Committers may choose to backport bugfixes at their own discretion,
|
|
||||||
provided they do not introduce backwards incompatibilities.
|
|
||||||
|
|
||||||
* Documentation fixes generally will be more freely backported to the last
|
* Documentation fixes generally will be more freely backported to the last
|
||||||
release branch. That's because it's highly advantageous to have the docs for
|
release branch. That's because it's highly advantageous to have the docs for
|
||||||
|
@ -116,12 +114,13 @@ Django 1.6 and 1.7. At this point in time:
|
||||||
* Critical bug fixes will be applied to the ``stable/1.6.x`` branch, and
|
* Critical bug fixes will be applied to the ``stable/1.6.x`` branch, and
|
||||||
released as 1.6.1, 1.6.2, etc.
|
released as 1.6.1, 1.6.2, etc.
|
||||||
|
|
||||||
* Security fixes will be applied to ``master``, to the ``stable/1.6.x``
|
* Security fixes and bug fixes for data loss issues will be applied to
|
||||||
branch, and to the ``stable/1.5.x`` branch. They will trigger the release of
|
``master`` and to the ``stable/1.6.x``, ``stable/1.5.x``, and
|
||||||
``1.6.1``, ``1.5.1``, etc.
|
``stable/1.4.x`` (LTS) branches. They will trigger the release of ``1.6.1``,
|
||||||
|
``1.5.1``, ``1.4.1``, etc.
|
||||||
|
|
||||||
* Documentation fixes will be applied to master, and, if easily backported, to
|
* Documentation fixes will be applied to master, and, if easily backported, to
|
||||||
the ``1.6.x`` branch. Bugfixes may also be backported.
|
the ``1.6.x`` branch.
|
||||||
|
|
||||||
.. _lts-releases:
|
.. _lts-releases:
|
||||||
|
|
||||||
|
@ -129,9 +128,9 @@ Long-term support (LTS) releases
|
||||||
================================
|
================================
|
||||||
|
|
||||||
Additionally, the Django team will occasionally designate certain releases
|
Additionally, the Django team will occasionally designate certain releases
|
||||||
to be "Long-term support" (LTS) releases. LTS releases will get security fixes
|
to be "Long-term support" (LTS) releases. LTS releases will get security and
|
||||||
applied for a guaranteed period of time, typically 3+ years, regardless of
|
data loss fixes applied for a guaranteed period of time, typically 3+ years,
|
||||||
the pace of releases afterwards.
|
regardless of the pace of releases afterwards.
|
||||||
|
|
||||||
The follow releases have been designated for long-term support:
|
The follow releases have been designated for long-term support:
|
||||||
|
|
||||||
|
@ -220,24 +219,3 @@ bugfixes. Critical bugs fixed on master must *also* be fixed on the bugfix
|
||||||
branch; this means that commits need to cleanly separate bug fixes from feature
|
branch; this means that commits need to cleanly separate bug fixes from feature
|
||||||
additions. The developer who commits a fix to master will be responsible for
|
additions. The developer who commits a fix to master will be responsible for
|
||||||
also applying the fix to the current bugfix branch.
|
also applying the fix to the current bugfix branch.
|
||||||
|
|
||||||
How this all fits together
|
|
||||||
--------------------------
|
|
||||||
|
|
||||||
Let's look at a hypothetical example for how this all first together. Imagine,
|
|
||||||
if you will, a point about halfway between 1.5 and 1.6. At this point,
|
|
||||||
development will be happening in a bunch of places:
|
|
||||||
|
|
||||||
* On master, development towards 1.6 proceeds with small additions, bugs
|
|
||||||
fixes, etc. being checked in daily.
|
|
||||||
|
|
||||||
* On the branch ``stable/1.5.x``, fixes for critical bugs found in
|
|
||||||
the 1.5 release are checked in as needed. At some point, this branch will
|
|
||||||
be released as "1.5.1", "1.5.2", etc.
|
|
||||||
|
|
||||||
* On the branch ``stable/1.4.x``, security fixes are made if
|
|
||||||
needed and released as "1.4.2", "1.4.3", etc.
|
|
||||||
|
|
||||||
* Development of major features is done in branches in forks of the main
|
|
||||||
repository. These branches will be merged into ``master`` before "1.6
|
|
||||||
alpha 1".
|
|
||||||
|
|
Loading…
Reference in New Issue