A utility for installing extremal versions of dependencies for more robust testing.
Install extremal versions of package dependencies for more robust continuous integration testing, given a package that specifies its dependencies in a pyproject.toml
file.
For instance, one might use this utility to install the minimum supported version of each dependency before a CI run. Ensuring all tests then pass adds confidence that the code is indeed compatible with the full range of package versions it claims to be compatible with, helping to prevent users from encountering broken installs.
Another way to use this tool is to install development versions of certain packages.
This utility works with dependencies specified in a pyproject.toml
file. It modifies pyproject.toml
, either by sending the transformed version to stdout (the default) or by modifying in place (which may be useful in CI scripts).
The following snippet modifies pyproject.toml
in place to test with the minimum supported version of each direct dependency, under the minimum supported tox version (as specified by minversion
in tox.ini
).
pip install "tox==$(extremal-python-dependencies get-tox-minversion)"
extremal-python-dependencies pin-dependencies-to-minimum --inplace
tox -epy
The following snippet modifies pyproject.toml
in place to test with the development version of one or more dependencies:
extremal-python-dependencies pin-dependencies \
"qiskit @ git+https://github.com/Qiskit/qiskit.git" \
"qiskit-ibm-runtime @ git+https://github.com/Qiskit/qiskit-ibm-runtime.git" \
--inplace
tox -epy
Each of the above patterns can be used in a CI script.
- The minimum versions of all optional dependencies installed simultaneously must be compatible with each other.
- This tool does not set the minimum supported version of transitive dependencies.
- requirements-builder (builds requirements from a
setup.py
file instead of apyproject.toml
file)