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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file virtualenv-tools3-2.0.0.tar.gz
.
File metadata
- Download URL: virtualenv-tools3-2.0.0.tar.gz
- Upload date:
- Size: 6.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | aae22dfb802327234cc0e3f7f05bda661873a06b0cc69a19d46e3935a56c7880 |
|
MD5 | 6adb5fc066bf471388bc9a7f8d074872 |
|
BLAKE2b-256 | ff594aadd6aee97663ae310b08b2620726debe0e7c3df4c46a065d183a3a49d6 |
File details
Details for the file virtualenv_tools3-2.0.0-py3-none-any.whl
.
File metadata
- Download URL: virtualenv_tools3-2.0.0-py3-none-any.whl
- Upload date:
- Size: 8.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c2a36e38eafc763cea91ec2375068f601ec6e7a6d9255b79f6abf62d4d20fe9f |
|
MD5 | 646266d11e83134b09cb7758738e70c3 |
|
BLAKE2b-256 | 2f5780ff4fccb8e453c373c3a2399d9b7164dc7240256cf5d4024ecf4c332ce2 |