Skip to main content

A set of tools for virtualenv

Project description

[![Build Status](https://travis-ci.org/Yelp/virtualenv-tools.svg?branch=master)](https://travis-ci.org/Yelp/virtualenv-tools) [![Coverage Status](https://img.shields.io/coveralls/Yelp/virtualenv-tools.svg?branch=master)](https://coveralls.io/r/Yelp/virtualenv-tools)

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

## virtualenv-tools

This repository contains scripts we’re using at Fireteam for our 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-tools3-2.0.0.tar.gz (6.0 kB view details)

Uploaded Source

Built Distribution

virtualenv_tools3-2.0.0-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

Details for the file virtualenv-tools3-2.0.0.tar.gz.

File metadata

File hashes

Hashes for virtualenv-tools3-2.0.0.tar.gz
Algorithm Hash digest
SHA256 aae22dfb802327234cc0e3f7f05bda661873a06b0cc69a19d46e3935a56c7880
MD5 6adb5fc066bf471388bc9a7f8d074872
BLAKE2b-256 ff594aadd6aee97663ae310b08b2620726debe0e7c3df4c46a065d183a3a49d6

See more details on using hashes here.

File details

Details for the file virtualenv_tools3-2.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for virtualenv_tools3-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c2a36e38eafc763cea91ec2375068f601ec6e7a6d9255b79f6abf62d4d20fe9f
MD5 646266d11e83134b09cb7758738e70c3
BLAKE2b-256 2f5780ff4fccb8e453c373c3a2399d9b7164dc7240256cf5d4024ecf4c332ce2

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