remove the version-checking code from __init__.py
#2749
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
2 Participants
Notifications
Due Date
No due date set.
Reference: tahoe-lafs/trac-2024-07-25#2749
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?
I think it's time we removed the (large!) chunk of code in
src/allmydata/*init*.py
that measures and checks versions of our dependencies at startup.I'd like to see a small subset of this code move into a utility function (maybe
src/allmydata/version_checks.py
): just enough to pull version strings for our known dependencies. This would support the extended form oftahoe --version
. I think this code should not know what the setup.pyinstall_requires=
is, nor should it make any attempt to pass judgement upon whether the versions it finds are good enough.Then I'd like to delete everything else from
*init*.py
except for the Versioneer setup clause (#2748).pip
now has responsibility for ensuring that the target virtualenv has the right code at install time, and (I think) the entrypoint script has that responsibility at runtime. The code in*init*.py
duplicates this, plus it frequently misfires, emitting a traceback-like warning that many users mistake for a fatal exception.This would let us move the list of
install_requires=
intosetup.py
where it belongs, rather than the current arrangement where it lives in src/ but getsexecfile()
ed bysetup.py
(which is causing problems with py3-based tox runs, #2747).One counter-argument I can think of: you
pip install --editable .
from a git checkout into a virtualenv, work for a while and everything is fine, then you do an update and get asetup.py
that bumps the dependency on something. If you don't update your virtualenv every once in a while (pip list -o
,pip install -U
on anything it says is out-of-date), then eventually Tahoe will want more than what you've got.I think the entrypoint script is supposed to do this checking, but you'd need to at least re-run
setup.py egg_info
to update the list of dependencies that it looks at. Having something at runtime would guard against this, and the shared_auto_deps.py
is the cleanest way to accomplish that.But I still think our
*init*.py
is too big, and I don't like having all that code run at import, and I don't think the git-update case is worth protecting against.#2873 brought up a case where those checks do not know as much about version strings as the real setuptools does, blocking us from changing our dependency on
twistedtls
totwistedtls,conch
because it makescheck_all_requirements()
crash.In 15af2bb/trunk:
YAY!!