Skip to content

A utility for installing extremal versions of dependencies for more robust testing

License

Notifications You must be signed in to change notification settings

IBM/extremal-python-dependencies

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Release Python License Downloads Tests Coverage

extremal-python-dependencies

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).

How to use

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.

Caveats

  • 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.

Similar tools

About

A utility for installing extremal versions of dependencies for more robust testing

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages