Skip to main content

Reproducible tests, by default.

Project description

tox-constraints

Reproducible tests, with minimal configuration, by default

Benefits

This plugin is helpful because it

  • makes using pinned versions the default,
  • tells virtualenv to use the pinned versions,
  • facilitates gathering of dependencies, and
  • alerts you of the above pitfalls so that, hopefully, you do not have to learn it the hard way.

Motivation

The best way to improve reproducibility of tox without this plugin is to set PIP_CONSTRAINT using either

  1. setenv, or
  2. passenv.

This is good, it ensures that all packages installed with pip will use the constraints file[^1].

Setting PIP_CONSTRAINT does however not ensure that packages installed with other tools will use the constraints file. Notably tox creates environments using virtualenv, which seeds the environment with some version of pip, setuptools, and wheel. By default, a version that was bundled with the virtualenv is used, so while the behavior may be surprising it should be reproducible. The versions installed can be controlled[^2] using setenv or passenv to set

  • VIRTUALENV_PIP,
  • VIRTUALENV_SETUPTOOLS, and
  • VIRTUALENV_WHEEL.

Setting PIP_CONSTRAINT also does not ensure that all packages that will be installed are listed in the constraints file[^3]. pip-compile is a great tool to help both resolve all transient dependencies and assign a consistent set of versions. But it cannot pick up deps from tox.ini file or build-system.requires from pyproject.toml.

Limitations

Known limitations and problems include

  • deps from environments not on the envlist will not be gathered.
  • -l should be set when gathering dependencies to avoid actually running the environments.
  • The build-system.requires section from pyproject.toml must be manually reproduced in a text file to make it available to pip-compile. There is an open issue in pip-tools that, if implemented, would resolve this.

[^1]: Using the -c flag on the other hand does not ensure that build dependencies are pinned, see pip#8439. [^2]: Except when it does not. Something about it caching and upgrading packages locally causes it to occasionally ignore the specified versions. It can be hard to realize that this is happening and when it does the best course of action seems to be removing the cache at ~/.local/share/virtualenv/. [^3]: One could enable hash checking mode in which case pip would refuse to install any package for which it has not been given a hash. However, this creates new problems such as the package under test not having a hash. This package previously attempted to solve this use case but stopped since hash checking mode has been mostly broken in pip since the new resolver. :face_exhaling:

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tox-constraints-0.14.1.tar.gz (12.5 kB view details)

Uploaded Source

Built Distribution

tox_constraints-0.14.1-py3-none-any.whl (7.5 kB view details)

Uploaded Python 3

File details

Details for the file tox-constraints-0.14.1.tar.gz.

File metadata

  • Download URL: tox-constraints-0.14.1.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.13

File hashes

Hashes for tox-constraints-0.14.1.tar.gz
Algorithm Hash digest
SHA256 716def98703d1029debbb670908a8566ce60aa26cd04dcf39231608d23a347b6
MD5 50ed3f6de1a8997161f8fc8dfe0bd794
BLAKE2b-256 45f8e19cd592bc84ab56b36f986a9ac6c864541ff4c07bd260502c1842e0e572

See more details on using hashes here.

File details

Details for the file tox_constraints-0.14.1-py3-none-any.whl.

File metadata

File hashes

Hashes for tox_constraints-0.14.1-py3-none-any.whl
Algorithm Hash digest
SHA256 65563a92aa74762c8b48dab0a75c77a5a5bd19c6d989d55abd6532277bcbdf49
MD5 095bbb14503c36f3eb331f9d98d73172
BLAKE2b-256 3db9daf9fa7beff4dae7cce18d83633c9b6888ec726593385cdf7ac474cb915b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page