-
-
Notifications
You must be signed in to change notification settings - Fork 175
Description
It would be good to have a simple plan to deprecate old Python versions and support new Python versions that would:
- track the EOL timeline of Python proper https://devguide.python.org/versions/
- but also track support of Python version in mainline Linux distros. See below.
- and also consider the context of a given project (library vs. application). Libraries may need a wider support of versions, while apps can have narrower ranges.
- and also consider which versions in which packaging are getting major bug and security fixes.
What this mean is that the Python.org EOL'ed versions may still need to supported.
Alternatively if we start promoting only containerized deployments, we could more readily deprecated and drop older Python versions, including non EOL'ed versions, but to the detriment of using the code a libraries....
We should also consider the many small things related to change of supported versions:
- CHANGELOG entries, READMEs and documentation updates
- pyproject/setup changes to add version constraints?
- Ci test suites across versions
One approach would be to have two policies:
- for libraries, we could support all Python versions that are receiving security and bug fixes, as of today, 3.9 to 3.12
- for apps, we could support only container deployments with a more restricted number of more recent versions, like the latest stable only 3.12
- for new versions we should define when we adopt them as supported. For instance 3.13 has just been released, and we could state that we work to support a new major release (like 3.13) within 12 months of its publication. Or we could also support re-releases, but frankly this is not something I look forward to.
As for supported versions, here is the https://devguide.python.org/versions/ EOL timeline:
And here is the distro support for various versions:
- On Debian:
Package python3
buster (oldoldstable) (python): interactive high-level object-oriented language (default python3 version) 3.7.3-1: amd64 arm64 armhf i386 bullseye (oldstable) (python): interactive high-level object-oriented language (default python3 version) 3.9.2-3: amd64 arm64 armel armhf i386 mips64el mipsel ppc64el s390x bookworm (stable) (python): interactive high-level object-oriented language (default python3 version) 3.11.2-1+b1: amd64 arm64 armel armhf i386 mips64el mipsel ppc64el s390x trixie (testing) (python): interactive high-level object-oriented language (default python3 version) 3.12.6-1: amd64 arm64 armel armhf i386 mips64el ppc64el riscv64 s390x
- On Ubuntu:
Package python3
focal (20.04LTS) (python): interactive high-level object-oriented language (default python3 version) 3.8.2-0ubuntu2: amd64 arm64 armhf i386 ppc64el riscv64 s390x jammy (22.04LTS) (python): interactive high-level object-oriented language (default python3 version) 3.10.6-1~22.04 [security]: amd64 i386 3.10.4-0ubuntu2 [ports]: arm64 armhf ppc64el riscv64 s390x jammy-updates (python): interactive high-level object-oriented language (default python3 version) 3.10.6-1~22.04.1: amd64 arm64 armhf i386 ppc64el riscv64 s390x noble (24.04LTS) (python): interactive high-level object-oriented language (default python3 version) 3.12.3-0ubuntu1: amd64 arm64 armhf i386 ppc64el riscv64 s390x
- On Fedora
Fedora 34 3.9.2-1.fc34
Fedora 36 3.10.11-1.fc36
Fedora 38 3.11.9-2.fc38
Fedora 40 3.12.7-1.fc40
Fedora 41 3.13.0-1.fc41