-
-
Notifications
You must be signed in to change notification settings - Fork 194
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
PLIP: drop Python 3.8 and 3.9 in Plone 6.1 #3926
Comments
I approve this PLIP. cc @plone/framework-team @plone/release-team |
I approve this PLIP. sorry for the delay |
I'd like to amend the documentation issue with this checklist: |
I approve this PLIP, and any other documentation issues that may arise as we discover them. |
I like it, and personally I would even never use 3.10. In my own experience 3.11 is way faster. |
Since we're testing and passing on Python 3.13, should this PLIP be amended to include support for it? I move to amend this PLIP accordingly. Can I get a second? |
Branch: refs/heads/master Date: 2024-12-16T17:41:32+01:00 Author: Maurits van Rees (mauritsvanrees) <[email protected]> Commit: plone/Products.CMFPlone@eba6e73 Officially drop support for Python 3.8 and 3.9, and support 3.13. See plone/Products.CMFPlone#3926 Files changed: A news/313.feature A news/3926.breaking M setup.py
Let's not amend this PLIP: it is finished. Well, I just did the last change needed, in commit eba6e73. We can still "Drop 3.8 and 3.9 classifiers from packages that are for 6.1 only" as one of the tasks says, but that is an ongoing effort as there keep coming more packages that for one reason or another drop Plone 6.0 support. Supporting Python 3.13 does not need a PLIP. |
Responsible Persons
Proposer: Maurits van Rees
Seconder:
Abstract
As agreed in the Plone Steering on 2024-03-07, let's drop Python 3.8 and 3.9 support in Plone 6.1. See community announcement that I just made.
It has already been decided. But in a discussion during the German Plone Tagung last week, we saw value in having a PLIP for all such major changes, even when it is a PLIP after the fact.
Motivation
Until now, the alpha releases of Plone 6.1 supported five Python versions: 3.8 through 3.12. In the next alpha we will drop 3.8 and 3.9. So 6.1 will support 3.10, 3.11, and 3.12. This was agreed during the meeting of the Plone Steering Circle last week. This is a meeting of Plone team leaders.
This means less burden on maintainers within the Plone community, like the release team and A/I team (including testing), and opens up the possibility for Plone core developers to use some more recent features. For inspiration, here is the Python document explaining what is new in each Python version:
https://docs.python.org/3/whatsnew/index.html
See what's new in 3.9 and 3.10 for what we can now use in 6.1 that was not possible earlier, for example the
zoneinfo
module and structural pattern matching (match/case
).Assumptions
If you must use an older Python version, you can stay on Plone 6.0, which will support each Python version until it runs out of security support from the Python community. For Python 3.8 this is October 2024, for Python 3.9 this is October 2025. See https://www.python.org/downloads/.
Proposal & Implementation
The only thing we really must do is announce it, and make it clear in the release notes and update the release schedule.
Deliverables
mr.roboto
as well probably.python_requires>=3.10
to at leastPlone
andProducts.CMFPlone
. We could also wait until there is a change that really requires a newer Python version.SUPPORTED_PYTHON_VERSIONS
replacement when 6.1 is released documentation#1674Perhaps:
plone/meta
are needed for packages that only run on 6.1.Risks
This will break for users that currently have a 6.1 alpha site on 3.8 or 3.9. But that seems unlikely: I expect all 6.1 users to use at least 3.11.
Participants
The text was updated successfully, but these errors were encountered: