-
Notifications
You must be signed in to change notification settings - Fork 1.8k
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
setuptools <49.0.0 does not handle Python 3.10 correctly in python_version
environment markers
#1248
Comments
@sileht Hi! Thank you for opening an issue :-) The Python buildpack doesn't use heroku-buildpack-python/bin/steps/python Lines 153 to 167 in ec2fd78
We're currently using Pip 20.2.4 since it's the last release before the new resolver became the default, and there are still several compatibility issues that make upgrading to newer pip painful (more in #1109). Thankfully the upcoming Pip 21.3 release (due within days, though we will want to wait for any dust to settle) resolves the most significant of those, so we should be good to update soon. For setuptools, we're currently using 47.1.1, since 47.2.0 and newer are affected by #1006. The long term fix for that is changing the way the build system works, so that the directory in which builds occur is the same as that which is used at runtime. However doing that breaks some other buildpacks, so is not a quick change (and that work has had to be put on hold). Re Python 3.10 specifically, do you have some examples of things that are failing currently using the above pip/setuptools versions? Our CI is currently passing, and the pip issue linked in the issue description was fixed in pip 19.3, so shouldn't affect Python 3.10 usage on Heroku. Many thanks :-) |
Yeah, I'm aware the buildpack doesn't use ensurepip, I just put the link as a reference for the recommended version. Here is an example of a backtrace, you have some others in bug reports I posted in the description.
|
Does your CI install any libraries that use python environment markers in requirements? if not that may explain why you didn't trigger the issue. |
Hi @edmorley, maybe you can run the tests on the pull request I send, it should trigger the issue. |
@sileht Hi! Sorry for the delay and thank you for the PR to try and reproduce. I have triggered CI on that PR, however it doesn't show the issue - the
Looking at the traceback in the earlier comment, I see it's originating via Could you open a support ticket (and give app access permission, and link to the ticket from here) so I can take a closer look at your app to try and work out a reduced testcase that demonstrates the issue? |
I was able to reproduce when using:
Example failure log:
Upgrading setuptools to I'll prioritise finding a shorter term fix for #1006 (compared to the ideal fix which is further out), so we can finally update setuptools. @sileht In the meantime, could you try adding |
I setup a tiny project that reproduces the issue, too, but it looks like you just beat me 😛 https://github.com/sileht/heroku-py3.10-bug Anyways, upgrading setuptools, workaround the issue. |
Thank you! I'll look into this more tomorrow :-) |
python_version
environment markers
Currently the build system performs builds in a different directory (`/tmp/build_<hash>`) to which the app will be run at runtime (`/app`). This means that any hardcoded paths in the slug must be rewritten by the buildpack, so the app still works after being moved. One such case of hardcoded paths, are the `.pth` and `.egg-link` files that are created in the `site-packages` directory by Pip/setuptools for editable package installs (aka develop mode). The most common way someone might use editable mode is via `-e <package specifier>` entries in their `requirements.txt` file. Until now, the Python buildpack rewrote paths inside these files during the compile itself, which meant the build-time paths were no longer present when subsequent buildpacks ran. This happened to work due to an interaction of legacy setuptools behaviour and a buildpack bug, but stops working in setuptools 47.2.0 or later - as described in #1006. Longer term we would like to stop building in one location and running the app from another, so that the path rewriting isn't required at all. However that change breaks some other buildpacks so requires a long-term transition plan. In the meantime, this change moves path rewriting to a `.profile.d/` script, so that it occurs at runtime, and so after all other buildpacks have run. Additional test coverage of editable packages was added previously in #1251 and #1253, and has confirmed that this new `profile.d/` script approach will prevent the issues in #1006 when setuptools is updated in a future PR. There is one subtle implication of moving this path rewriting, in that subsequent cached builds will no longer see the existing package as being already installed, so won't uninstall if before reinstalling it (as seen in the test log output change). However this is not believed to have any significant impact. Fixes #1006. (And so unblocks updating to the newer setuptools required for #1248.)
…#1252) Currently the build system performs builds in a different directory (`/tmp/build_<hash>`) to which the app will be run at runtime (`/app`). This means that any hardcoded paths in the slug must be rewritten by the buildpack, so the app still works after being moved. One such case of hardcoded paths, are the `.pth` and `.egg-link` files that are created in the `site-packages` directory by Pip/setuptools for editable package installs (aka develop mode). The most common way someone might use editable mode is via `-e <package specifier>` entries in their `requirements.txt` file. Until now, the Python buildpack rewrote paths inside these files during the compile itself, which meant the build-time paths were no longer present when subsequent buildpacks ran. This happened to work due to an interaction of legacy setuptools behaviour and a buildpack bug, but stops working in setuptools 47.2.0 or later - as described in #1006. Longer term we would like to stop building in one location and running the app from another, so that the path rewriting isn't required at all. However that change breaks some other buildpacks so requires a long-term transition plan. In the meantime, this change moves path rewriting to a `.profile.d/` script, so that it occurs at runtime, and so after all other buildpacks have run. Additional test coverage of editable packages was added previously in #1251 and #1253, and has confirmed that this new `profile.d/` script approach will prevent the issues in #1006 when setuptools is updated in a future PR. There is one subtle implication of moving this path rewriting, in that subsequent cached builds will no longer see the existing package as being already installed, so won't uninstall if before reinstalling it (as seen in the test log output change). However this is not believed to have any significant impact. Fixes #1006. (And so unblocks updating to the newer setuptools required for #1248.) GUS-W-7828034.
Updates: - setuptools from 47.1.1 to: - 50.3.2 for Python 3.5 - 57.5.0 for Python 3.6+ - wheel from 0.36.2 to 0.37.0. Of note, the newer setuptools is fully compatible with Python 3.10, thereby fixing #1248. Updating to newer setuptools was blocked on #1006, but that's now been fixed by #1252. The setuptools version hasn't been updated all the way to the latest (58.2.0), since v58 dropped support for 2to3, which caused breakage in a few packages, so I would rather hold off as long as possible (and there are no fixes that we need since then). Release notes: https://setuptools.pypa.io/en/latest/history.html#v57-5-0 https://wheel.readthedocs.io/en/stable/news.html Full changelogs: pypa/setuptools@v47.1.1...v57.5.0 pypa/wheel@0.36.2...0.37.0 Fixes #1248. GUS-W-10052807.
python_version
environment markerspython_version
environment markers
Updates: - setuptools from 47.1.1 to: - 50.3.2 for Python 3.5 - 57.5.0 for Python 3.6+ - wheel from 0.36.2 to 0.37.0. Of note, the newer setuptools is fully compatible with Python 3.10, thereby fixing #1248. Updating to newer setuptools was blocked on #1006, but that's now been fixed by #1252. The setuptools version hasn't been updated all the way to the latest (58.2.0), since v58 dropped support for 2to3, which caused breakage in a few packages, so I would rather hold off as long as possible (and there are no fixes that we need since then). Release notes: https://setuptools.pypa.io/en/latest/history.html#v57-5-0 https://wheel.readthedocs.io/en/stable/news.html Full changelogs: pypa/setuptools@v47.1.1...v57.5.0 pypa/wheel@0.36.2...0.37.0 Fixes #1248. GUS-W-10052807.
Awesome! Thanks @edmorley |
The newly added
python 3.10
doesn't work with pip 20 and setuptools 47old pip/setuptools version thinks python 3.10 is python 3.1:
Python 3.10 requires pip>=21 and setuptools>=52 (https://github.com/python/cpython/blob/3.10/Lib/ensurepip/__init__.py)
The text was updated successfully, but these errors were encountered: