setuptools downloads and builds a correct version of a dependency in the install-to-egg step, but then adds a different version not satisfying the requirement to easy_install.pth #1450
Labels
No Label
0.2.0
0.3.0
0.4.0
0.5.0
0.5.1
0.6.0
0.6.1
0.7.0
0.8.0
0.9.0
1.0.0
1.1.0
1.10.0
1.10.1
1.10.2
1.10a2
1.11.0
1.12.0
1.12.1
1.13.0
1.14.0
1.15.0
1.15.1
1.2.0
1.3.0
1.4.1
1.5.0
1.6.0
1.6.1
1.7.0
1.7.1
1.7β
1.8.0
1.8.1
1.8.2
1.8.3
1.8β
1.9.0
1.9.0-s3branch
1.9.0a1
1.9.0a2
1.9.0b1
1.9.1
1.9.2
1.9.2a1
LeastAuthority.com automation
blocker
cannot reproduce
cloud-branch
code
code-dirnodes
code-encoding
code-frontend
code-frontend-cli
code-frontend-ftp-sftp
code-frontend-magic-folder
code-frontend-web
code-mutable
code-network
code-nodeadmin
code-peerselection
code-storage
contrib
critical
defect
dev-infrastructure
documentation
duplicate
enhancement
fixed
invalid
major
minor
n/a
normal
operational
packaging
somebody else's problem
supercritical
task
trivial
unknown
was already fixed
website
wontfix
worksforme
No Milestone
No Assignees
3 Participants
Notifications
Due Date
No due date set.
Reference: tahoe-lafs/trac-2024-07-25#1450
Loading…
Reference in New Issue
Block a user
No description provided.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
In the attached install-to-egg build on the 'Eugen lenny' buildslave, the requirement for Twisted is >= 10.1.0.
setuptools downloads and builds Twisted 10.2:
but then it adds Twisted 8.1 to easy-install.pth, resulting in a failed Tahoe build:
Since we're installing to an egg rather than globally, there's no good reason why that shouldn't work even if Twisted 8.1 is installed single-version-externally-managed. But if that's not supported for some reason, it's still incorrect to build 10.2 and then fail with a misleading error message.
Attachment Eugen-lenny-amd64-build-850-install-to-egg.txt (12931 bytes) added
Copy of http://tahoe-lafs.org/buildbot/builders/Eugen%20lenny-amd64/builds/850/steps/install-to-egg/logs/stdio/text
According to http://tahoe-lafs.org/buildbot/builders/Eugen%20lenny-amd64/builds/860/steps/show-tool-versions/logs/stdio , that is setuptools-0.6c8 doing that. That is a very old version. Perhaps this is one of the bugs that has been fixed between setuptools-0.6c8 and the current setuptools-0.6c11 or distribute-0.6.19. We don't see the same bug on other builders, that have newer version of setuptools installed.
I'll ask Eugen in email if he could upgrade the setuptools on there. If not, we could try to reproduce this by installing setuptools-0.6c8, reproducing this failure, then upgrading setuptools to 0.6c11 or distribute-0.6.19 and seeing if the failure goes away.
Eugen upgraded to setuptools-0.6c12dev-!r88846 (show-tool-versions), and this problem went away: test-from-egg stdio.
Now there is another problem in the subsequent test-from-egg step. The
sys.path
has/usr/lib/python2.5/site-packages
earlier than/home/tahoebuildslave/tahoebuildslave/Eugen lenny-amd64/build/egginstalldir/Twisted-11.0.0-py2.5-linux-x86_64.egg
, so Twisted 8.1 (which is in/usr/lib/python2.5/site-packages
gets imported and then our [check_all_requirements()]source:trunk/src/allmydata/init.py?annotate=blame&rev=5079#L346 function correctly objects that we imported a disallowed version.I don't know why
/usr/lib/python2.5/site-packages
is earlier than the Twisted egg. Setuptools normally puts all .egg's earlier on thesys.path
earlier than all non-egg entries (which is the cause of the most widely hated setuptools issue: setuptools issue #53 -- respect the PYTHONPATH).Replying to zooko:
setuptools does not always put .egg entries earlier than non-egg entries. If a non-egg is needed to satisfy a dependency and it is in a shared package directory (such as a
site-packages
directory, either the global one or one in a virtualenv), then other packages from that directory can end up being found before the ones required by Tahoe, even when setuptools thinks theose requirements have been correctly satisfied (see /tahoe-lafs/trac-2024-07-25/issues/6308#comment:6). This behaviour is nondeterministic.We no longer use eggs, and pip installs our dependencies in an unpacked form. I think we can close this now.