Opened 6 weeks ago
Last modified 3 weeks ago
#35980 assigned Cleanup/optimization
Make Django release artifacts PEP 625 compliant
Reported by: | Sarah Boyce | Owned by: | Natalia Bidart |
---|---|---|---|
Component: | Packaging | Version: | 5.1 |
Severity: | Normal | Keywords: | |
Cc: | Claude Paroz, Natalia Bidart, Mariusz Felisiak, Tim Graham, Carlton Gibson, Nick Pope, Baptiste Mispelon | Triage Stage: | Accepted |
Has patch: | yes | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | yes |
Easy pickings: | no | UI/UX: | no |
Description
After the recent security release, I received some email notifications from PyPI:
This email is notifying you of an upcoming deprecation that we have determined may affect you as a result of your recent upload to 'Django'.
In the future, PyPI will require all newly uploaded source distribution filenames to comply with PEP 625. Any source distributions already uploaded will remain in place as-is and do not need to be updated.
Specifically, your recent upload of 'Django-5.1.4.tar.gz' is incompatible with PEP 625 because it does not contain the normalized project name 'django'.
In most cases, this can be resolved by upgrading the version of your build tooling to a later version that supports PEP 625 and produces compliant filenames.
If you have questions, you can email admin@… to communicate with the PyPI admin@… to communicate with the PyPI administrators.
I believe this relates to: https://github.com/pypi/warehouse/issues/12245
There's a chance that they might stop supporting non-normalized names by "end of year": https://github.com/pypi/warehouse/issues/12245#issuecomment-2272378958
I believe the name normalization was also discussed here: https://github.com/django/django/pull/17806#issuecomment-2176465382 hence cc-ing some people involved from that PR
I'm not 100% certain the path forward, it feels to me we might need to make a change and backport to all supported versions and perhaps announce this on the blog. I have no preference, but I need help to know what we should do here.
Change History (12)
comment:1 by , 6 weeks ago
Triage Stage: | Unreviewed → Accepted |
---|
comment:2 by , 6 weeks ago
Has patch: | set |
---|
Certainly using v69.3.0 as a minimum version for setuptools
should make us compliant with PEP 625.
But, honestly, I remain as baffled as last time I looked into this. I found this comment which basically says that the source distribution filename should follow the same normalisation rules as the binary distribution filename and that states that uppercase should be replaced with lowercase. So why, oh why, do I get the following?
$ git clean -fdX $ python -m build ... Successfully built django-5.2.dev20241206115354.tar.gz and Django-5.2-py3-none-any.whl
I even tried with the latest setuptools
, at the time of writing v75.6.0.
While we could go to the PyPA and say, "What the heck?", it's probably just easier to change name = Django
to name = django
in pyproject.toml
and move on:
$ git clean -fdX $ python -m build ... Successfully built django-5.2.dev20241206115354.tar.gz and django-5.2-py3-none-any.whl
It also seems concerning that the version in the wheel filename is incomplete...
Here is a draft PR for consideration.
I'm not sure what we'll have to do regarding backports, but it might mean a more significant backport of the setup.cfg
to pyproject.toml
changes.
comment:3 by , 6 weeks ago
Also looking at https://packaging.python.org/en/latest/specifications/binary-distribution-format/#file-name-convention...
Oh the irony that "django" is shown as an example of the distribution name... :')
comment:4 by , 6 weeks ago
AFAIR, we refrained from using a recent setuptools with requires = setuptools>=61.0.0,<69.3.0, to avoid that change (Django to django).
Yes, that was done in this merge request: https://github.com/django/django/pull/17806#issuecomment-2176465382
I've just tried to build with the latest setuptools (python -m pip install build twine && python -m build
from a clean checkout of the git repo) and it creates two files:
- django-5.2.dev20241206115354.tar.gz
- Django-5.2-py3-none-any.whl
The inconsistent naming seems to be a bug in setuptools (mentionned in the comment on the patch I linked above).
My opinion is that we should be using the latest version of setuptools and let it generate the filenames for the builds. Those filenames are internal plumbing and are not normally exposed to users. They also don't change how Django is installed when using tools like pip, since those tools will normalize names internally as well.
One hitch with this plan is that the current release documentation (both the public one and I assume the ad-hoc scripts used by the fellows) makes assumptions about those filenames that would not hold true anymore.
comment:5 by , 6 weeks ago
I took a look at the website's code to see what changes might be needed if/when the build files' naming structure changes.
It's not too bad, but it's still quite substantial: https://github.com/django/djangoproject.com/pull/1801.
With the changes proposed in this merge request there would be a slight change in the release process, since the build files should now be uploaded via the release creation form, and not via scp
as currently documented.
comment:6 by , 6 weeks ago
Hi, me again 😁
I took a look at the Jenkins confirm-release
job mentionned in the release documentation and the only assumption it makes is that the checksum file is named Django-${VERSION}.checksum.txt
, then it fetches the names of the build files (tarball and wheel as of now) from the checksum file itself.
So we can either keep the capitalized name for the checksum, or change one line in the Jenkins config.
comment:7 by , 6 weeks ago
Cc: | added |
---|---|
Owner: | set to |
Status: | new → assigned |
Hello everyone, I'm assigning this ticket to myself to "own" the transition process. I have read comments, reviewed PRs and pondered about this. I have some thoughts:
- For the changes to djangoproject.com, I added a newer comment suggesting to make the tarball and checksum a cached property (we could use something not fancy but simple like "If the lowercase django-... file exists, return that, otherwise return the uppercase one".
- Uploading the tarballs via the Django admin feels a step in the wrong direction when thinking about automating the Django release process.
- For the changes to Django itself from Nick, those look good, we should think what to do for 5.0 and 4.2. We may need to backport the
pyproject.toml
changes to 5.0 and 4.2, I'm unclear about the implications of this, but it certainly has advantages from the POV of maintaining the project.- It would certainly help the release process to use the same release procedure for all versions.
comment:8 by , 6 weeks ago
Summary: | PyPI will require uploaded source distribution filenames to comply with PEP 625 and contain the normalized project name "django" → Make Django binaries PEP 625 compliant |
---|
comment:9 by , 6 weeks ago
comment:10 by , 6 weeks ago
Component: | Core (Other) → Packaging |
---|
comment:11 by , 6 weeks ago
Summary: | Make Django binaries PEP 625 compliant → Make Django release artifacts PEP 625 compliant |
---|
After lots of reading, I think we are dealing with a mix of issues. The PyPI deprecation warning is only about the tarball, not about the wheel name. Specifically, there are two relevant PEPs:
- PEP 625, which addresses naming conventions for source distributions, and
- PEP 491, which addresses naming conventions for wheels.
As Baptiste said in comment:4, current setuptools
(75.6.0
) produces lowercase django
tarball and capitalized Django
wheel. If we proceed with this as-is, we would resolve the "PyPI warning" for the source distribution, addressing that part of the issue. However, we'd still need smart tools and a flexible download page to handle both naming formats. I think this is doable and would allow us to "detach" ourselves from the pressure of solving the wheel naming inconsistency from external sources.
comment:12 by , 3 weeks ago
Patch needs improvement: | set |
---|
AFAIR, we refrained from using a recent setuptools with
requires = ["setuptools>=61.0.0,<69.3.0"]
, to avoid that change (Django to django). Maybe you could try a setuptools version > 69.3 and see what's happening?