Skip to main content

A set of tools for virtualenv

Project description

Build Status Coverage Status PyPI version

virtualenv-tools4

virtualenv-tools4 is a fork of virtualenv-tools3 (now unmaintained) which adds support for Python 3.12, among other things. Full patch details are below.

virtualenv-tool4 patch

  • Add Python 3.12 & 3.13 support.

virtualenv-tool3 (yelp) patches

yelp4

  • Add python3 support
  • Drop python2.6 support
  • 100% test coverage
  • Removes $VENV/local instead of fixing up symlinks
  • Removed --reinitialize, instead run virtualenv $VENV -p $PYTHON
  • Rewrite .pth files to relative paths

yelp3

  • default output much more concise, added a --verbose option
  • improved fault tolerance, in the case of:
    • corrupt pyc files
    • broken symlinks
    • unexpected directories
  • no-changes-needed is a success case (idempotency exits 0)

yelp1

  • --update now works more generally and reliably (e.g. virtualenv --python=python2.7)

How-to

This repository contains scripts for deployment of Python code. We're using them in combination with salt to build code on one server on a self contained virtualenv and then move that over to the destination servers to run.

Why not virtualenv --relocatable?

For starters: because it does not work. relocatable is very limited in what it does and it works at runtime instead of making the whole thing actually move to the new location. We ran into a ton of issues with it and it is currently in the process of being phased out.

Why would I want to use it?

The main reason you want to use this is for build caching. You have one folder where one virtualenv exists, you install the latest version of your codebase and all extensions in there, then you can make the virtualenv relocate to a target location, put it into a tarball, distribute it to all servers and done!

Example flow:

First time: create the build cache

$ mkdir /tmp/build-cache
$ virtualenv --distribute /tmp/build-cache

Now every time you build:

$ . /tmp/build-cache/bin/activate
$ pip install YourApplication

Build done, package up and copy to whatever location you want to have it.

Once unpacked on the target server, use the virtualenv tools to update the paths and make the virtualenv magically work in the new location. For instance we deploy things to a path with the hash of the commit in:

$ virtualenv-tools --update-path /srv/your-application/<hash>

Compile once, deploy whereever. Virtualenvs are completely self contained. In order to switch the current version all you need to do is to relink the builds.

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

virtualenv_tools4-3.1.2.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

virtualenv_tools4-3.1.2-py2.py3-none-any.whl (7.8 kB view details)

Uploaded Python 2Python 3

File details

Details for the file virtualenv_tools4-3.1.2.tar.gz.

File metadata

  • Download URL: virtualenv_tools4-3.1.2.tar.gz
  • Upload date:
  • Size: 7.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.9.6

File hashes

Hashes for virtualenv_tools4-3.1.2.tar.gz
Algorithm Hash digest
SHA256 51d47a5ef9b55db40d901c42cc7ddcbcc625809cba2b42fab02eb6727de61e90
MD5 93eb9aae9a662c58ab79814be8313b46
BLAKE2b-256 844dc9cc71613f79908c4aa248b0b182a21549e5fe028c99b48c99cc64a1b00c

See more details on using hashes here.

File details

Details for the file virtualenv_tools4-3.1.2-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for virtualenv_tools4-3.1.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 3da8d52e8566038fd4df5d71993ec3433431045abe260024248994e30e492b03
MD5 dd154d4978be0c9350f2226154721e2e
BLAKE2b-256 9d9405333624d4eb2e1cfdbad772071f50eaf935500c4996d95d23aaa29b7cb3

See more details on using hashes here.

Supported by

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