crwood / tox-venv

Use python3 venvs for python3 test environments

Repository from Github https://github.comcrwood/tox-venvRepository from Github https://github.comcrwood/tox-venv

tox-venv

https://travis-ci.org/tox-dev/tox-venv.svg?branch=master https://ci.appveyor.com/api/projects/status/fak35ur9yibmn0ly?svg=true

What is tox-venv?

tox-venv is a plugin that uses Python 3's builtin venv module for creating test environments, instead of creating them with the virtualenv package. For Python versions that do not include venv (namely 3.2 and earlier), this package does nothing and reverts to tox's default implementation.

Why use tox-venv?

virtualenv is historically Python 2/3 compatible, however to achieve this, it ships some files that are pinned at their Python 2.6 version, such as the site module (see: pypa/virtualenv#355). This has a few effects:

  • Builds using the -Werror option fail, as the deprecations are raised before the test suite can run.
  • Users cannot take advantage of newer features of the site module in their test environments.
  • Eventually, these deprecations will become exceptions in future versions of Python.

By using the builtin venv module, these issues can be avoided.

Compatibility

tox-venv is compatible with both Python 2 and 3, however it only creates test environments in Python 3.3 and later. Python 3.3 environments are only partially compatible, as not all options (such as --copies/--symlinks) were supported. Environments for Python 3.4 and later are fully compatible.

Release process

  • Update changelog
  • Update package version in setup.py
  • Create git tag for version
  • Upload release to PyPI
$ pip install -U setuptools wheel
$ rm -rf dist/ build/
$ python setup.py bdist_wheel upload

About

Use python3 venvs for python3 test environments

License:BSD 3-Clause "New" or "Revised" License


Languages

Language:Python 100.0%