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)
[![PyPI version](https://badge.fury.io/py/virtualenv-tools3.svg)](https://pypi-hypernode.com/pypi/virtualenv-tools3)

virtualenv-tools3
--------

virtualenv-tools3 is a fork of [the original
virtualenv-tools](https://github.com/fireteam/virtualenv-tools) (now
unmaintained) which adds support for Python 3, among other things. Full patch
details are below.

## 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.2.tar.gz (6.3 kB view details)

Uploaded Source

Built Distribution

virtualenv_tools3-2.0.2-py2.py3-none-any.whl (7.5 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

  • Download URL: virtualenv-tools3-2.0.2.tar.gz
  • Upload date:
  • Size: 6.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.1 requests-toolbelt/0.9.1 tqdm/4.30.0 CPython/3.5.2

File hashes

Hashes for virtualenv-tools3-2.0.2.tar.gz
Algorithm Hash digest
SHA256 a90936b268e60af174f209f4bad6783303e7529c5d3297ab93a6d6a7d9cfd4e6
MD5 f69356a694adea5e8ce1214e18a4595f
BLAKE2b-256 8e48eb9bbb898154458207941fac746b3e093609f87218a51db3f7d6dd76120b

See more details on using hashes here.

File details

Details for the file virtualenv_tools3-2.0.2-py2.py3-none-any.whl.

File metadata

  • Download URL: virtualenv_tools3-2.0.2-py2.py3-none-any.whl
  • Upload date:
  • Size: 7.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.1 requests-toolbelt/0.9.1 tqdm/4.30.0 CPython/3.5.2

File hashes

Hashes for virtualenv_tools3-2.0.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 02af2e12ad54c99bc9675e4c7c5493cee4e55700175eed673a963b62f89c57f6
MD5 8c5358595fd1f0e1aab234ca4c4a845f
BLAKE2b-256 2ace2edba8062cf2fee277ce0ea41b3a1c888034aaf23673740cde435c5d1b47

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