Churchyard (talk | contribs) |
Churchyard (talk | contribs) m (→Scope) |
||
Line 70: | Line 70: | ||
* '''Django libraries owners:''' Either drop Python 2 subpackages (eventually retire the package if no subpackages are left) or use {{package|python2-django1.11}} as a dependency for the python 2 subpackages iff those are needed by apps. When removing subpackages, add proper Obosletes tags to their Python 3 counterparts. When orphaning entire packages, add Obosletes to the {{package|python3-django}} package. | * '''Django libraries owners:''' Either drop Python 2 subpackages (eventually retire the package if no subpackages are left) or use {{package|python2-django1.11}} as a dependency for the python 2 subpackages iff those are needed by apps. When removing subpackages, add proper Obosletes tags to their Python 3 counterparts. When orphaning entire packages, add Obosletes to the {{package|python3-django}} package. | ||
* Release engineering: [https://pagure.io/releng/issues #Releng issue number] (a check of an impact with Release Engineering is needed) <!-- REQUIRED FOR SYSTEM WIDE AS WELL AS FOR SELF CONTAINED CHANGES --> | * '''Release engineering:''' [https://pagure.io/releng/issues #Releng issue number] (a check of an impact with Release Engineering is needed) <!-- REQUIRED FOR SYSTEM WIDE AS WELL AS FOR SELF CONTAINED CHANGES --> | ||
<!-- Does this feature require coordination with release engineering (e.g. changes to installer image generation or update package delivery)? Is a mass rebuild required? include a link to the releng issue. | <!-- Does this feature require coordination with release engineering (e.g. changes to installer image generation or update package delivery)? Is a mass rebuild required? include a link to the releng issue. | ||
The issue is required to be filed prior to feature submission, to ensure that someone is on board to do any process development work and testing, and that all changes make it into the pipeline; a bullet point in a change is not sufficient communication --> | The issue is required to be filed prior to feature submission, to ensure that someone is on board to do any process development work and testing, and that all changes make it into the pipeline; a bullet point in a change is not sufficient communication --> | ||
** | ** releng will help with bulk retirement of packages that fail to keep up with this proposal | ||
<!-- Please check the list of Fedora release deliverables and list all the differences the feature brings --> | <!-- Please check the list of Fedora release deliverables and list all the differences the feature brings --> | ||
Line 81: | Line 81: | ||
<!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
<!-- Do the packaging guidelines or other documents need to be updated for this feature? If so, does it need to happen before or after the implementation is done? If a FPC ticket exists, add a link here. --> | <!-- Do the packaging guidelines or other documents need to be updated for this feature? If so, does it need to happen before or after the implementation is done? If a FPC ticket exists, add a link here. --> | ||
List of packages requiring {{package|python2-django}}/ {{package|python-django}} without having <code>django</code> in their name: | List of packages requiring {{package|python2-django}}/ {{package|python-django}} without having <code>django</code> in their name: |
Revision as of 14:25, 12 December 2017
Django 2.0
Summary
This change is about upgrading python-django
to version 2.0. The latest Django release drops support for Python 2, but a few Django apps packaged in Fedora do not yet support Python 3. A compatibility package will be provided for those.
Owner
- Name: Matthias Runge
- Name: Miro Hrončok
- Name: Petr Viktorin
- Email: <python-devel@lists.fedoraproject.org>
- Release notes owner:
Current status
- Targeted release: Fedora 28
- Last updated: 2017-12-12
- Tracker bug: <will be assigned by the Wrangler>
Detailed Description
The latest Django release 2.0 finally drops support for Python 2.7. Not all dependent applications in Fedora can keep up with Djangos pace. This change describes a way how to enable both, keeping 2.7 compatibility and also leveraging the latest version.
The python-django
package will be updated to 2.0, Python 2 subpackage(s) will be removed. A new compatibility python2-django1.11
package will be created with Python 2 version of Django 1.11. The Django 1.11.x series is the last to support Python 2.7, it also has Long Term Support (supported until April 2020 by upstream). See the Django 2.0 release notes for details about Django compatibility with various Python versions.
The new python2-django1.11
package will obsolete python2-django < 2
and python-django < 2
, but it will deliberately not provide either of those. This will render packages depending on python(2)-django
FTBFS (or broken runtime dependencies if tehy don't require Django at buildtime). This is intentional. If we don't do that, all Django packages in Fedora will just keep dragging the Legacy Python dependency chain forever. Package owners of Django applications requiring Python 2 will need to manually adjust their dependencies to use python2-django1.11
or move to Python 3 only (this is preferred but not always possible). Package owners of Django libraries will need to coordinate this with package owners of the applications. The rule of thumb is: If the library is not required by an application (packaged in Fedora) that uses Legacy Python, remove the Python 2 subpackage (or retire the package, if it cannot support Python 3).
There will be packages that fail to build or have broken dependencies. Package owners shall fix those by the steps described above. Proposal owners will send dist-git Pull Requests or Bugzilla patches to help. Proven packager powers will be used to merge those after 14 days of no activity. The removal of leftover packages from Fedora will be coordinated with FESCo.
Most of the Django packages in Fedora are already Python 3 compatible.
Benefit to Fedora
Fedora will be able to provide both: latest and current release of Django and also a fallback for applications, which do not support Python 3 yet.
This will also remove some Legacy packages nobody is actively taking care of.
Scope
- Proposal owners: drop Python 2 subpackage(s) from
python-django
, upgradepython-django
to 2.0 and packagepython2-django1.11
for Python 2 only.
- Django apps owners: Either update to Python 3 or use
python2-django1.11
as a dependency.
- Django libraries owners: Either drop Python 2 subpackages (eventually retire the package if no subpackages are left) or use
python2-django1.11
as a dependency for the python 2 subpackages iff those are needed by apps. When removing subpackages, add proper Obosletes tags to their Python 3 counterparts. When orphaning entire packages, add Obosletes to thepython3-django
package.
- Release engineering: #Releng issue number (a check of an impact with Release Engineering is needed)
- releng will help with bulk retirement of packages that fail to keep up with this proposal
- Policies and guidelines:
- Python packaging guidelines
- Documentation should be provided
List of packages requiring python2-django
/ python-django
without having django
in their name:
cobbler-web
fts-monitoring
gramps-webapp
graphite-web
pony
pulp-server
python2-kobo-admin
python2-kobo-hub
python2-pelican
python2-testfixtures-tests
python2-whitenoise
python2-xmlrunner
Upgrade/compatibility impact
The obsoletes added to python2-django1.11
and others should make the upgrade work seamlessly.
How To Test
You should be able to install two web-apps, one requiring python2-django1.11
and one requiring python3-django
. (TODO: provide actual package names)
- dnf install (package 1)
- see python2-django1.11 is installed as dependency
- run that package
- dnf install (package 2)
- verify python3-django is installed as dependency
- package 1 still works
- package 2 works as well
- dnf remove package 1
- package 2 still works
User Experience
Users using RPM installed Django to develop Django apps might be affected by this change. We shall recommend either using venvs or using Python 3. See The developer portal, we are already recommending both.
Contingency Plan
- Contingency mechanism: (What to do? Who will do it?) Add
python2-django
andpython-django
virtual provides topython2-django1.11
. - Contingency deadline: beta freeze
- Blocks release? No
- Blocks product? No
Documentation
TBD
Release Notes
TBD