Skip to content

Commit

Permalink
announce sunsetting python3.7 in bundled lockfiles
Browse files Browse the repository at this point in the history
Providing the path forward for:
pantsbuild/pants#21184
pantsbuild/pants#21103
  • Loading branch information
cburroughs committed Aug 21, 2024
1 parent 9ea8b7f commit b3abbf3
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 0 deletions.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
35 changes: 35 additions & 0 deletions blog/2024-08-24-venerable-pythons/index.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
---
authors: [cburroughs]
tags: [announcement]
date: 2024-08-22
---

# Venerable Pythons, Pants, Pip, and Ecosystems

<CaptionedImg src={require("./splash.jpeg").default}>
Photo by [David Clode](https://unsplash.com/@davidclode) /
[Unsplash](https://unsplash.com/photos/python-resting-its-head-on-body-yrcaXCWe0VY)
</CaptionedImg>

{/* truncate */}


The Python development community concurrently supports multiple version of the Python programming language. These are in various states such as "prerelease", "bugfix", "security", or "end-of-life". For example version 3.12 is currently in "bugfix" while 3.8 is the oldest still receiving security updates. The cadence of future release is currently governed by [PEP 602 – Annual Release Cycle for Python](https://peps.python.org/pep-0602/)

Circa 2024 the state of [all Python versions](https://devguide.python.org/versions/) look something like:

![CPython Release Status](./cpython-release-status.png)

That covers Python the *language*. The various projects and libraries that make up the broader Python ecosystem may support versions on different timetables. For example the `pip` project stopped supporting Python 3.7 in [2024-05](https://pip.pypa.io/en/stable/news/#b1-2024-05-06) which was significantly after Python 3.7 itself reached end-of-life in 2023. Other projects may hue closer to the "bleeding edge".

There are a few different "versions of Python" that are relevant for Pants:

* The versions of Python that Pants can test and build.
* The versions of Python that Pants supports "out of the box" with default tool lockfiles. This includes tools like `pip`, `black`, or `mypy`.
* The version of Python that Pants itself is written in. This is only relevant for plugin authors, the version that Pants itself uses is otherwise an [implementation detail](/blog/2023/02/23/the-pants-launcher-binary-a-much-simpler-way-to-install-and-run-pants)

Starting in Pants version 2.23, the default tool lockfile bundled with Pants will no longer support Python 3.7. Pants will still build and test Python 3.7 code! But you will first need to create your own [tool lockfiles](https://www.pantsbuild.org/2.21/docs/python/overview/lockfiles#lockfiles-for-tools).

This will allow the bundled lockfiles to support [versions of pip that will generate lockfiles faster](https://pip.pypa.io/en/stable/news/#v24-2), the [Python 3.13 release](https://github.com/pantsbuild/pants/issues/21103), and [more secure](https://github.com/pantsbuild/pants/issues/21184) versions of `setuptools`.

In the future as support across the Python ecosystem ebbs and flows, Pants will continue to adjust to provide broad "out of the box" support for a variety of Python versions.
Binary file added blog/2024-08-24-venerable-pythons/splash.jpeg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit b3abbf3

Please sign in to comment.