Skip to content
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

Closed
7 of 9 tasks
mauritsvanrees opened this issue Mar 13, 2024 · 7 comments
Closed
7 of 9 tasks

PLIP: drop Python 3.8 and 3.9 in Plone 6.1 #3926

mauritsvanrees opened this issue Mar 13, 2024 · 7 comments

Comments

@mauritsvanrees
Copy link
Member

mauritsvanrees commented Mar 13, 2024

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

Perhaps:

  • Check if changes in 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

  • Maurits van Rees
@tisto
Copy link
Member

tisto commented Jun 28, 2024

I approve this PLIP. cc @plone/framework-team @plone/release-team

@MrTango
Copy link
Contributor

MrTango commented Nov 5, 2024

I approve this PLIP. sorry for the delay

@MrTango MrTango moved this to In Process (approved) in PLIPs (core) Nov 5, 2024
@stevepiercy
Copy link
Contributor

I'd like to amend the documentation issue with this checklist:

plone/documentation#1721

@stevepiercy
Copy link
Contributor

I approve this PLIP, and any other documentation issues that may arise as we discover them.

@ale-rt
Copy link
Member

ale-rt commented Nov 6, 2024

I like it, and personally I would even never use 3.10. In my own experience 3.11 is way faster.

@stevepiercy
Copy link
Contributor

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?

mister-roboto pushed a commit to plone/buildout.coredev that referenced this issue Dec 16, 2024
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
@mauritsvanrees
Copy link
Member Author

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.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: In Process (approved)
Development

No branches or pull requests

5 participants