mirror of
https://github.com/pyenv/pyenv-virtualenv.git
synced 2025-11-09 12:03:55 -05:00
Compare commits
1 Commits
v1.1.0
...
check-usag
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
56c232610a |
@@ -1,4 +1,3 @@
|
|||||||
sudo: false
|
|
||||||
install: git clone https://github.com/sstephenson/bats.git
|
install: git clone https://github.com/sstephenson/bats.git
|
||||||
script: bats/bin/bats --tap test
|
script: bats/bin/bats --tap test
|
||||||
language: c
|
language: c
|
||||||
|
|||||||
179
CHANGELOG.md
179
CHANGELOG.md
@@ -1,179 +0,0 @@
|
|||||||
## Version History
|
|
||||||
|
|
||||||
#### 1.1.0
|
|
||||||
|
|
||||||
* fish: use "set -gx" instead of "setenv" (#215, #216, #217, #218)
|
|
||||||
|
|
||||||
#### 1.0.0
|
|
||||||
|
|
||||||
* Use similar versioning scheme as pyenv; YYYYMMDD -> X.Y.Z
|
|
||||||
|
|
||||||
#### 20160716
|
|
||||||
|
|
||||||
* Suppress activate/deactivate messages by default (#169, #170, #171)
|
|
||||||
* Source conda package activate/deactivat scripts if exist (#173)
|
|
||||||
* Use `source` in favor of `.` for `fish` (#175)
|
|
||||||
* Use `python -m venv` instead of `pyvenv` due to deprecation of `pyvenv` after 3.6 (#184, #185)
|
|
||||||
|
|
||||||
#### 20160315
|
|
||||||
|
|
||||||
* Evaluate `${PATH}` when outputted code is eval'd. (#154)
|
|
||||||
* Set proper `CONDA_DEFAULT_ENV` for shorter name (#160)
|
|
||||||
|
|
||||||
#### 20160202
|
|
||||||
|
|
||||||
* Install virtualenv 13.1.2 for CPython/Stackless 3.2.x (yyuu/pyenv#531)
|
|
||||||
|
|
||||||
#### 20160112
|
|
||||||
|
|
||||||
* Fix problem with `virtualenv` to look up executables from source version with `--system-site-packages` (#62)
|
|
||||||
|
|
||||||
#### 20151229
|
|
||||||
|
|
||||||
* Fix `deactivate` error on `fish` (#136)
|
|
||||||
|
|
||||||
#### 20151222
|
|
||||||
|
|
||||||
* Improved interoperability with Anaconda/Miniconda (#103, #106, #107, #108)
|
|
||||||
* Create `virtualenv` inside `envs` directory of source version, like Anaconda/Miniconda (#103, #107)
|
|
||||||
* Rewrite `pyenv activate` and `pyenv deactivate` without using scripts provided by virtualenv and conda (#51, #69, #103, #104, #121)
|
|
||||||
* Improve the `pyenv activate` behaviour on multipe versions (#105, #111)
|
|
||||||
* Reject creating a virtualenv named `system` (yyuu/pyenv#475)
|
|
||||||
* Add `--skip-aliases` to `pyenv virtualenvs` (#120)
|
|
||||||
* Stop showing `version not installed` warning messages in precmd (#49)
|
|
||||||
|
|
||||||
#### 20151103
|
|
||||||
|
|
||||||
* Passing return value from executed command. (#100)
|
|
||||||
* Add workaround for commands installed in a virtual environment created by `pyvenv` (#62)
|
|
||||||
* init: zsh: prepend hook to `precmd_functions` (#101)
|
|
||||||
|
|
||||||
#### 20151006
|
|
||||||
|
|
||||||
* Ignore user's site-packages on ensurepip/get-pip (#89)
|
|
||||||
* Find `python-config` from source version if current version is a virtualenv
|
|
||||||
* Fix pyenv-virtualenv-init script for fish where command was in string and not being evaluated (#98)
|
|
||||||
* Add foolproof for `-p` argument. (yyuu/pyenv#98)
|
|
||||||
|
|
||||||
#### 20150719
|
|
||||||
|
|
||||||
* Add support for `conda` environments created by Anaconda/Miniconda (#91)
|
|
||||||
* Look up commands for original version as well if the environment is created with `--system-site-packages` (#62)
|
|
||||||
* Add error message if the source version is not installed (#83)
|
|
||||||
|
|
||||||
#### 20150526
|
|
||||||
|
|
||||||
* Use `typeset -g` with `precmd_functions` (#75)
|
|
||||||
* activate: display setup instructions only with `PYENV_VIRTUALENV_INIT=0` (#78)
|
|
||||||
* Ignore failure of pyenv activate (#68)
|
|
||||||
|
|
||||||
#### 20150119
|
|
||||||
|
|
||||||
* Ignore errors from `pyenv-version-name` since it might fail if there is configuration error (yyuu/pyenv#291)
|
|
||||||
* The _shell_ version set in `activate` should be unset in `deactivate` (#61)
|
|
||||||
* Anaconda has `activate` script nevertheless it is not a virtual environment (#65)
|
|
||||||
|
|
||||||
#### 20141106
|
|
||||||
|
|
||||||
* Stop creating after `ensurepip` since it has done by `ensurepip` itself
|
|
||||||
* Suppress some useless warnings from `pyenv virtualenv-init`
|
|
||||||
|
|
||||||
#### 20141012
|
|
||||||
|
|
||||||
* Fix warnings from `shellcheck` to improve support for POSIX sh (#40)
|
|
||||||
* Do not allow whitespace in `VIRTUALENV_NAME` (#44)
|
|
||||||
* Should not persist `PYENV_DEACTIVATE` after automatic deactivation (#47, #48)
|
|
||||||
|
|
||||||
#### 20140705
|
|
||||||
|
|
||||||
* Display information on auto-(de)?activation
|
|
||||||
* Support manual (de)?activation with auto-activation enabled (#32, #34)
|
|
||||||
* Exit as error when (de)?activation failed
|
|
||||||
* Use https://bootstrap.pypa.io/ to install setuptools and pip
|
|
||||||
* Create backup of original virtualenv within `$(pyenv root)/versions` when `--upgrade`
|
|
||||||
|
|
||||||
#### 20140615
|
|
||||||
|
|
||||||
* Fix incompatibility issue of `pyenv activate` and `pyenv deactivate` (#26)
|
|
||||||
* Workaround for the issue with pyenv-which-ext (#26)
|
|
||||||
|
|
||||||
#### 20140614
|
|
||||||
|
|
||||||
* Add `pyenv virtualenv-init` to enable auto-activation feature (#24)
|
|
||||||
* Create symlinks for executables with version suffix (yyuu/pyenv#182)
|
|
||||||
|
|
||||||
#### 20140602
|
|
||||||
|
|
||||||
* Use new style GH raw url to avoid redirects (raw.github.com -> raw.githubusercontent.com)
|
|
||||||
* Repaired virtualenv activation and deactivation for the fish shell (#23)
|
|
||||||
|
|
||||||
#### 20140421
|
|
||||||
|
|
||||||
* Display error if `pyenv activate` was invoked as a command
|
|
||||||
* Fix completion of `pyenv activate` (#15)
|
|
||||||
* Use `virtualenv` instead of `pyvenv` if `-p` has given (yyuu/pyenv#158)
|
|
||||||
|
|
||||||
#### 20140123
|
|
||||||
|
|
||||||
* Add `activate` and `deactivate` to make `pyenv-virtualenv` work with [jedi](https://github.com/davidhalter/jedi) (#9)
|
|
||||||
* Use `ensurepip` to install `pip` if it is available
|
|
||||||
* Unset `PIP_REQUIRE_VENV` to avoid problem on the installation of `virtualenv` (#10)
|
|
||||||
* Add tests
|
|
||||||
|
|
||||||
#### 20140110.1
|
|
||||||
|
|
||||||
* Fix install script
|
|
||||||
|
|
||||||
#### 20140110
|
|
||||||
|
|
||||||
* Support environment variables of `EZ_SETUP` and `GET_PIP`.
|
|
||||||
* Support a short option `-p` of `virtualenv`.
|
|
||||||
|
|
||||||
#### 20131216
|
|
||||||
|
|
||||||
* Use latest release of setuptools and pip if the version not given via environment variables.
|
|
||||||
|
|
||||||
#### 20130622
|
|
||||||
|
|
||||||
* Removed bundled `virtualenv.py` script. Now pyenv-virtualenv installs `virtualenv` package into source version and then use it.
|
|
||||||
* On Python 3.3+, use `pyvenv` as virtualenv command if `virtualenv` is not available.
|
|
||||||
* Install setuptools and pip into environments created by `pyvenv`.
|
|
||||||
|
|
||||||
#### 20130614
|
|
||||||
|
|
||||||
* Add `pyenv virtualenvs` to list all virtualenv versions.
|
|
||||||
* *EXPERIMENTAL*: Add `--upgrade` option to re-create virtualenv with migrating packages
|
|
||||||
|
|
||||||
#### 20130527
|
|
||||||
|
|
||||||
* Remove `python-virtualenv` which was no longer used.
|
|
||||||
* Change the installation path of the `virtualenv.py` script. (`./libexec` -> `./libexec/pyenv-virtualenv/${VIRTUALENV_VERSION}`)
|
|
||||||
* Download `virtualenv.py` if desired version has not been installed.
|
|
||||||
|
|
||||||
#### 20130507
|
|
||||||
|
|
||||||
* Display virtualenv information in `--help` and `--version`
|
|
||||||
* Update virtualenv version; 1.8.4 -> 1.9.1
|
|
||||||
|
|
||||||
#### 20130307
|
|
||||||
|
|
||||||
* Rename the project; `s/python-virtualenv/pyenv-virtualenv/g`
|
|
||||||
* The `pyenv-virtualenv` script is not depending on `python-virtualenv` now.
|
|
||||||
`python-virtualenv` will left for compatibility and will not continue for future releases.
|
|
||||||
* Update virtualenv version; 1.8.2 -> 1.8.4
|
|
||||||
|
|
||||||
#### 20130218
|
|
||||||
|
|
||||||
* Add pyenv 0.2.x (rbenv 0.4.x) style help messages.
|
|
||||||
|
|
||||||
#### 20121023
|
|
||||||
|
|
||||||
* Create virtualenv with exact name of python executables.
|
|
||||||
* Changed command-line options of python-virtualenv.
|
|
||||||
First argument should be a path to the python executable.
|
|
||||||
* Add install script.
|
|
||||||
|
|
||||||
#### 20120927
|
|
||||||
|
|
||||||
* Initial public release.
|
|
||||||
|
|
||||||
2
LICENSE
2
LICENSE
@@ -1,4 +1,4 @@
|
|||||||
Copyright (c) 2015 Yamashita, Yuu
|
Copyright (c) 2013 Yamashita, Yuu
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
a copy of this software and associated documentation files (the
|
a copy of this software and associated documentation files (the
|
||||||
|
|||||||
285
README.md
285
README.md
@@ -1,238 +1,211 @@
|
|||||||
# pyenv-virtualenv
|
# pyenv-virtualenv
|
||||||
|
|
||||||
[](https://gitter.im/yyuu/pyenv-virtualenv?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
[](https://travis-ci.org/yyuu/pyenv-virtualenv)
|
||||||
|
|
||||||
[](https://travis-ci.org/pyenv/pyenv-virtualenv)
|
pyenv-virtualenv is a [pyenv](https://github.com/yyuu/pyenv) plugin
|
||||||
|
that provides a `pyenv virtualenv` command to create virtualenv for Python
|
||||||
pyenv-virtualenv is a [pyenv](https://github.com/pyenv/pyenv) plugin
|
on UNIX-like systems.
|
||||||
that provides features to manage virtualenvs and conda environments
|
|
||||||
for Python on UNIX-like systems.
|
|
||||||
|
|
||||||
(NOTICE: If you are an existing user of [virtualenvwrapper](http://pypi.python.org/pypi/virtualenvwrapper)
|
(NOTICE: If you are an existing user of [virtualenvwrapper](http://pypi.python.org/pypi/virtualenvwrapper)
|
||||||
and you love it, [pyenv-virtualenvwrapper](https://github.com/pyenv/pyenv-virtualenvwrapper) may help you
|
and you love it, [pyenv-virtualenvwrapper](https://github.com/yyuu/pyenv-virtualenvwrapper) may help you
|
||||||
(additionally) to manage your virtualenvs.)
|
to manage your virtualenvs.)
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
|
|
||||||
### Installing as a pyenv plugin
|
### Installing as a pyenv plugin
|
||||||
|
|
||||||
This will install the latest development version of pyenv-virtualenv into
|
Installing pyenv-virtualenv as a pyenv plugin will give you access to the
|
||||||
the `$(pyenv root)/plugins/pyenv-virtualenv` directory.
|
`pyenv virtualenv` command.
|
||||||
|
|
||||||
**Important note:** If you installed pyenv into a non-standard directory, make
|
$ git clone https://github.com/yyuu/pyenv-virtualenv.git ~/.pyenv/plugins/pyenv-virtualenv
|
||||||
sure that you clone this repo into the 'plugins' directory of wherever you
|
$ exec "$SHELL"
|
||||||
installed into.
|
|
||||||
|
This will install the latest development version of pyenv-virtualenv into
|
||||||
|
the `~/.pyenv/plugins/pyenv-virtualenv` directory.
|
||||||
|
**Important note:** If you installed pyenv into a non-standard directory, make sure that you clone this
|
||||||
|
repo into the 'plugins' directory of wherever you installed into.
|
||||||
|
|
||||||
From inside that directory you can:
|
From inside that directory you can:
|
||||||
- Check out a specific release tag.
|
- Check out a specific release tag.
|
||||||
- Get the latest development release by running `git pull` to download the
|
- Get the latest development release by running `git pull` to download the latest changes.
|
||||||
latest changes.
|
|
||||||
|
|
||||||
1. **Check out pyenv-virtualenv into plugin directory**
|
|
||||||
|
|
||||||
```sh
|
|
||||||
$ git clone https://github.com/pyenv/pyenv-virtualenv.git $(pyenv root)/plugins/pyenv-virtualenv
|
|
||||||
```
|
|
||||||
|
|
||||||
2. (OPTIONAL) **Add `pyenv virtualenv-init` to your shell** to enable auto-activation of virtualenvs. This is entirely optional but pretty useful. See "Activate virtualenv" below.
|
|
||||||
|
|
||||||
```sh
|
|
||||||
$ echo 'eval "$(pyenv virtualenv-init -)"' >> ~/.bash_profile
|
|
||||||
```
|
|
||||||
|
|
||||||
**Zsh note**: Modify your `~/.zshenv` file instead of `~/.bash_profile`.
|
|
||||||
**Pyenv note**: You may also need to add `eval "$(pyenv init -)"` to your profile if you haven't done so already.
|
|
||||||
|
|
||||||
3. **Restart your shell to enable pyenv-virtualenv**
|
|
||||||
|
|
||||||
```sh
|
|
||||||
$ exec "$SHELL"
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
### Installing with Homebrew (for OS X users)
|
### Installing with Homebrew (for OS X users)
|
||||||
|
|
||||||
Mac OS X users can install pyenv-virtualenv with the
|
Mac OS X users can install pyenv-virtualenv with the
|
||||||
[Homebrew](http://brew.sh) package manager.
|
[Homebrew](http://brew.sh) package manager. This
|
||||||
This will give you access to the `pyenv-virtualenv` command. If you have pyenv
|
will give you access to the `pyenv-virtualenv` command. If you have pyenv
|
||||||
installed, you will also be able to use the `pyenv virtualenv` command.
|
installed, you will also be able to use the `pyenv virtualenv` command.
|
||||||
|
|
||||||
*This is the recommended method of installation if you installed pyenv
|
*This is recommended method of installation if you installed pyenv
|
||||||
with Homebrew.*
|
with Homebrew.*
|
||||||
|
|
||||||
```sh
|
brew install pyenv-virtualenv
|
||||||
$ brew install pyenv-virtualenv
|
|
||||||
```
|
|
||||||
|
|
||||||
Or, if you would like to install the latest development release:
|
Or, if you would like to install the latest development release:
|
||||||
|
|
||||||
```sh
|
brew install --HEAD pyenv-virtualenv
|
||||||
$ brew install --HEAD pyenv-virtualenv
|
|
||||||
```
|
|
||||||
|
|
||||||
After installation, you'll still need to add
|
|
||||||
```sh
|
|
||||||
eval "$(pyenv init -)"
|
|
||||||
eval "$(pyenv virtualenv-init -)"
|
|
||||||
```
|
|
||||||
to your profile (as stated in the caveats). You'll only ever have to do this once.
|
|
||||||
|
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
### Using `pyenv virtualenv` with pyenv
|
### Using `pyenv virtualenv` with pyenv
|
||||||
|
|
||||||
To create a virtualenv for the Python version used with pyenv, run
|
To create a virtualenv for the Python version use with pyenv, run
|
||||||
`pyenv virtualenv`, specifying the Python version you want and the name
|
`pyenv virtualenv`, specifying the Python version you want and the name
|
||||||
of the virtualenv directory. For example,
|
of the virtualenv directory. For example,
|
||||||
|
|
||||||
```sh
|
$ pyenv virtualenv 2.7.6 my-virtual-env-2.7.6
|
||||||
$ pyenv virtualenv 2.7.10 my-virtual-env-2.7.10
|
|
||||||
```
|
|
||||||
|
|
||||||
will create a virtualenv based on Python 2.7.10 under `$(pyenv root)/versions` in a
|
will create a virtualenv based on Python 2.7.6
|
||||||
folder called `my-virtual-env-2.7.10`.
|
under `~/.pyenv/versions` in a folder called `my-virtual-env-2.7.6`.
|
||||||
|
|
||||||
|
|
||||||
### Create virtualenv from current version
|
### Create virtualenv from current version
|
||||||
|
|
||||||
If there is only one argument given to `pyenv virtualenv`, the virtualenv will
|
If there is only one argument is given to `pyenv virtualenv`,
|
||||||
be created with the given name based on the current pyenv Python version.
|
virtualenv will be created with given name based on current
|
||||||
|
version.
|
||||||
|
|
||||||
```sh
|
|
||||||
$ pyenv version
|
$ pyenv version
|
||||||
3.4.3 (set by /home/yyuu/.pyenv/version)
|
3.3.3 (set by /home/yyuu/.pyenv/version)
|
||||||
$ pyenv virtualenv venv34
|
$ pyenv virtualenv venv33
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
### List existing virtualenvs
|
### List existing virtualenvs
|
||||||
|
|
||||||
`pyenv virtualenvs` shows you the list of existing virtualenvs and `conda` environments.
|
`pyenv virtualenvs` shows you the list of existing virtualenvs.
|
||||||
|
|
||||||
```sh
|
$ pyenv shell venv27
|
||||||
$ pyenv shell venv34
|
|
||||||
$ pyenv virtualenvs
|
$ pyenv virtualenvs
|
||||||
miniconda3-3.9.1 (created from /home/yyuu/.pyenv/versions/miniconda3-3.9.1)
|
* venv27 (created from /home/yyuu/.pyenv/versions/2.7.6)
|
||||||
miniconda3-3.9.1/envs/myenv (created from /home/yyuu/.pyenv/versions/miniconda3-3.9.1)
|
venv33 (created from /home/yyuu/.pyenv/versions/3.3.3)
|
||||||
2.7.10/envs/my-virtual-env-2.7.10 (created from /home/yyuu/.pyenv/versions/2.7.10)
|
|
||||||
3.4.3/envs/venv34 (created from /home/yyuu/.pyenv/versions/3.4.3)
|
|
||||||
my-virtual-env-2.7.10 (created from /home/yyuu/.pyenv/versions/2.7.10)
|
|
||||||
* venv34 (created from /home/yyuu/.pyenv/versions/3.4.3)
|
|
||||||
```
|
|
||||||
|
|
||||||
There are two entries for each virtualenv, and the shorter one is just a symlink.
|
|
||||||
|
|
||||||
|
|
||||||
### Activate virtualenv
|
### Activate virtualenv
|
||||||
|
|
||||||
Some external tools (e.g. [jedi](https://github.com/davidhalter/jedi)) might
|
Some external tools (e.g. [jedi](https://github.com/davidhalter/jedi)) might require you to `activate` the virtualenv.
|
||||||
require you to `activate` the virtualenv and `conda` environments.
|
`pyenv activate` lets you to activate the virtualenv into your shell.
|
||||||
|
|
||||||
If `eval "$(pyenv virtualenv-init -)"` is configured in your shell, `pyenv-virtualenv` will automatically activate/deactivate virtualenvs on entering/leaving directories which contain a `.python-version` file that contains the name of a valid virtual environment as shown in the output of `pyenv virtualenvs` (e.g., `venv34` or `3.4.3/envs/venv34` in example above) . `.python-version` files are used by pyenv to denote local Python versions and can be created and deleted with the [`pyenv local`](https://github.com/pyenv/pyenv/blob/master/COMMANDS.md#pyenv-local) command.
|
$ pyenv activate venv27
|
||||||
|
|
||||||
You can also activate and deactivate a pyenv virtualenv manually:
|
`pyenv activate` acts almost like following commands.
|
||||||
|
The activate'd virtualenv will be persisted as _shell_ version.
|
||||||
|
|
||||||
```sh
|
$ pyenv shell venv27
|
||||||
pyenv activate <name>
|
$ source "$(pyenv prefix venv27)/bin/activate"
|
||||||
pyenv deactivate
|
|
||||||
```
|
|
||||||
|
|
||||||
|
### Deactivate virtualenv
|
||||||
|
|
||||||
### Delete existing virtualenv
|
You can `deactivate` the activate'd virtualenv by `pyenv deactivate`.
|
||||||
|
|
||||||
Removing the directories in `$(pyenv root)/versions` and `$(pyenv root)/versions/{version}/envs` will delete the virtualenv, or you can run:
|
|
||||||
|
|
||||||
```sh
|
|
||||||
pyenv uninstall my-virtual-env
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
### virtualenv and venv
|
|
||||||
|
|
||||||
There is a [venv](http://docs.python.org/3/library/venv.html) module available
|
|
||||||
for CPython 3.3 and newer.
|
|
||||||
It provides an executable module `venv` which is the successor of `virtualenv`
|
|
||||||
and distributed by default.
|
|
||||||
|
|
||||||
`pyenv-virtualenv` uses `python -m venv` if it is available and the `virtualenv`
|
|
||||||
command is not available.
|
|
||||||
|
|
||||||
|
|
||||||
### Anaconda and Miniconda
|
|
||||||
|
|
||||||
You can manage `conda` environments by `conda create` as same manner as standard Anaconda/Miniconda installations.
|
|
||||||
To use those environments, you can use `pyenv activate` and `pyenv deactivate`.
|
|
||||||
|
|
||||||
```sh
|
|
||||||
$ pyenv version
|
|
||||||
miniconda3-3.9.1 (set by /home/yyuu/.pyenv/version)
|
|
||||||
$ conda env list
|
|
||||||
# conda environments:
|
|
||||||
#
|
|
||||||
myenv /home/yyuu/.pyenv/versions/miniconda3-3.9.1/envs/myenv
|
|
||||||
root * /home/yyuu/.pyenv/versions/miniconda3-3.9.1
|
|
||||||
$ pyenv activate miniconda3-3.9.1/envs/myenv
|
|
||||||
discarding /home/yyuu/.pyenv/versions/miniconda3-3.9.1/bin from PATH
|
|
||||||
prepending /home/yyuu/.pyenv/versions/miniconda3-3.9.1/envs/myenv/bin to PATH
|
|
||||||
$ python --version
|
|
||||||
Python 3.4.3 :: Continuum Analytics, Inc.
|
|
||||||
$ pyenv deactivate
|
$ pyenv deactivate
|
||||||
discarding /home/yyuu/.pyenv/versions/miniconda3-3.9.1/envs/myenv/bin from PATH
|
|
||||||
```
|
|
||||||
|
|
||||||
If `conda` is available, `pyenv virtualenv` will use it to create environment by `conda create`.
|
Or, there is an alias in `activate` command.
|
||||||
|
This is prepared for similality between other `pyenv` commands like `shell` and `local`.
|
||||||
|
|
||||||
```sh
|
$ pyenv activate --unset
|
||||||
$ pyenv version
|
|
||||||
miniconda3-3.9.1 (set by /home/yyuu/.pyenv/version)
|
|
||||||
$ pyenv virtualenv myenv2
|
|
||||||
$ conda env list
|
|
||||||
# conda environments:
|
|
||||||
#
|
|
||||||
myenv /home/yyuu/.pyenv/versions/miniconda3-3.9.1/envs/myenv
|
|
||||||
myenv /home/yyuu/.pyenv/versions/miniconda3-3.9.1/envs/myenv2
|
|
||||||
root * /home/yyuu/.pyenv/versions/miniconda3-3.9.1
|
|
||||||
```
|
|
||||||
|
|
||||||
You can use version like `miniconda3-3.9.1/envs/myenv` to specify `conda` environment as a version in pyenv.
|
`pyenv deactivate` acts almost like following commands.
|
||||||
|
You can also use virtualenv's `deactivate` in place of `pyenv deactivate`,
|
||||||
```sh
|
but be careful with the _shell_ version because it will be persisted even if `deactivate` has invoked.
|
||||||
$ pyenv version
|
|
||||||
miniconda3-3.9.1 (set by /home/yyuu/.pyenv/version)
|
|
||||||
$ pyenv shell miniconda3-3.9.1/envs/myenv
|
|
||||||
$ which python
|
|
||||||
/home/yyuu/.pyenv/versions/miniconda3-3.9.1/envs/myenv/bin/python
|
|
||||||
```
|
|
||||||
|
|
||||||
|
$ deactivate
|
||||||
|
$ pyenv shell --unset
|
||||||
|
|
||||||
### Special environment variables
|
### Special environment variables
|
||||||
|
|
||||||
You can set certain environment variables to control pyenv-virtualenv.
|
You can set certain environment variables to control the pyenv-virtualenv.
|
||||||
|
|
||||||
* `PYENV_VIRTUALENV_CACHE_PATH`, if set, specifies a directory to use for
|
* `PYENV_VIRTUALENV_CACHE_PATH`, if set, specifies a directory to use for
|
||||||
caching downloaded package files.
|
caching downloaded package files.
|
||||||
* `VIRTUALENV_VERSION`, if set, forces pyenv-virtualenv to install the desired
|
* `VIRTUALENV_VERSION`, if set, forces pyenv-virtualenv to install desired
|
||||||
version of virtualenv. If `virtualenv` has not been installed,
|
version of virtualenv. If the virtualenv has not been installed,
|
||||||
pyenv-virtualenv will try to install the given version of virtualenv.
|
pyenv-virtualenv will try to install the given version of virtualenv.
|
||||||
* `GET_PIP`, if set and `venv` is preferred over `virtualenv`,
|
* `EZ_SETUP` and `GET_PIP`, if set and pyvenv is preferred than virtualenv,
|
||||||
use `get_pip.py` from the specified location.
|
use `ez_setup.py` and `get_pip.py` at specified location.
|
||||||
* `GET_PIP_URL`, if set and `venv` is preferred over
|
* `EZ_SETUP_URL` and `GET_PIP_URL`, if set and pyvenv is preferred
|
||||||
`virtualenv`, download `get_pip.py` from the specified URL.
|
than virtualenv, download `ez_setup.py` and `get_pip.py` from specified URL.
|
||||||
* `PIP_VERSION`, if set and `venv` is preferred
|
* `SETUPTOOLS_VERSION` and `PIP_VERSION`, if set and pyvenv is preferred
|
||||||
over `virtualenv`, install the specified version of pip.
|
than virtualenv, install specified version of setuptools and pip.
|
||||||
|
|
||||||
|
|
||||||
## Version History
|
## Version History
|
||||||
|
|
||||||
See [CHANGELOG.md](CHANGELOG.md).
|
#### 20140421
|
||||||
|
|
||||||
|
* Display error if `pyenv activate` was invoked as a command
|
||||||
|
* Fix completion of `pyenv activate` (#15)
|
||||||
|
* Use `virtualenv` instead of `pyvenv` if `-p` has given (yyuu/pyenv#158)
|
||||||
|
|
||||||
|
#### 20140123
|
||||||
|
|
||||||
|
* Add `activate` and `deactivate` to make `pyenv-virtualenv` work with [jedi](https://github.com/davidhalter/jedi) (#9)
|
||||||
|
* Use `ensurepip` to install `pip` if it is available
|
||||||
|
* Unset `PIP_REQUIRE_VENV` to avoid problem on the installation of `virtualenv` (#10)
|
||||||
|
* Add tests
|
||||||
|
|
||||||
|
#### 20140110.1
|
||||||
|
|
||||||
|
* Fix install script
|
||||||
|
|
||||||
|
#### 20140110
|
||||||
|
|
||||||
|
* Support environment variables of `EZ_SETUP` and `GET_PIP`.
|
||||||
|
* Support a short option `-p` of `virtualenv`.
|
||||||
|
|
||||||
|
#### 20131216
|
||||||
|
|
||||||
|
* Use latest release of setuptools and pip if the version not given via environment variables.
|
||||||
|
|
||||||
|
#### 20130622
|
||||||
|
|
||||||
|
* Removed bundled `virtualenv.py` script. Now pyenv-virtualenv installs `virtualenv` package into source version and then use it.
|
||||||
|
* On Python 3.3+, use `pyvenv` as virtualenv command if `virtualenv` is not available.
|
||||||
|
* Install setuptools and pip into environments created by `pyvenv`.
|
||||||
|
|
||||||
|
#### 20130614
|
||||||
|
|
||||||
|
* Add `pyenv virtualenvs` to list all virtualenv versions.
|
||||||
|
* *EXPERIMENTAL*: Add `--upgrade` option to re-create virtualenv with migrating packages
|
||||||
|
|
||||||
|
#### 20130527
|
||||||
|
|
||||||
|
* Remove `python-virtualenv` which was no longer used.
|
||||||
|
* Change the installation path of the `virtualenv.py` script. (`./libexec` -> `./libexec/pyenv-virtualenv/${VIRTUALENV_VERSION}`)
|
||||||
|
* Download `virtualenv.py` if desired version has not been installed.
|
||||||
|
|
||||||
|
#### 20130507
|
||||||
|
|
||||||
|
* Display virtualenv information in `--help` and `--version`
|
||||||
|
* Update virtualenv version; 1.8.4 -> 1.9.1
|
||||||
|
|
||||||
|
#### 20130307
|
||||||
|
|
||||||
|
* Rename the project; `s/python-virtualenv/pyenv-virtualenv/g`
|
||||||
|
* The `pyenv-virtualenv` script is not depending on `python-virtualenv` now.
|
||||||
|
`python-virtualenv` will left for compatibility and will not continue for future releases.
|
||||||
|
* Update virtualenv version; 1.8.2 -> 1.8.4
|
||||||
|
|
||||||
|
#### 20130218
|
||||||
|
|
||||||
|
* Add pyenv 0.2.x (rbenv 0.4.x) style help messages.
|
||||||
|
|
||||||
|
#### 20121023
|
||||||
|
|
||||||
|
* Create virtualenv with exact name of python executables.
|
||||||
|
* Changed command-line options of python-virtualenv.
|
||||||
|
First argument should be a path to the python executable.
|
||||||
|
* Add install script.
|
||||||
|
|
||||||
|
#### 20120927
|
||||||
|
|
||||||
|
* Initial public release.
|
||||||
|
|
||||||
### License
|
### License
|
||||||
|
|
||||||
(The MIT License)
|
(The MIT License)
|
||||||
|
|
||||||
* Copyright (c) 2015 Yamashita, Yuu
|
* Copyright (c) 2013 Yamashita, Yuu
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
a copy of this software and associated documentation files (the
|
a copy of this software and associated documentation files (the
|
||||||
|
|||||||
@@ -14,236 +14,35 @@
|
|||||||
set -e
|
set -e
|
||||||
[ -n "$PYENV_DEBUG" ] && set -x
|
[ -n "$PYENV_DEBUG" ] && set -x
|
||||||
|
|
||||||
if [ -z "${PYENV_ROOT}" ]; then
|
|
||||||
PYENV_ROOT="$(pyenv-root)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
resolve_link() {
|
|
||||||
$(type -p greadlink readlink | head -1) "$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
unset FORCE
|
|
||||||
unset QUIET
|
|
||||||
|
|
||||||
while [ $# -gt 0 ]; do
|
|
||||||
case "$1" in
|
|
||||||
"--complete" )
|
|
||||||
# Provide pyenv completions
|
# Provide pyenv completions
|
||||||
|
if [ "$1" = "--complete" ]; then
|
||||||
echo --unset
|
echo --unset
|
||||||
exec pyenv-virtualenvs --bare
|
exec pyenv-virtualenvs --bare
|
||||||
;;
|
fi
|
||||||
"-f" | "--force" )
|
|
||||||
FORCE=1
|
if [ "$1" = "--unset" ]; then
|
||||||
;;
|
echo "pyenv deactivate"
|
||||||
"-q" | "--quiet" )
|
exit
|
||||||
QUIET=1
|
fi
|
||||||
;;
|
|
||||||
"--unset" )
|
|
||||||
exec pyenv-sh-deactivate
|
|
||||||
;;
|
|
||||||
"-v" | "--verbose" )
|
|
||||||
unset QUIET
|
|
||||||
PYENV_VIRTUALENV_VERBOSE_ACTIVATE=1
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
break
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
shift 1
|
|
||||||
done
|
|
||||||
|
|
||||||
no_shell=
|
|
||||||
versions=("$@")
|
versions=("$@")
|
||||||
if [ -z "${versions}" ]; then
|
shell="$(basename "${PYENV_SHELL:-$SHELL}")"
|
||||||
no_shell=1
|
|
||||||
|
if [ -z "$versions" ]; then
|
||||||
OLDIFS="$IFS"
|
OLDIFS="$IFS"
|
||||||
IFS=: versions=($(pyenv-version-name 2>/dev/null))
|
IFS=: versions=($(pyenv-version-name))
|
||||||
IFS="$OLDIFS"
|
IFS="$OLDIFS"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -z "${PYENV_VIRTUALENV_INIT}" ]; then
|
if [ "${#versions[@]}" -gt 1 ]; then
|
||||||
# Backward compatibility issue
|
|
||||||
# https://github.com/yyuu/pyenv-virtualenv/issues/26
|
|
||||||
no_shell=
|
|
||||||
fi
|
|
||||||
|
|
||||||
venv="${versions}"
|
|
||||||
|
|
||||||
if [ -n "${VIRTUAL_ENV}" ]; then
|
|
||||||
# exit as success if some virtualenv is already activated outside from pyenv-virtualenv
|
|
||||||
if [ -z "${PYENV_VIRTUAL_ENV}" ]; then
|
|
||||||
if [ -z "${FORCE}" ]; then
|
|
||||||
if [ -z "${QUIET}" ]; then
|
|
||||||
echo "pyenv-virtualenv: virtualenv \`${VIRTUAL_ENV}' is already activated" 1>&2
|
|
||||||
fi
|
|
||||||
echo "true"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! pyenv-virtualenv-prefix "${venv}" 1>/dev/null 2>&1; then
|
|
||||||
# fallback to virtualenv of current version
|
|
||||||
OLDIFS="$IFS"
|
|
||||||
IFS=: current_versions=($(pyenv-version-name))
|
|
||||||
IFS="$OLDIFS"
|
|
||||||
new_venv="${current_versions%/envs/*}/envs/${venv}"
|
|
||||||
if pyenv-virtualenv-prefix "${new_venv}" 1>/dev/null 2>&1; then
|
|
||||||
venv="${new_venv}"
|
|
||||||
versions[0]="${new_venv}"
|
|
||||||
else
|
|
||||||
if [ -z "${QUIET}" ]; then
|
|
||||||
echo "pyenv-virtualenv: version \`${venv}' is not a virtualenv" 1>&2
|
|
||||||
fi
|
|
||||||
echo "false"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# exit as error if there are multiple virtualenvs
|
|
||||||
# https://github.com/yyuu/pyenv-virtualenv/issues/105
|
|
||||||
for version in "${versions[@]}"; do
|
|
||||||
if [[ "${version}" != "${venv}" ]]; then
|
|
||||||
if pyenv-virtualenv-prefix "${version}" 1>/dev/null 2>&1; then
|
|
||||||
if [ -z "${QUIET}" ]; then
|
|
||||||
echo "pyenv-virtualenv: cannot activate multiple versions at once: ${versions[@]}" 1>&2
|
echo "pyenv-virtualenv: cannot activate multiple versions at once: ${versions[@]}" 1>&2
|
||||||
fi
|
|
||||||
echo "false"
|
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
shell="${PYENV_SHELL:-${SHELL##*/}}"
|
pyenv-virtualenv-prefix "${versions}" 1>/dev/null
|
||||||
prefix="$(pyenv-prefix "${venv}")"
|
|
||||||
|
|
||||||
if [ -L "${prefix}" ]; then
|
echo "pyenv shell \"${versions}\""
|
||||||
prefix="$(resolve_link "${prefix}" 2>/dev/null)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# exit as success if the virtualenv is already activated
|
|
||||||
if [[ "${VIRTUAL_ENV}" == "${prefix}" ]]; then
|
|
||||||
if [ -z "${FORCE}" ]; then
|
|
||||||
if [ -z "${QUIET}" ]; then
|
|
||||||
echo "pyenv-virtualenv: version \`${venv}' is already activated" 1>&2
|
|
||||||
fi
|
|
||||||
echo "true"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
pyenv-sh-deactivate --force --quiet || true
|
|
||||||
|
|
||||||
if [ -n "$PYENV_VIRTUALENV_VERBOSE_ACTIVATE" ]; then
|
|
||||||
echo "pyenv-virtualenv: activate ${venv}" 1>&2
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$no_shell" ]; then
|
|
||||||
# shell version set in pyenv-sh-activate should be unset
|
|
||||||
# https://github.com/yyuu/pyenv-virtualenv/issues/61
|
|
||||||
OLDIFS="$IFS"
|
|
||||||
IFS=:
|
|
||||||
case "$shell" in
|
case "$shell" in
|
||||||
fish )
|
fish ) echo ". \"$(pyenv-prefix "${versions}")/bin/activate.fish\"" ;;
|
||||||
cat <<EOS
|
* ) echo "source \"$(pyenv-prefix "${versions}")/bin/activate\"" ;;
|
||||||
set -gx PYENV_VERSION "${versions[*]}";
|
|
||||||
set -gx PYENV_ACTIVATE_SHELL 1;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
export PYENV_VERSION="${versions[*]}";
|
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
IFS="$OLDIFS"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# virtualenv/venv
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
cat <<EOS
|
|
||||||
set -gx PYENV_VIRTUAL_ENV "${prefix}";
|
|
||||||
set -gx VIRTUAL_ENV "${prefix}";
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
export PYENV_VIRTUAL_ENV="${prefix}";
|
|
||||||
export VIRTUAL_ENV="${prefix}";
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# anaconda/miniconda
|
|
||||||
if [ -x "${prefix}/bin/conda" ]; then
|
|
||||||
if [[ "${prefix}" != "${prefix%/envs/*}" ]]; then
|
|
||||||
CONDA_DEFAULT_ENV="${venv##*/envs/}"
|
|
||||||
else
|
|
||||||
CONDA_DEFAULT_ENV="root"
|
|
||||||
fi
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
echo "set -gx CONDA_DEFAULT_ENV \"${CONDA_DEFAULT_ENV}\";"
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
echo "export CONDA_DEFAULT_ENV=\"${CONDA_DEFAULT_ENV}\";"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "${PYTHONHOME}" ]; then
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
cat <<EOS
|
|
||||||
set -gx _OLD_VIRTUAL_PYTHONHOME "${PYTHONHOME}";
|
|
||||||
set -e PYTHONHOME;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
export _OLD_VIRTUAL_PYTHONHOME="${PYTHONHOME}";
|
|
||||||
unset PYTHONHOME;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
PYENV_VIRTUALENV_DISABLE_PROMPT="${PYENV_VIRTUALENV_DISABLE_PROMPT:-${PYENV_VIRTUAL_ENV_DISABLE_PROMPT}}"
|
|
||||||
PYENV_VIRTUALENV_DISABLE_PROMPT="${PYENV_VIRTUALENV_DISABLE_PROMPT:-${VIRTUAL_ENV_DISABLE_PROMPT}}"
|
|
||||||
|
|
||||||
if [ -z "${PYENV_VIRTUALENV_DISABLE_PROMPT}" ]; then
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
if [ -z "${QUIET}" ]; then
|
|
||||||
echo "pyenv-virtualenv: prompt changing not working for fish." 1>&2
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
if [ -z "${QUIET}" ]; then
|
|
||||||
echo "pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior." 1>&2
|
|
||||||
fi
|
|
||||||
cat <<EOS
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(${venv}) \${PS1}";
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
# conda package anaconda/miniconda scripts (#173)
|
|
||||||
if [ -x "${prefix}/bin/conda" ]; then
|
|
||||||
shopt -s nullglob
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
: # conda doesn't support fish
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
for script in "${prefix}/etc/conda/activate.d"/*.sh; do
|
|
||||||
echo ". \"${script}\";"
|
|
||||||
done
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
shopt -u nullglob
|
|
||||||
fi
|
|
||||||
|
|||||||
@@ -9,183 +9,9 @@
|
|||||||
set -e
|
set -e
|
||||||
[ -n "$PYENV_DEBUG" ] && set -x
|
[ -n "$PYENV_DEBUG" ] && set -x
|
||||||
|
|
||||||
if [ -z "${PYENV_ROOT}" ]; then
|
|
||||||
PYENV_ROOT="$(pyenv-root)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
unset FORCE
|
|
||||||
unset QUIET
|
|
||||||
|
|
||||||
while [ $# -gt 0 ]; do
|
|
||||||
case "$1" in
|
|
||||||
"-f" | "--force" )
|
|
||||||
FORCE=1
|
|
||||||
;;
|
|
||||||
"-q" | "--quiet")
|
|
||||||
QUIET=1
|
|
||||||
;;
|
|
||||||
"-v" | "--verbose" )
|
|
||||||
unset QUIET
|
|
||||||
PYENV_VIRTUALENV_VERBOSE_ACTIVATE=1
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
break
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
shift 1
|
|
||||||
done
|
|
||||||
|
|
||||||
if [ -z "${VIRTUAL_ENV}" ]; then
|
|
||||||
if [ -z "${FORCE}" ]; then
|
|
||||||
if [ -z "${QUIET}" ]; then
|
|
||||||
echo "pyenv-virtualenv: no virtualenv has been activated." 1>&2
|
|
||||||
fi
|
|
||||||
echo "false"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
shell="$(basename "${PYENV_SHELL:-$SHELL}")"
|
shell="$(basename "${PYENV_SHELL:-$SHELL}")"
|
||||||
prefix="${VIRTUAL_ENV}"
|
|
||||||
|
|
||||||
if [[ "${prefix%/*/envs/*}" == "${PYENV_ROOT}/versions" ]]; then
|
|
||||||
venv="${prefix#${PYENV_ROOT}/versions/}"
|
|
||||||
else
|
|
||||||
venv="${prefix##*/}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "$PYENV_VIRTUALENV_VERBOSE_ACTIVATE" ]; then
|
|
||||||
echo "pyenv-virtualenv: deactivate ${venv}" 1>&2
|
|
||||||
fi
|
|
||||||
|
|
||||||
# conda package anaconda/miniconda scripts (#173)
|
|
||||||
if [ -x "${prefix}/bin/conda" ]; then
|
|
||||||
shopt -s nullglob
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
: # conda doesn't support fish
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
for script in "${prefix}/etc/conda/deactivate.d"/*.sh; do
|
|
||||||
echo ". \"${script}\";"
|
|
||||||
done
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
shopt -u nullglob
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "${PYENV_ACTIVATE_SHELL}" ]; then
|
|
||||||
# shell version set in pyenv-sh-activate should be unset
|
|
||||||
# https://github.com/yyuu/pyenv-virtualenv/issues/61
|
|
||||||
case "$shell" in
|
case "$shell" in
|
||||||
fish )
|
fish ) echo "functions -q deactivate; and deactivate";;
|
||||||
cat <<EOS
|
* ) echo "declare -f deactivate 1>/dev/null 2>&1 && deactivate";;
|
||||||
set -e PYENV_VERSION;
|
|
||||||
set -e PYENV_ACTIVATE_SHELL;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
unset PYENV_VERSION;
|
|
||||||
unset PYENV_ACTIVATE_SHELL;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
# virtualenv/venv
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
cat <<EOS
|
|
||||||
set -e PYENV_VIRTUAL_ENV;
|
|
||||||
set -e VIRTUAL_ENV;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
|
||||||
unset VIRTUAL_ENV;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# anaconda/miniconda
|
|
||||||
if [ -n "${CONDA_DEFAULT_ENV}" ]; then
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
echo "set -e CONDA_DEFAULT_ENV;"
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
echo "unset CONDA_DEFAULT_ENV;"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
cat <<EOS
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
|
||||||
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
|
||||||
end;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
|
||||||
export PATH="\${_OLD_VIRTUAL_PATH}";
|
|
||||||
unset _OLD_VIRTUAL_PATH;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
cat <<EOS
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
|
||||||
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
end;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PYTHONHOME}" ]; then
|
|
||||||
export PYTHONHOME="\${_OLD_VIRTUAL_PYTHONHOME}";
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
:
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PS1}" ]; then
|
|
||||||
export PS1="\${_OLD_VIRTUAL_PS1}";
|
|
||||||
unset _OLD_VIRTUAL_PS1;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
case "${shell}" in
|
|
||||||
fish )
|
|
||||||
cat <<EOS
|
|
||||||
if functions -q deactivate;
|
|
||||||
functions -e deactivate;
|
|
||||||
end;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
if declare -f deactivate 1>/dev/null 2>&1; then
|
|
||||||
unset -f deactivate;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
|
echo "pyenv shell --unset"
|
||||||
|
|||||||
@@ -2,27 +2,29 @@
|
|||||||
#
|
#
|
||||||
# Summary: Create a Python virtualenv using the pyenv-virtualenv plugin
|
# Summary: Create a Python virtualenv using the pyenv-virtualenv plugin
|
||||||
#
|
#
|
||||||
# Usage: pyenv virtualenv [-f|--force] [VIRTUALENV_OPTIONS] [version] <virtualenv-name>
|
# Usage: pyenv virtualenv [-f|--force] [-u|--upgrade] [VIRTUALENV_OPTIONS] <version> <virtualenv-name>
|
||||||
# pyenv virtualenv --version
|
# pyenv virtualenv --version
|
||||||
# pyenv virtualenv --help
|
# pyenv virtualenv --help
|
||||||
#
|
#
|
||||||
|
# -u/--upgrade Upgrade existing virtualenv to use new version of Python,
|
||||||
|
# assuming Python has been upgraded in-place.
|
||||||
# -f/--force Install even if the version appears to be installed already
|
# -f/--force Install even if the version appears to be installed already
|
||||||
#
|
#
|
||||||
|
|
||||||
PYENV_VIRTUALENV_VERSION="1.1.0"
|
PYENV_VIRTUALENV_VERSION="20140421"
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
[ -n "$PYENV_DEBUG" ] && set -x
|
[ -n "$PYENV_DEBUG" ] && set -x
|
||||||
|
|
||||||
if [ -z "${PYENV_ROOT}" ]; then
|
|
||||||
PYENV_ROOT="$(pyenv-root)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Provide pyenv completions
|
# Provide pyenv completions
|
||||||
if [ "$1" = "--complete" ]; then
|
if [ "$1" = "--complete" ]; then
|
||||||
exec pyenv-versions --bare
|
exec pyenv-versions --bare
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ -z "$PYENV_ROOT" ]; then
|
||||||
|
PYENV_ROOT="${HOME}/.pyenv"
|
||||||
|
fi
|
||||||
|
|
||||||
unset PIP_REQUIRE_VENV
|
unset PIP_REQUIRE_VENV
|
||||||
unset PIP_REQUIRE_VIRTUALENV
|
unset PIP_REQUIRE_VIRTUALENV
|
||||||
|
|
||||||
@@ -103,119 +105,145 @@ http_get_wget() {
|
|||||||
version() {
|
version() {
|
||||||
detect_venv
|
detect_venv
|
||||||
local version
|
local version
|
||||||
if [ -n "${USE_CONDA}" ]; then
|
if [ -n "$USE_PYVENV" ]; then
|
||||||
version="$(pyenv-exec conda --version 2>/dev/null || true)"
|
version="$(pyenv-which pyvenv 2>/dev/null || true)"
|
||||||
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (conda ${version:-unknown})"
|
version="${version#$(pyenv-root)/versions/}"
|
||||||
|
version="${version%/bin/pyvenv}"
|
||||||
|
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (pyvenv ${version:-unknown})"
|
||||||
else
|
else
|
||||||
if [ -n "$USE_M_VENV" ]; then
|
version="$(venv --version 2>/dev/null || true)"
|
||||||
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (python -m venv)"
|
|
||||||
else
|
|
||||||
version="$(pyenv-exec virtualenv --version 2>/dev/null || true)"
|
|
||||||
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (virtualenv ${version:-unknown})"
|
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (virtualenv ${version:-unknown})"
|
||||||
fi
|
fi
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
usage() {
|
usage() {
|
||||||
# We can remove the sed fallback once pyenv 0.2.0 is widely available.
|
# We can remove the sed fallback once pyenv 0.2.0 is widely available.
|
||||||
pyenv-help virtualenv 2>/dev/null || sed -ne '/^#/!q;s/.//;s/.//;1,4d;p' < "$0"
|
pyenv-help virtualenv 2>/dev/null || sed -ne '/^#/!q;s/.//;s/.//;1,4d;p' < "$0"
|
||||||
if [ -n "${USE_CONDA}" ]; then
|
venv --help 2>/dev/null || true
|
||||||
pyenv-exec conda create --help 2>/dev/null || true
|
|
||||||
else
|
|
||||||
if [ -n "${USE_M_VENV}" ]; then
|
|
||||||
pyenv-exec python -m venv --help 2>/dev/null || true
|
|
||||||
else
|
|
||||||
pyenv-exec virtualenv --help 2>/dev/null || true
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
[ -z "$1" ] || exit "$1"
|
[ -z "$1" ] || exit "$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
detect_venv() {
|
detect_venv() {
|
||||||
# Check the existence of executables as a workaround for the issue with pyenv-which-ext
|
if pyenv-which "virtualenv" 1>/dev/null 2>&1; then
|
||||||
# https://github.com/yyuu/pyenv-virtualenv/issues/26
|
|
||||||
local prefix="$(pyenv-prefix)"
|
|
||||||
if [ -x "${prefix}/bin/conda" ]; then
|
|
||||||
HAS_CONDA=1
|
|
||||||
else
|
|
||||||
if [ -x "${prefix}/bin/virtualenv" ]; then
|
|
||||||
HAS_VIRTUALENV=1
|
HAS_VIRTUALENV=1
|
||||||
fi
|
fi
|
||||||
if pyenv-exec python -m venv --help 1>/dev/null 2>&1; then
|
if pyenv-which "pyvenv" 1>/dev/null 2>&1; then
|
||||||
HAS_M_VENV=1
|
HAS_PYVENV=1
|
||||||
fi
|
|
||||||
fi
|
|
||||||
# Use `python -m venv` only if there is venv available, virtualenv is not installed, and `-p` not given
|
|
||||||
if [ -n "${HAS_CONDA}" ]; then
|
|
||||||
USE_CONDA=1
|
|
||||||
else
|
|
||||||
if [ -n "${HAS_M_VENV}" ] && [ -z "${HAS_VIRTUALENV}" ] && [ -z "${VIRTUALENV_PYTHON}" ]; then
|
|
||||||
USE_M_VENV=1
|
|
||||||
fi
|
fi
|
||||||
|
# Use pyvenv only if there is pyvenv, virtualenv is not installed, and `-p` not given
|
||||||
|
if [ -n "${HAS_PYVENV}" ] && [ -z "${HAS_VIRTUALENV}" ] && [ -z "${VIRTUALENV_PYTHON}" ]; then
|
||||||
|
USE_PYVENV=1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
build_package_ez_setup() {
|
venv() {
|
||||||
local ez_setup="${PYENV_VIRTUALENV_CACHE_PATH}/ez_setup.py"
|
local args=("$@")
|
||||||
rm -f "${ez_setup}"
|
if [ -n "${USE_PYVENV}" ]; then
|
||||||
|
pyenv-exec pyvenv "${args[@]}"
|
||||||
|
|
||||||
|
local last="${args[${#args[@]}-1]}"
|
||||||
|
ensurepip "${last##*/}"
|
||||||
|
else
|
||||||
|
pyenv-exec virtualenv "${args[@]}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
install_setuptools() {
|
||||||
|
local version="$1"
|
||||||
{ if [ "${EZ_SETUP+defined}" ] && [ -f "${EZ_SETUP}" ]; then
|
{ if [ "${EZ_SETUP+defined}" ] && [ -f "${EZ_SETUP}" ]; then
|
||||||
|
if [ -n "$VERBOSE" ]; then
|
||||||
echo "Installing setuptools from ${EZ_SETUP}..." 1>&2
|
echo "Installing setuptools from ${EZ_SETUP}..." 1>&2
|
||||||
|
fi
|
||||||
cat "${EZ_SETUP}"
|
cat "${EZ_SETUP}"
|
||||||
else
|
else
|
||||||
[ -n "${EZ_SETUP_URL}" ] || EZ_SETUP_URL="https://bootstrap.pypa.io/ez_setup.py"
|
[ -n "${EZ_SETUP_URL}" ] || {
|
||||||
|
if [ -n "${SETUPTOOLS_VERSION}" ]; then
|
||||||
|
EZ_SETUP_URL="https://bitbucket.org/pypa/setuptools/raw/${SETUPTOOLS_VERSION}/ez_setup.py"
|
||||||
|
else
|
||||||
|
EZ_SETUP_URL="https://bitbucket.org/pypa/setuptools/downloads/ez_setup.py"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
if [ -n "$VERBOSE" ]; then
|
||||||
echo "Installing setuptools from ${EZ_SETUP_URL}..." 1>&2
|
echo "Installing setuptools from ${EZ_SETUP_URL}..." 1>&2
|
||||||
|
fi
|
||||||
http get "${EZ_SETUP_URL}"
|
http get "${EZ_SETUP_URL}"
|
||||||
fi
|
fi
|
||||||
} 1> "${ez_setup}"
|
} | PYENV_VERSION="${version}" pyenv-exec python
|
||||||
pyenv-exec python -s "${ez_setup}" ${EZ_SETUP_OPTS} 1>&2 || {
|
|
||||||
echo "error: failed to install setuptools via ez_setup.py" >&2
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
build_package_get_pip() {
|
install_pip() {
|
||||||
local get_pip="${PYENV_VIRTUALENV_CACHE_PATH}/get-pip.py"
|
local version="$1"
|
||||||
rm -f "${get_pip}"
|
|
||||||
{ if [ "${GET_PIP+defined}" ] && [ -f "${GET_PIP}" ]; then
|
{ if [ "${GET_PIP+defined}" ] && [ -f "${GET_PIP}" ]; then
|
||||||
|
if [ -n "$VERBOSE" ]; then
|
||||||
echo "Installing pip from ${GET_PIP}..." 1>&2
|
echo "Installing pip from ${GET_PIP}..." 1>&2
|
||||||
|
fi
|
||||||
cat "${GET_PIP}"
|
cat "${GET_PIP}"
|
||||||
else
|
else
|
||||||
[ -n "${GET_PIP_URL}" ] || GET_PIP_URL="https://bootstrap.pypa.io/get-pip.py"
|
[ -n "${GET_PIP_URL}" ] || {
|
||||||
|
if [ -n "${PIP_VERSION}" ]; then
|
||||||
|
GET_PIP_URL="https://raw.github.com/pypa/pip/${PIP_VERSION}/contrib/get-pip.py"
|
||||||
|
else
|
||||||
|
GET_PIP_URL="https://raw.github.com/pypa/pip/master/contrib/get-pip.py"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
if [ -n "$VERBOSE" ]; then
|
||||||
echo "Installing pip from ${GET_PIP_URL}..." 1>&2
|
echo "Installing pip from ${GET_PIP_URL}..." 1>&2
|
||||||
|
fi
|
||||||
http get "${GET_PIP_URL}"
|
http get "${GET_PIP_URL}"
|
||||||
fi
|
fi
|
||||||
} 1> "${get_pip}"
|
} | PYENV_VERSION="${version}" pyenv-exec python
|
||||||
pyenv-exec python -s "${get_pip}" ${GET_PIP_OPTS} 1>&2 || {
|
|
||||||
echo "error: failed to install pip via get-pip.py" >&2
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
build_package_ensurepip() {
|
install_virtualenv() {
|
||||||
pyenv-exec python -s -m ensurepip 2>/dev/null || build_package_get_pip "$@" || return 1
|
local version="$1"
|
||||||
|
VIRTUALENV_VERSION="==${VIRTUALENV_VERSION}"
|
||||||
|
PYENV_VERSION="${version}" pyenv-exec pip install $QUIET $VERBOSE "virtualenv${VIRTUALENV_VERSION%==}"
|
||||||
}
|
}
|
||||||
|
|
||||||
prepare_requirements() {
|
ensurepip() {
|
||||||
pyenv-exec pip freeze > "${REQUIREMENTS}"
|
local version="$1"
|
||||||
mv -f "${VIRTUALENV_PATH}" "${VIRTUALENV_ORIG}"
|
if PYENV_VERSION="${version}" pyenv-exec python -m ensurepip 2>/dev/null; then
|
||||||
|
local PREFIX_PATH="$(pyenv-prefix "${version}")"
|
||||||
|
if [ ! -e "${PREFIX_PATH}/bin/pip" ]; then
|
||||||
|
local pip="$(PYENV_VERSION="${version}" pyenv-exec python -c 'import sys;v=sys.version_info;sys.stdout.write("pip%d.%d"%(v[0],v[1]))')"
|
||||||
|
if [ -e "${PREFIX_PATH}/bin/${pip}" ]; then
|
||||||
|
( cd "${PREFIX_PATH}/bin" && ln -fs "${pip}" "pip" )
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
PYENV_VERSION="${version}" pyenv-exec python -c "import setuptools" 1>/dev/null 2>&1 || {
|
||||||
|
install_setuptools "${version}"
|
||||||
|
} 1>&2
|
||||||
|
PYENV_VERSION="${version}" pyenv-which pip 1>/dev/null 2>&1 || {
|
||||||
|
install_pip "${version}"
|
||||||
|
} 1>&2
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
install_requirements() {
|
prepare_upgrade() {
|
||||||
if [ -f "${REQUIREMENTS}" ]; then
|
local version="$1"
|
||||||
|
local prefix="$2"
|
||||||
|
PYENV_VERSION="${version}" pyenv-exec pip freeze >"${UPGRADE_LIST}"
|
||||||
|
mv -f "${prefix}" "${UPGRADE_PATH}"
|
||||||
|
}
|
||||||
|
|
||||||
|
upgrade() {
|
||||||
|
local version="$1"
|
||||||
|
local prefix="$2"
|
||||||
## Migrate previously installed packages from requirements.txt
|
## Migrate previously installed packages from requirements.txt
|
||||||
pyenv-exec pip install $QUIET $VERBOSE --requirement "${REQUIREMENTS}" || {
|
if ! PYENV_VERSION="${version}" pyenv-exec pip install $QUIET $VERBOSE --requirement "${UPGRADE_LIST}"; then
|
||||||
|
{ echo
|
||||||
|
echo "UPGRADE FAILED"
|
||||||
echo
|
echo
|
||||||
echo "PIP INSTALL FAILED"
|
echo "Inspect or clean up the original tree at ${UPGRADE_PATH}"
|
||||||
echo
|
|
||||||
echo "Inspect or clean up the original tree at ${VIRTUALENV_ORIG}"
|
|
||||||
echo
|
echo
|
||||||
echo "Package list:"
|
echo "Package list:"
|
||||||
cat "${REQUIREMENTS}" | sed 's/^/ * /'
|
cat "${UPGRADE_LIST}"
|
||||||
return 1
|
|
||||||
} 1>&2
|
} 1>&2
|
||||||
rm -f "${REQUIREMENTS}"
|
return 1
|
||||||
rm -fr "${VIRTUALENV_ORIG}"
|
|
||||||
fi
|
fi
|
||||||
|
rm -f "${UPGRADE_LIST}"
|
||||||
|
rm -fr "${UPGRADE_PATH}"
|
||||||
}
|
}
|
||||||
|
|
||||||
PYENV_VIRTUALENV_ROOT="$(abs_dirname "$0")/.."
|
PYENV_VIRTUALENV_ROOT="$(abs_dirname "$0")/.."
|
||||||
@@ -225,11 +253,10 @@ fi
|
|||||||
VIRTUALENV_OPTIONS=()
|
VIRTUALENV_OPTIONS=()
|
||||||
|
|
||||||
unset FORCE
|
unset FORCE
|
||||||
unset NO_ENSUREPIP
|
unset VIRTUALENV_PYTHON
|
||||||
unset QUIET
|
unset QUIET
|
||||||
unset UPGRADE
|
unset UPGRADE
|
||||||
unset VERBOSE
|
unset VERBOSE
|
||||||
unset VIRTUALENV_PYTHON
|
|
||||||
|
|
||||||
parse_options "$@"
|
parse_options "$@"
|
||||||
for option in "${OPTIONS[@]}"; do
|
for option in "${OPTIONS[@]}"; do
|
||||||
@@ -240,14 +267,6 @@ for option in "${OPTIONS[@]}"; do
|
|||||||
"h" | "help" )
|
"h" | "help" )
|
||||||
usage 0
|
usage 0
|
||||||
;;
|
;;
|
||||||
"no-pip" )
|
|
||||||
NO_ENSUREPIP=1
|
|
||||||
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--$option"
|
|
||||||
;;
|
|
||||||
"no-setuptools" )
|
|
||||||
NO_ENSUREPIP=1
|
|
||||||
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--$option"
|
|
||||||
;;
|
|
||||||
"p" | "python" )
|
"p" | "python" )
|
||||||
VIRTUALENV_PYTHON="${ARGUMENTS[0]}"
|
VIRTUALENV_PYTHON="${ARGUMENTS[0]}"
|
||||||
ARGUMENTS=("${ARGUMENTS[@]:1}") # shift 1
|
ARGUMENTS=("${ARGUMENTS[@]:1}") # shift 1
|
||||||
@@ -265,10 +284,6 @@ for option in "${OPTIONS[@]}"; do
|
|||||||
version
|
version
|
||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
"without-pip" )
|
|
||||||
NO_ENSUREPIP=1
|
|
||||||
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--$option"
|
|
||||||
;;
|
|
||||||
* ) # virtualenv long options
|
* ) # virtualenv long options
|
||||||
if [[ "$option" == "python="* ]]; then
|
if [[ "$option" == "python="* ]]; then
|
||||||
VIRTUALENV_PYTHON="${option#python=}"
|
VIRTUALENV_PYTHON="${option#python=}"
|
||||||
@@ -284,46 +299,23 @@ if [[ "${#ARGUMENTS[@]}" == 0 ]]; then
|
|||||||
exit 1
|
exit 1
|
||||||
elif [[ "${#ARGUMENTS[@]}" == 1 ]]; then
|
elif [[ "${#ARGUMENTS[@]}" == 1 ]]; then
|
||||||
# If only one argument given, use current version as source version
|
# If only one argument given, use current version as source version
|
||||||
OLDIFS="${IFS}"
|
VERSION_NAME="$(pyenv-version-name)"
|
||||||
IFS=:
|
|
||||||
VERSION_NAMES=($(pyenv-version-name))
|
|
||||||
IFS="${OLDIFS}"
|
|
||||||
VERSION_NAME="${VERSION_NAMES}"
|
|
||||||
VIRTUALENV_NAME="${ARGUMENTS[0]}"
|
VIRTUALENV_NAME="${ARGUMENTS[0]}"
|
||||||
else
|
else
|
||||||
# Otherwise, use former as source version, and latter as virtualenv version
|
# Otherwise, use former as source version, and latter as virtualenv version
|
||||||
VERSION_NAME="${ARGUMENTS[0]}"
|
VERSION_NAME="${ARGUMENTS[0]}"
|
||||||
VIRTUALENV_NAME="${ARGUMENTS[1]}"
|
VIRTUALENV_NAME="${ARGUMENTS[1]##*/}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -z "${VERSION_NAME}" ] || [ -z "${VIRTUALENV_NAME}" ]; then
|
if [ -z "${VERSION_NAME}" ] || [ -z "${VIRTUALENV_NAME}" ]; then
|
||||||
usage 1
|
usage 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "${VIRTUALENV_NAME##*/}" == "system" ]]; then
|
|
||||||
echo "pyenv-virtualenv: \`system' is not allowed as virtualenv name." 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$VIRTUALENV_NAME" != "${VIRTUALENV_NAME%[[:space:]]*}" ]; then
|
|
||||||
echo "pyenv-virtualenv: no whitespace allowed in virtualenv name." 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "${VIRTUALENV_NAME}" != "${VIRTUALENV_NAME%/*}" ] && [[ "${VIRTUALENV_NAME}" != "${VERSION_NAME%%/*}/envs/${VIRTUALENV_NAME##*/}" ]] ; then
|
|
||||||
echo "pyenv-virtualenv: no slash allowed in virtualenv name." 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Set VERSION_NAME as default version in this script
|
# Set VERSION_NAME as default version in this script
|
||||||
export PYENV_VERSION="${VERSION_NAME}"
|
export PYENV_VERSION="${VERSION_NAME}"
|
||||||
|
|
||||||
# Source version must exist before creating virtualenv.
|
# Source version must exists before creating virtualenv
|
||||||
PREFIX="$(pyenv-prefix 2>/dev/null || true)"
|
pyenv-prefix 1>/dev/null 2>&1 || usage 1
|
||||||
if [ ! -d "${PREFIX}" ]; then
|
|
||||||
echo "pyenv-virtualenv: \`${PYENV_VERSION}' is not installed in pyenv." 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$TMPDIR" ]; then
|
if [ -z "$TMPDIR" ]; then
|
||||||
TMP="/tmp"
|
TMP="/tmp"
|
||||||
@@ -331,130 +323,40 @@ else
|
|||||||
TMP="${TMPDIR%/}"
|
TMP="${TMPDIR%/}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Not create `system/envs` directory even if source version is `system`
|
SEED="$(date "+%Y%m%d%H%M%S").$$"
|
||||||
if [[ "${VERSION_NAME%/envs/*}" == "system" ]]; then
|
UPGRADE_PATH="${TMP}/pyenv-virtualenv.${SEED}"
|
||||||
VIRTUALENV_NAME="${VIRTUALENV_NAME##*/}"
|
UPGRADE_LIST="${TMP}/pyenv-virtualenv.${SEED}.txt"
|
||||||
else
|
|
||||||
VIRTUALENV_PREFIX="$(pyenv-virtualenv-prefix 2>/dev/null || true)"
|
|
||||||
if [[ "${VIRTUALENV_PREFIX%/*}" == "${PYENV_ROOT}/versions" ]]; then
|
|
||||||
VIRTUALENV_NAME="${VIRTUALENV_PREFIX#${PYENV_ROOT}/versions/}/envs/${VIRTUALENV_NAME##*/}"
|
|
||||||
else
|
|
||||||
VIRTUALENV_NAME="${VERSION_NAME}/envs/${VIRTUALENV_NAME##*/}"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
VIRTUALENV_PATH="${PYENV_ROOT}/versions/${VIRTUALENV_NAME}"
|
VIRTUALENV_PATH="${PYENV_ROOT}/versions/${VIRTUALENV_NAME}"
|
||||||
if [[ "${VIRTUALENV_PATH/*/envs/*}" != "${PYENV_ROOT}/versions" ]]; then
|
|
||||||
COMPAT_VIRTUALENV_PATH="${PYENV_ROOT}/versions/${VIRTUALENV_NAME##*/}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "${COMPAT_VIRTUALENV_PATH}" ]; then
|
|
||||||
if [ -e "${COMPAT_VIRTUALENV_PATH}" ] || [ -L "${COMPAT_VIRTUALENV_PATH}" ]; then
|
|
||||||
echo "pyenv-virtualenv: \`${COMPAT_VIRTUALENV_PATH}' already exists." 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
unset HAS_VIRTUALENV
|
unset HAS_VIRTUALENV
|
||||||
unset HAS_M_VENV
|
unset HAS_PYVENV
|
||||||
unset USE_CONDA
|
unset USE_PYVENV
|
||||||
unset USE_M_VENV
|
|
||||||
detect_venv
|
detect_venv
|
||||||
|
|
||||||
SEED="$(date "+%Y%m%d%H%M%S").$$"
|
if [ -n "${USE_PYVENV}" ]; then
|
||||||
VIRTUALENV_ORIG="${VIRTUALENV_PATH}.${SEED}"
|
# Unset some arguments not supported by pyvenv
|
||||||
REQUIREMENTS="${TMP}/requirements.${SEED}.txt"
|
unset QUIET
|
||||||
|
unset VERBOSE
|
||||||
# Upgrade existing virtualenv
|
|
||||||
if [ -n "$UPGRADE" ]; then
|
if [ -n "$UPGRADE" ]; then
|
||||||
FORCE=1
|
|
||||||
# `python -m venv` has `--upgrade` by default
|
|
||||||
if [ -n "${USE_M_VENV}" ]; then
|
|
||||||
unset UPGRADE
|
unset UPGRADE
|
||||||
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--upgrade"
|
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--upgrade"
|
||||||
fi
|
fi
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "${VIRTUALENV_VERSION}" ]; then
|
|
||||||
case "${PYENV_VERSION}" in
|
|
||||||
"3.0"* )
|
|
||||||
NO_ENSUREPIP=1
|
|
||||||
;;
|
|
||||||
"3.1"* )
|
|
||||||
NO_ENSUREPIP=1
|
|
||||||
;;
|
|
||||||
"3.2"* | "stackless-3.2"* )
|
|
||||||
# pip 8.x (bundled with virtualenv 14+) doesn't support 3.2 anymore
|
|
||||||
# https://github.com/yyuu/pyenv/issues/531
|
|
||||||
VIRTUALENV_VERSION="13.1.2"
|
|
||||||
NO_ENSUREPIP=1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "${USE_CONDA}" ]; then
|
|
||||||
# e.g. `conda create -n py35 python=3.5 anaconda`
|
|
||||||
if [ -n "${VIRTUALENV_PYTHON}" ]; then
|
|
||||||
VIRTUALENV_PYTHON="${VIRTUALENV_PYTHON##*/}"
|
|
||||||
VIRTUALENV_PYTHON="${VIRTUALENV_PYTHON#python}"
|
|
||||||
if [ -n "${VIRTUALENV_PYTHON}" ]; then
|
|
||||||
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="python=${VIRTUALENV_PYTHON}"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
if [ -n "${USE_M_VENV}" ]; then
|
|
||||||
# Unset some arguments not supported by `python -m venv`
|
|
||||||
unset QUIET
|
|
||||||
unset VERBOSE
|
|
||||||
if [ -n "${VIRTUALENV_PYTHON}" ]; then
|
|
||||||
echo "pyenv-virtualenv: \`--python=${VIRTUALENV_PYTHON}' is not supported by \`python -m venv'." 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
if [ -n "${VIRTUALENV_PYTHON}" ]; then
|
if [ -n "${VIRTUALENV_PYTHON}" ]; then
|
||||||
if [[ "${VIRTUALENV_PYTHON}" == "${VIRTUALENV_PYTHON##*/}" ]] || [[ "${VIRTUALENV_PYTHON}" == "${PYENV_ROOT}/shims/"* ]]; then
|
|
||||||
python="$(pyenv-which "${VIRTUALENV_PYTHON##*/}" 2>/dev/null || true)"
|
|
||||||
if [ -x "${python}" ]; then
|
|
||||||
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--python=${python}"
|
|
||||||
else
|
|
||||||
python="$(PYENV_VERSION="$(pyenv-whence "${VIRTUALENV_PYTHON##*/}" 2>/dev/null | tail -n 1 || true)" pyenv-which "${VIRTUALENV_PYTHON##*/}" 2>/dev/null || true)"
|
|
||||||
if [ -x "${python}" ]; then
|
|
||||||
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--python=${python}"
|
|
||||||
else
|
|
||||||
echo "pyenv-virtualenv: \`${VIRTUALENV_PYTHON##*/}' is not installed in pyenv." 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--python=${VIRTUALENV_PYTHON}"
|
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--python=${VIRTUALENV_PYTHON}"
|
||||||
fi
|
fi
|
||||||
fi
|
|
||||||
if [ -z "${HAS_VIRTUALENV}" ]; then
|
if [ -z "${HAS_VIRTUALENV}" ]; then
|
||||||
if [ -n "${VIRTUALENV_VERSION}" ]; then
|
install_virtualenv "${PYENV_VERSION}"
|
||||||
virtualenv_spec="virtualenv==${VIRTUALENV_VERSION}"
|
|
||||||
else
|
|
||||||
virtualenv_spec="virtualenv"
|
|
||||||
fi
|
|
||||||
pyenv-exec pip install $QUIET $VERBOSE "${virtualenv_spec}"
|
|
||||||
HAS_VIRTUALENV=1
|
HAS_VIRTUALENV=1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
|
||||||
|
|
||||||
# Unset environment variables which start with `VIRTUALENV_`.
|
# Unset environment variables which starts with `VIRTUALENV_`.
|
||||||
# These variables are reserved for virtualenv.
|
# These variables are reserved for virtualenv.
|
||||||
unset VIRTUALENV_VERSION
|
unset VIRTUALENV_VERSION
|
||||||
|
|
||||||
|
|
||||||
# Download specified version of ez_setup.py/get-pip.py.
|
|
||||||
if [ -n "${SETUPTOOLS_VERSION}" ]; then
|
|
||||||
EZ_SETUP_URL="https://bitbucket.org/pypa/setuptools/raw/${SETUPTOOLS_VERSION}/ez_setup.py"
|
|
||||||
fi
|
|
||||||
if [ -n "${PIP_VERSION}" ]; then
|
|
||||||
GET_PIP_URL="https://raw.githubusercontent.com/pypa/pip/${PIP_VERSION}/contrib/get-pip.py"
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
# Define `before_virtualenv` and `after_virtualenv` functions that allow
|
# Define `before_virtualenv` and `after_virtualenv` functions that allow
|
||||||
# plugin hooks to register a string of code for execution before or
|
# plugin hooks to register a string of code for execution before or
|
||||||
# after the installation process.
|
# after the installation process.
|
||||||
@@ -493,12 +395,7 @@ if [ -d "${VIRTUALENV_PATH}/bin" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -n "$UPGRADE" ]; then
|
if [ -n "$UPGRADE" ]; then
|
||||||
if [ -n "${NO_ENSUREPIP}" ]; then
|
prepare_upgrade "${VIRTUALENV_NAME}" "${VIRTUALENV_PATH}"
|
||||||
echo "pyenv-virtualenv: upgrading will not work with --no-setuptools or --no-pip" 1>&2
|
|
||||||
exit 1
|
|
||||||
else
|
|
||||||
PYENV_VERSION="${VIRTUALENV_NAME}" prepare_requirements
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -514,34 +411,18 @@ trap cleanup SIGINT
|
|||||||
|
|
||||||
# Invoke virtualenv and record exit status in $STATUS.
|
# Invoke virtualenv and record exit status in $STATUS.
|
||||||
STATUS=0
|
STATUS=0
|
||||||
# virtualenv may download distribute/setuptools into the current directory.
|
# virtualenv may download distribute/setuptools in current directory.
|
||||||
# Change to cache directory to reuse them between invocations.
|
# change to cache directory to reuse them between invocation.
|
||||||
mkdir -p "${PYENV_VIRTUALENV_CACHE_PATH}"
|
mkdir -p "${PYENV_VIRTUALENV_CACHE_PATH}"
|
||||||
cd "${PYENV_VIRTUALENV_CACHE_PATH}"
|
cd "${PYENV_VIRTUALENV_CACHE_PATH}"
|
||||||
if [ -n "${USE_CONDA}" ]; then
|
venv $QUIET $VERBOSE "${VIRTUALENV_OPTIONS[@]}" "${VIRTUALENV_PATH}" || STATUS="$?"
|
||||||
pyenv-exec conda create $QUIET $VERBOSE --name "${VIRTUALENV_PATH##*/}" --yes "${VIRTUALENV_OPTIONS[@]}" python || STATUS="$?"
|
|
||||||
else
|
## Migrate previously installed packages from requirements.txt
|
||||||
if [ -n "${USE_M_VENV}" ]; then
|
if [ -n "$UPGRADE" ]; then
|
||||||
pyenv-exec python -m venv $QUIET $VERBOSE "${VIRTUALENV_OPTIONS[@]}" "${VIRTUALENV_PATH}" || STATUS="$?"
|
upgrade "${VIRTUALENV_NAME}" "${VIRTUALENV_PATH}" || STATUS="$?"
|
||||||
else
|
|
||||||
pyenv-exec virtualenv $QUIET $VERBOSE "${VIRTUALENV_OPTIONS[@]}" "${VIRTUALENV_PATH}" || STATUS="$?"
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
## Create symlink in the `versions` directory for backward compatibility
|
# Execute `after_virtualenv` hooks
|
||||||
if [ -d "${VIRTUALENV_PATH}" ] && [ -n "${COMPAT_VIRTUALENV_PATH}" ]; then
|
|
||||||
ln -fs "${VIRTUALENV_PATH}" "${COMPAT_VIRTUALENV_PATH}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "${NO_ENSUREPIP}" ]; then
|
|
||||||
## Install setuptools and pip.
|
|
||||||
PYENV_VERSION="${VIRTUALENV_NAME}" build_package_ensurepip
|
|
||||||
|
|
||||||
## Migrate previously installed packages from requirements.txt.
|
|
||||||
PYENV_VERSION="${VIRTUALENV_NAME}" install_requirements || true
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Execute `after_virtualenv` hooks.
|
|
||||||
for hook in "${after_hooks[@]}"; do eval "$hook"; done
|
for hook in "${after_hooks[@]}"; do eval "$hook"; done
|
||||||
|
|
||||||
# Run `pyenv-rehash` after a successful installation.
|
# Run `pyenv-rehash` after a successful installation.
|
||||||
|
|||||||
@@ -1,104 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
#
|
|
||||||
# Summary: Uninstall a specific Python virtualenv
|
|
||||||
#
|
|
||||||
# Usage: pyenv virtualenv-delete [-f|--force] <virtualenv>
|
|
||||||
#
|
|
||||||
# -f Attempt to remove the specified virtualenv without prompting
|
|
||||||
# for confirmation. If the virtualenv does not exist, do not
|
|
||||||
# display an error message.
|
|
||||||
#
|
|
||||||
# See `pyenv virtualenvs` for a complete list of installed versions.
|
|
||||||
#
|
|
||||||
set -e
|
|
||||||
[ -n "$PYENV_DEBUG" ] && set -x
|
|
||||||
|
|
||||||
if [ -z "${PYENV_ROOT}" ]; then
|
|
||||||
PYENV_ROOT="$(pyenv-root)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Provide pyenv completions
|
|
||||||
if [ "$1" = "--complete" ]; then
|
|
||||||
exec pyenv virtualenvs --bare
|
|
||||||
fi
|
|
||||||
|
|
||||||
resolve_link() {
|
|
||||||
$(type -p greadlink readlink | head -1) "$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
usage() {
|
|
||||||
pyenv-help virtualenv-delete 2>/dev/null
|
|
||||||
[ -z "$1" ] || exit "$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
if [ -z "$PYENV_ROOT" ]; then
|
|
||||||
PYENV_ROOT="${HOME}/.pyenv"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$1" = "-h" ] || [ "$1" = "--help" ]; then
|
|
||||||
usage 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
unset FORCE
|
|
||||||
if [ "$1" = "-f" ] || [ "$1" = "--force" ]; then
|
|
||||||
FORCE=true
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
[ "$#" -eq 1 ] || usage 1 >&2
|
|
||||||
|
|
||||||
DEFINITION="$1"
|
|
||||||
case "$DEFINITION" in
|
|
||||||
"" | -* )
|
|
||||||
usage 1 >&2
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
VERSION_NAME="${DEFINITION##*/}"
|
|
||||||
COMPAT_PREFIX="${PYENV_ROOT}/versions/${VERSION_NAME}"
|
|
||||||
|
|
||||||
if [[ "${DEFINITION}" != "${DEFINITION%/envs/*}" ]]; then
|
|
||||||
PREFIX="${PYENV_ROOT}/versions/${DEFINITION}"
|
|
||||||
if [ -L "${COMPAT_PREFIX}" ]; then
|
|
||||||
if [[ "${PREFIX}" != "$(resolve_link "${COMPAT_PREFIX}" 2>/dev/null || true)" ]]; then
|
|
||||||
unset COMPAT_PREFIX
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
if [ -L "${COMPAT_PREFIX}" ]; then
|
|
||||||
PREFIX="$(resolve_link "${COMPAT_PREFIX}" 2>/dev/null || true)"
|
|
||||||
if [[ "${PREFIX%/*/envs/*}" != "${PYENV_ROOT}/versions" ]]; then
|
|
||||||
echo "pyenv-virtualenv: \`${COMPAT_PREFIX}' is a symlink for unknown location." 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
if pyenv-virtualenv-prefix "${VERSION_NAME}" 1>/dev/null 2>&1; then
|
|
||||||
PREFIX="${PYENV_ROOT}/versions/${VERSION_NAME}"
|
|
||||||
unset COMPAT_PREFIX
|
|
||||||
else
|
|
||||||
echo "pyenv-virtualenv: \`${DEFINITION}' is not a virtualenv." 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$FORCE" ]; then
|
|
||||||
if [ ! -d "$PREFIX" ]; then
|
|
||||||
echo "pyenv-virtualenv: virtualenv \`$VERSION_NAME' not installed" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
read -p "pyenv-virtualenv: remove $PREFIX? "
|
|
||||||
case "$REPLY" in
|
|
||||||
y* | Y* ) ;;
|
|
||||||
* ) exit 1 ;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -d "$PREFIX" ]; then
|
|
||||||
rm -rf "$PREFIX"
|
|
||||||
if [ -L "$COMPAT_PREFIX" ]; then
|
|
||||||
rm -rf "$COMPAT_PREFIX"
|
|
||||||
fi
|
|
||||||
pyenv-rehash
|
|
||||||
fi
|
|
||||||
@@ -1,159 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
# Summary: Configure the shell environment for pyenv-virtualenv
|
|
||||||
# Usage: eval "$(pyenv virtualenv-init - [<shell>])"
|
|
||||||
#
|
|
||||||
# Automatically activates a Python virtualenv environment based on current
|
|
||||||
# pyenv version.
|
|
||||||
#
|
|
||||||
|
|
||||||
set -e
|
|
||||||
[ -n "$PYENV_DEBUG" ] && set -x
|
|
||||||
|
|
||||||
resolve_link() {
|
|
||||||
$(type -p greadlink readlink | head -1) "$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
abs_dirname() {
|
|
||||||
local cwd="$(pwd)"
|
|
||||||
local path="$1"
|
|
||||||
|
|
||||||
while [ -n "$path" ]; do
|
|
||||||
cd "${path%/*}"
|
|
||||||
local name="${path##*/}"
|
|
||||||
path="$(resolve_link "$name" || true)"
|
|
||||||
done
|
|
||||||
|
|
||||||
pwd
|
|
||||||
cd "$cwd"
|
|
||||||
}
|
|
||||||
|
|
||||||
PYENV_VIRTUALENV_INSTALL_PREFIX="$(dirname "$(abs_dirname "$0")")"
|
|
||||||
|
|
||||||
print=""
|
|
||||||
for args in "$@"
|
|
||||||
do
|
|
||||||
if [ "$args" = "-" ]; then
|
|
||||||
print=1
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
shell="${1:-$PYENV_SHELL}"
|
|
||||||
if [ -z "$shell" ]; then
|
|
||||||
shell="$(ps -p "$PPID" -o 'args=' 2>/dev/null || true)"
|
|
||||||
shell="${shell##-}"
|
|
||||||
shell="${shell%% *}"
|
|
||||||
shell="${shell:-$SHELL}"
|
|
||||||
shell="${shell##*/}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$print" ]; then
|
|
||||||
case "$shell" in
|
|
||||||
bash )
|
|
||||||
profile='~/.bash_profile'
|
|
||||||
;;
|
|
||||||
zsh )
|
|
||||||
profile='~/.zshrc'
|
|
||||||
;;
|
|
||||||
ksh )
|
|
||||||
profile='~/.profile'
|
|
||||||
;;
|
|
||||||
fish )
|
|
||||||
profile='~/.config/fish/config.fish'
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
profile='your profile'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
{ echo "# Load pyenv-virtualenv automatically by adding"
|
|
||||||
echo "# the following to ${profile}:"
|
|
||||||
echo
|
|
||||||
case "$shell" in
|
|
||||||
fish )
|
|
||||||
echo 'status --is-interactive; and source (pyenv virtualenv-init -|psub)'
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
echo 'eval "$(pyenv virtualenv-init -)"'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
echo
|
|
||||||
} >&2
|
|
||||||
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$shell" in
|
|
||||||
fish )
|
|
||||||
cat <<EOS
|
|
||||||
set -gx PATH '${PYENV_VIRTUALENV_ROOT:-${PYENV_VIRTUALENV_INSTALL_PREFIX}}/shims' \$PATH;
|
|
||||||
set -gx PYENV_VIRTUALENV_INIT 1;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
export PATH="${PYENV_VIRTUALENV_ROOT:-${PYENV_VIRTUALENV_INSTALL_PREFIX}}/shims:\${PATH}";
|
|
||||||
export PYENV_VIRTUALENV_INIT=1;
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
case "$shell" in
|
|
||||||
fish )
|
|
||||||
cat <<EOS
|
|
||||||
function _pyenv_virtualenv_hook --on-event fish_prompt;
|
|
||||||
set -l ret \$status
|
|
||||||
if [ -n "\$VIRTUAL_ENV" ]
|
|
||||||
pyenv activate --quiet; or pyenv deactivate --quiet; or true
|
|
||||||
else
|
|
||||||
pyenv activate --quiet; or true
|
|
||||||
end
|
|
||||||
return \$ret
|
|
||||||
end
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
ksh )
|
|
||||||
cat <<EOS
|
|
||||||
function _pyenv_virtualenv_hook() {
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
cat <<EOS
|
|
||||||
_pyenv_virtualenv_hook() {
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [[ "$shell" != "fish" ]]; then
|
|
||||||
cat <<EOS
|
|
||||||
local ret=\$?
|
|
||||||
if [ -n "\$VIRTUAL_ENV" ]; then
|
|
||||||
eval "\$(pyenv sh-activate --quiet || pyenv sh-deactivate --quiet || true)" || true
|
|
||||||
else
|
|
||||||
eval "\$(pyenv sh-activate --quiet || true)" || true
|
|
||||||
fi
|
|
||||||
return \$ret
|
|
||||||
};
|
|
||||||
EOS
|
|
||||||
|
|
||||||
case "$shell" in
|
|
||||||
bash )
|
|
||||||
cat <<EOS
|
|
||||||
if ! [[ "\$PROMPT_COMMAND" =~ _pyenv_virtualenv_hook ]]; then
|
|
||||||
PROMPT_COMMAND="_pyenv_virtualenv_hook;\$PROMPT_COMMAND";
|
|
||||||
fi
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
zsh )
|
|
||||||
cat <<EOS
|
|
||||||
typeset -g -a precmd_functions
|
|
||||||
if [[ -z \$precmd_functions[(r)_pyenv_virtualenv_hook] ]]; then
|
|
||||||
precmd_functions=(_pyenv_virtualenv_hook \$precmd_functions);
|
|
||||||
fi
|
|
||||||
EOS
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
# FIXME: what should i do here??
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
@@ -19,56 +19,27 @@ else
|
|||||||
IFS=: versions=($(pyenv-version-name))
|
IFS=: versions=($(pyenv-version-name))
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
real_prefix() { # virtualenv
|
||||||
|
local version="$1"
|
||||||
|
PYENV_VERSION="${version}" pyenv-exec python -c 'import sys;print(sys.real_prefix)' 2>/dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
base_prefix() { # pyvenv
|
||||||
|
# FIXME: non-pyvenv versions also have sys.base_prefix
|
||||||
|
local version="$1"
|
||||||
|
PYENV_VERSION="${version}" pyenv-exec python -c 'import sys;print(sys.base_prefix)' 2>/dev/null
|
||||||
|
}
|
||||||
|
|
||||||
VIRTUALENV_PREFIX_PATHS=()
|
VIRTUALENV_PREFIX_PATHS=()
|
||||||
for version in "${versions[@]}"; do
|
for version in "${versions[@]}"; do
|
||||||
if [ "$version" = "system" ]; then
|
PREFIX="$(pyenv-prefix "${version}")"
|
||||||
echo "pyenv-virtualenv: version \`${version}' is not a virtualenv" 1>&2
|
if [ -f "${PREFIX}/bin/activate" ]; then
|
||||||
exit 1
|
VIRTUALENV_PREFIX_PATH="$(real_prefix "${version}" || base_prefix "${version}" || true)"
|
||||||
fi
|
VIRTUALENV_PREFIX_PATHS=("${VIRTUALENV_PREFIX_PATHS[@]}" "$VIRTUALENV_PREFIX_PATH")
|
||||||
PYENV_PREFIX_PATH="$(pyenv-prefix "${version}")"
|
|
||||||
if [ -x "${PYENV_PREFIX_PATH}/bin/python" ]; then
|
|
||||||
if [ -f "${PYENV_PREFIX_PATH}/bin/activate" ]; then
|
|
||||||
if [ -f "${PYENV_PREFIX_PATH}/bin/conda" ]; then
|
|
||||||
# conda
|
|
||||||
VIRTUALENV_PREFIX_PATH="${PYENV_PREFIX_PATH}"
|
|
||||||
else
|
|
||||||
if [ -f "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" ]; then
|
|
||||||
# venv
|
|
||||||
virtualenv_binpath="$(cut -b 1-1024 "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" | sed -n '/^ *home *= */s///p' || true)"
|
|
||||||
VIRTUALENV_PREFIX_PATH="${virtualenv_binpath%/bin}"
|
|
||||||
else
|
|
||||||
# virtualenv
|
|
||||||
if [ -d "${PYENV_ROOT}/versions/${version}/Lib" ]; then
|
|
||||||
# jython
|
|
||||||
virtualenv_libpath="${PYENV_ROOT}/versions/${version}/Lib"
|
|
||||||
else
|
|
||||||
if [ -d "${PYENV_ROOT}/versions/${version}/lib-python" ]; then
|
|
||||||
# pypy
|
|
||||||
virtualenv_libpath="${PYENV_ROOT}/versions/${version}/lib-python"
|
|
||||||
else
|
|
||||||
virtualenv_libpath="${PYENV_ROOT}/versions/${version}/lib"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
virtualenv_orig_prefix="$(find "${virtualenv_libpath}/" -maxdepth 2 -type f -and -name "orig-prefix.txt" 2>/dev/null | head -1)"
|
|
||||||
if [ -f "${virtualenv_orig_prefix}" ]; then
|
|
||||||
VIRTUALENV_PREFIX_PATH="$(cat "${virtualenv_orig_prefix}" 2>/dev/null || true)"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
if [ -d "${VIRTUALENV_PREFIX_PATH}" ]; then
|
|
||||||
VIRTUALENV_PREFIX_PATHS=("${VIRTUALENV_PREFIX_PATHS[@]}" "${VIRTUALENV_PREFIX_PATH:-${PYENV_PREFIX_PATH}}")
|
|
||||||
else
|
else
|
||||||
echo "pyenv-virtualenv: version \`${version}' is not a virtualenv" 1>&2
|
echo "pyenv-virtualenv: version \`${version}' is not a virtualenv" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
else
|
|
||||||
echo "pyenv-virtualenv: version \`${version}' is not a virtualenv" 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "pyenv-virtualenv: \`python' not found in version \`${version}'" 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
|
|
||||||
IFS=: echo "${VIRTUALENV_PREFIX_PATHS[*]}"
|
IFS=: echo "${VIRTUALENV_PREFIX_PATHS[*]}"
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
#
|
#
|
||||||
# Summary: List all Python virtualenvs found in `$PYENV_ROOT/versions/*'.
|
# Summary: List all Python virtualenvs found in `$PYENV_ROOT/versions/*'.
|
||||||
# Usage: pyenv virtualenvs [--bare] [--skip-aliases]
|
|
||||||
#
|
#
|
||||||
# List all virtualenvs found in `$PYENV_ROOT/versions/*' and its `$PYENV_ROOT/versions/envs/*'.
|
# Usage: pyenv virtualenvs [--bare]
|
||||||
|
#
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
[ -n "$PYENV_DEBUG" ] && set -x
|
[ -n "$PYENV_DEBUG" ] && set -x
|
||||||
@@ -12,124 +12,45 @@ if [ -z "$PYENV_ROOT" ]; then
|
|||||||
PYENV_ROOT="${HOME}/.pyenv"
|
PYENV_ROOT="${HOME}/.pyenv"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
unset bare
|
if [ "$1" = "--bare" ]; then
|
||||||
unset skip_aliases
|
|
||||||
# Provide pyenv completions
|
|
||||||
for arg; do
|
|
||||||
case "$arg" in
|
|
||||||
--complete )
|
|
||||||
echo --bare
|
|
||||||
echo --skip-aliases
|
|
||||||
exit ;;
|
|
||||||
--bare ) bare=1 ;;
|
|
||||||
--skip-aliases ) skip_aliases=1 ;;
|
|
||||||
* )
|
|
||||||
pyenv-help --usage virtualenvs >&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
versions_dir="${PYENV_ROOT}/versions"
|
|
||||||
|
|
||||||
if ! enable -f "${BASH_SOURCE%/*}"/../libexec/pyenv-realpath.dylib realpath 2>/dev/null; then
|
|
||||||
if [ -n "$PYENV_NATIVE_EXT" ]; then
|
|
||||||
echo "pyenv: failed to load \`realpath' builtin" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
READLINK=$(type -p greadlink readlink | head -1)
|
|
||||||
if [ -z "$READLINK" ]; then
|
|
||||||
echo "pyenv: cannot find readlink - are you missing GNU coreutils?" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
resolve_link() {
|
|
||||||
$READLINK "$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
realpath() {
|
|
||||||
local cwd="$PWD"
|
|
||||||
local path="$1"
|
|
||||||
local name
|
|
||||||
|
|
||||||
while [ -n "$path" ]; do
|
|
||||||
name="${path##*/}"
|
|
||||||
[ "$name" = "$path" ] || cd "${path%/*}"
|
|
||||||
path="$(resolve_link "$name" || true)"
|
|
||||||
done
|
|
||||||
|
|
||||||
echo "${PWD}/$name"
|
|
||||||
cd "$cwd"
|
|
||||||
}
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -d "$versions_dir" ]; then
|
|
||||||
versions_dir="$(realpath "$versions_dir")"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "$bare" ]; then
|
|
||||||
hit_prefix=""
|
hit_prefix=""
|
||||||
miss_prefix=""
|
miss_prefix=""
|
||||||
current_versions=()
|
current_versions=()
|
||||||
unset print_origin
|
print_origin=""
|
||||||
include_system=""
|
|
||||||
else
|
else
|
||||||
hit_prefix="* "
|
hit_prefix="* "
|
||||||
miss_prefix=" "
|
miss_prefix=" "
|
||||||
OLDIFS="$IFS"
|
current_versions=($(IFS=:; for version in $(pyenv-version-name); do echo "$version"; done))
|
||||||
IFS=: current_versions=($(pyenv-version-name || true))
|
|
||||||
IFS="$OLDIFS"
|
|
||||||
print_origin="1"
|
print_origin="1"
|
||||||
include_system=""
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
num_versions=0
|
array_exists() {
|
||||||
|
local x car="$1"
|
||||||
exists() {
|
|
||||||
local car="$1"
|
|
||||||
local cdar
|
|
||||||
shift
|
shift
|
||||||
for cdar in "$@"; do
|
for x in "$@"; do
|
||||||
if [ "${car}" == "${cdar}" ]; then
|
[ "${x}" = "${car}" ] && return 0
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
print_version() {
|
print_version() {
|
||||||
if exists "$1" "${current_versions[@]}"; then
|
if [ -n "${print_origin}" ]; then
|
||||||
echo "${hit_prefix}${1}${print_origin+$2}"
|
local version_origin="$2"
|
||||||
else
|
else
|
||||||
echo "${miss_prefix}${1}${print_origin+$2}"
|
local version_origin=""
|
||||||
|
fi
|
||||||
|
if array_exists "$1" "${current_versions[@]}"; then
|
||||||
|
echo "${hit_prefix}${1}${version_origin}"
|
||||||
|
else
|
||||||
|
echo "${miss_prefix}${1}${version_origin}"
|
||||||
fi
|
fi
|
||||||
num_versions=$((num_versions + 1))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
shopt -s nullglob
|
for version in $(pyenv-versions --bare); do
|
||||||
for path in "$versions_dir"/*; do
|
if [[ "${version}" != "system" ]]; then
|
||||||
if [ -d "$path" ]; then
|
virtualenv_prefix="$(pyenv-virtualenv-prefix "${version}" 2>/dev/null || true)"
|
||||||
if [ -n "$skip_aliases" ] && [ -L "$path" ]; then
|
|
||||||
target="$(realpath "$path")"
|
|
||||||
[ "${target%/*/envs/*}" != "$versions_dir" ] || continue
|
|
||||||
fi
|
|
||||||
virtualenv_prefix="$(pyenv-virtualenv-prefix "${path##*/}" 2>/dev/null || true)"
|
|
||||||
if [ -d "${virtualenv_prefix}" ]; then
|
if [ -d "${virtualenv_prefix}" ]; then
|
||||||
print_version "${path##*/}" " (created from ${virtualenv_prefix})"
|
print_version "${version}" " (created from ${virtualenv_prefix})"
|
||||||
fi
|
fi
|
||||||
for venv_path in "${path}/envs/"*; do
|
|
||||||
venv="${path##*/}/envs/${venv_path##*/}"
|
|
||||||
virtualenv_prefix="$(pyenv-virtualenv-prefix "${venv}" 2>/dev/null || true)"
|
|
||||||
if [ -d "${virtualenv_prefix}" ]; then
|
|
||||||
print_version "${venv}" " (created from ${virtualenv_prefix})"
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
fi
|
|
||||||
done
|
|
||||||
shopt -u nullglob
|
|
||||||
|
|
||||||
if [ "$num_versions" -eq 0 ] && [ -n "$include_system" ]; then
|
|
||||||
echo "Warning: no Python virtualenv detected on the system" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|||||||
@@ -1,11 +0,0 @@
|
|||||||
virtualenv_list_executable_names() {
|
|
||||||
local file
|
|
||||||
shopt -s nullglob
|
|
||||||
for file in "$PYENV_ROOT"/versions/*/envs/*/bin/*; do
|
|
||||||
echo "${file##*/}"
|
|
||||||
done
|
|
||||||
shopt -u nullglob
|
|
||||||
}
|
|
||||||
if declare -f make_shims 1>/dev/null 2>&1; then
|
|
||||||
make_shims $(virtualenv_list_executable_names | sort -u)
|
|
||||||
fi
|
|
||||||
@@ -1,30 +0,0 @@
|
|||||||
resolve_link() {
|
|
||||||
$(type -p greadlink readlink | head -1) "$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
if [ -n "${DEFINITION}" ]; then
|
|
||||||
if [[ "${DEFINITION}" != "${DEFINITION%/envs/*}" ]]; then
|
|
||||||
# Uninstall virtualenv by long name
|
|
||||||
exec pyenv-virtualenv-delete ${FORCE+-f} "${DEFINITION}"
|
|
||||||
exit 128
|
|
||||||
else
|
|
||||||
VERSION_NAME="${VERSION_NAME:-${DEFINITION##*/}}"
|
|
||||||
PREFIX="${PREFIX:-${PYENV_ROOT}/versions/${VERSION_NAME}}"
|
|
||||||
if [ -L "${PREFIX}" ]; then
|
|
||||||
REAL_PREFIX="$(resolve_link "${PREFIX}" 2>/dev/null || true)"
|
|
||||||
REAL_DEFINITION="${REAL_PREFIX#${PYENV_ROOT}/versions/}"
|
|
||||||
if [[ "${REAL_DEFINITION}" != "${REAL_DEFINITION%/envs/*}" ]]; then
|
|
||||||
# Uninstall virtualenv by short name
|
|
||||||
exec pyenv-virtualenv-delete ${FORCE+-f} "${REAL_DEFINITION}"
|
|
||||||
exit 128
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
# Uninstall all virtualenvs inside `envs` directory too
|
|
||||||
shopt -s nullglob
|
|
||||||
for virtualenv in "${PREFIX}/envs/"*; do
|
|
||||||
pyenv-virtualenv-delete ${FORCE+-f} "${DEFINITION}/envs/${virtualenv##*/}"
|
|
||||||
done
|
|
||||||
shopt -u nullglob
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
25
etc/pyenv.d/uninstall/virtualenv.bash
Normal file
25
etc/pyenv.d/uninstall/virtualenv.bash
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
VERSION_NAME="${DEFINITION##*/}"
|
||||||
|
PREFIX="${PYENV_ROOT}/versions/${VERSION_NAME}"
|
||||||
|
|
||||||
|
if ! pyenv-virtualenv-prefix "${VERSION_NAME}" 1>/dev/null 2>&1; then
|
||||||
|
OLDIFS="$IFS"
|
||||||
|
IFS=$'\n' virtualenvs=($(pyenv-virtualenvs --bare))
|
||||||
|
IFS="$OLDIFS"
|
||||||
|
|
||||||
|
declare -a dependencies
|
||||||
|
for venv in "${virtualenvs[@]}"; do
|
||||||
|
venv_prefix="$(pyenv-virtualenv-prefix "${venv}" 2>/dev/null || true)"
|
||||||
|
if [ -d "${venv_prefix}" ] && [ "${PREFIX}" = "${venv_prefix}" ]; then
|
||||||
|
dependencies[${#dependencies[*]}]="${venv}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ -z "$FORCE" ] && [ -n "$dependencies" ]; then
|
||||||
|
echo "pyenv: ${#dependencies[@]} virtualenv(s) is depending on $PREFIX." >&2
|
||||||
|
read -p "continue with uninstallation? (y/N) "
|
||||||
|
case "$REPLY" in
|
||||||
|
y* | Y* ) ;;
|
||||||
|
* ) exit 1 ;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
fi
|
||||||
@@ -1,43 +0,0 @@
|
|||||||
# some of libraries require `python-config` in PATH to build native extensions.
|
|
||||||
# as a workaround, this hook will try to find the executable from the source
|
|
||||||
# version of the virtualenv.
|
|
||||||
# https://github.com/yyuu/pyenv/issues/397
|
|
||||||
|
|
||||||
if [ ! -x "${PYENV_COMMAND_PATH}" ] && [[ "${PYENV_COMMAND_PATH##*/}" == "python"*"-config" ]]; then
|
|
||||||
OLDIFS="${IFS}"
|
|
||||||
IFS=:
|
|
||||||
version="$(pyenv-version-name)"
|
|
||||||
IFS="${OLDIFS}"
|
|
||||||
if [ -f "${PYENV_ROOT}/versions/${version}/bin/activate" ]; then
|
|
||||||
if [ -f "${PYENV_ROOT}/versions/${version}/bin/conda" ]; then
|
|
||||||
: # do nothing for conda's environments
|
|
||||||
else
|
|
||||||
if [ -f "${PYENV_ROOT}/versions/${version}/bin/pyvenv.cfg" ]; then
|
|
||||||
# venv
|
|
||||||
virtualenv_binpath="$(cut -b 1-1024 "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" | sed -n '/^ *home *= */s///p' || true)"
|
|
||||||
virtualenv_prefix="${virtualenv_binpath%/bin}"
|
|
||||||
else
|
|
||||||
# virtualenv
|
|
||||||
if [ -d "${PYENV_ROOT}/versions/${version}/Lib" ]; then
|
|
||||||
# jython
|
|
||||||
virtualenv_libpath="${PYENV_ROOT}/versions/${version}/Lib"
|
|
||||||
else
|
|
||||||
if [ -d "${PYENV_ROOT}/versions/${version}/lib-python" ]; then
|
|
||||||
# pypy
|
|
||||||
virtualenv_libpath="${PYENV_ROOT}/versions/${version}/lib-python"
|
|
||||||
else
|
|
||||||
virtualenv_libpath="${PYENV_ROOT}/versions/${version}/lib"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
virtualenv_orig_prefix="$(find "${virtualenv_libpath}/" -maxdepth 2 -type f -and -name "orig-prefix.txt" 2>/dev/null | head -1)"
|
|
||||||
if [ -f "${virtualenv_orig_prefix}" ]; then
|
|
||||||
virtualenv_prefix="$(cat "${virtualenv_orig_prefix}" 2>/dev/null || true)"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
virtualenv_command_path="${virtualenv_prefix}/bin/${PYENV_COMMAND_PATH##*/}"
|
|
||||||
if [ -x "${virtualenv_command_path}" ]; then
|
|
||||||
PYENV_COMMAND_PATH="${virtualenv_command_path}"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
@@ -1,54 +0,0 @@
|
|||||||
# if virtualenv is created with `--system-site-packages`,
|
|
||||||
# looks up executables for source version as well if none is
|
|
||||||
# installed in the virtualenv.
|
|
||||||
# https://github.com/yyuu/pyenv-virtualenv/issues/62
|
|
||||||
|
|
||||||
if [ ! -x "${PYENV_COMMAND_PATH}" ]; then
|
|
||||||
OLDIFS="${IFS}"
|
|
||||||
IFS=:
|
|
||||||
version="$(pyenv-version-name)"
|
|
||||||
IFS="${OLDIFS}"
|
|
||||||
if [ -f "${PYENV_ROOT}/versions/${version}/bin/activate" ]; then
|
|
||||||
unset include_system_site_packages
|
|
||||||
if [ -f "${PYENV_ROOT}/versions/${version}/bin/conda" ]; then
|
|
||||||
: # do nothing for conda's environments
|
|
||||||
else
|
|
||||||
if [ -f "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" ]; then
|
|
||||||
# venv
|
|
||||||
virtualenv_binpath="$(cut -b 1-1024 "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" | sed -n '/^ *home *= */s///p' || true)"
|
|
||||||
virtualenv_prefix="${virtualenv_binpath%/bin}"
|
|
||||||
if grep -q -i "include-system-site-packages *= *true" "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" 1>/dev/null 2>&1; then
|
|
||||||
include_system_site_packages=1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
# virtualenv
|
|
||||||
if [ -d "${PYENV_ROOT}/versions/${version}/Lib" ]; then
|
|
||||||
# jython
|
|
||||||
virtualenv_libpath="${PYENV_ROOT}/versions/${version}/Lib"
|
|
||||||
else
|
|
||||||
if [ -d "${PYENV_ROOT}/versions/${version}/lib-python" ]; then
|
|
||||||
# pypy
|
|
||||||
virtualenv_libpath="${PYENV_ROOT}/versions/${version}/lib-python"
|
|
||||||
else
|
|
||||||
virtualenv_libpath="${PYENV_ROOT}/versions/${version}/lib"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
no_global_site_packages="$(find "${virtualenv_libpath}/" -maxdepth 2 -type f -and -name "no-global-site-packages.txt" 2>/dev/null | head -1)"
|
|
||||||
if [ ! -f "${no_global_site_packages}" ]; then
|
|
||||||
include_system_site_packages=1
|
|
||||||
fi
|
|
||||||
virtualenv_orig_prefix="$(find "${virtualenv_libpath}/" -maxdepth 2 -type f -and -name "orig-prefix.txt" 2>/dev/null | head -1)"
|
|
||||||
if [ -f "${virtualenv_orig_prefix}" ]; then
|
|
||||||
virtualenv_prefix="$(cat "${virtualenv_orig_prefix}" 2>/dev/null || true)"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
if [ -n "${include_system_site_packages}" ] && [ -n "${virtualenv_prefix}" ]; then
|
|
||||||
# virtualenv is created with `--system-site-packages`
|
|
||||||
virtualenv_command_path="${virtualenv_prefix}/bin/${PYENV_COMMAND_PATH##*/}"
|
|
||||||
if [ -x "${virtualenv_command_path}" ]; then
|
|
||||||
PYENV_COMMAND_PATH="${virtualenv_command_path}"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
15
install.sh
15
install.sh
@@ -12,19 +12,10 @@ if [ -z "${PREFIX}" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
BIN_PATH="${PREFIX}/bin"
|
BIN_PATH="${PREFIX}/bin"
|
||||||
SHIMS_PATH="${PREFIX}/shims"
|
ETC_PATH="${PREFIX}/etc/pyenv.d"
|
||||||
HOOKS_PATH="${PREFIX}/etc/pyenv.d"
|
|
||||||
|
|
||||||
mkdir -p "$BIN_PATH"
|
mkdir -p "$BIN_PATH"
|
||||||
mkdir -p "$SHIMS_PATH"
|
mkdir -p "$ETC_PATH"
|
||||||
mkdir -p "$HOOKS_PATH"
|
|
||||||
|
|
||||||
install -p bin/* "$BIN_PATH"
|
install -p bin/* "$BIN_PATH"
|
||||||
install -p shims/* "$SHIMS_PATH"
|
cp -RPp etc/pyenv.d/* "$ETC_PATH"
|
||||||
for hook in etc/pyenv.d/*; do
|
|
||||||
if [ -d "$hook" ]; then
|
|
||||||
cp -RPp "$hook" "$HOOKS_PATH"
|
|
||||||
else
|
|
||||||
install -p -m 0644 "$hook" "$HOOKS_PATH"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|||||||
@@ -1,7 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
if [[ "$0" != "${BASH_SOURCE}" ]]; then
|
|
||||||
eval "$(pyenv sh-activate --verbose "$@" || true)"
|
|
||||||
else
|
|
||||||
echo "pyenv-virtualenv: activate must be sourced. Run 'source activate envname' instead of 'activate envname'" 1>&2
|
|
||||||
false
|
|
||||||
fi
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
if [[ "$0" != "${BASH_SOURCE}" ]]; then
|
|
||||||
eval "$(pyenv sh-deactivate --verbose "$@" || true)"
|
|
||||||
else
|
|
||||||
echo "pyenv-virtualenv: deactivate must be sourced. Run 'source deactivate' instead of 'deactivate'" 1>&2
|
|
||||||
false
|
|
||||||
fi
|
|
||||||
@@ -3,401 +3,87 @@
|
|||||||
load test_helper
|
load test_helper
|
||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
export HOME="${TMP}"
|
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
export PYENV_ROOT="${TMP}/pyenv"
|
||||||
unset PYENV_VERSION
|
|
||||||
unset PYENV_ACTIVATE_SHELL
|
|
||||||
unset VIRTUAL_ENV
|
|
||||||
unset CONDA_DEFAULT_ENV
|
|
||||||
unset PYTHONHOME
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME
|
|
||||||
unset PYENV_VIRTUALENV_VERBOSE_ACTIVATE
|
|
||||||
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
|
||||||
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
|
||||||
unset VIRTUAL_ENV_DISABLE_PROMPT
|
|
||||||
unset _OLD_VIRTUAL_PS1
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "activate virtualenv from current version" {
|
@test "activate virtualenv from current version" {
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
stub pyenv-version-name "echo venv"
|
stub pyenv-version-name "echo venv"
|
||||||
stub pyenv-virtualenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
stub pyenv-virtualenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
||||||
stub pyenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
stub pyenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" PYENV_VERSION="venv" run pyenv-sh-activate
|
PYENV_SHELL="bash" PYENV_VERSION="venv" run pyenv-sh-activate
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
|
||||||
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(venv) \${PS1}";
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate virtualenv from current version (quiet)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
stub pyenv-version-name "echo venv"
|
|
||||||
stub pyenv-virtualenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
|
||||||
stub pyenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" PYENV_VERSION="venv" run pyenv-sh-activate --quiet
|
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
pyenv shell "venv"
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
source "${PYENV_ROOT}/versions/venv/bin/activate"
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(venv) \${PS1}";
|
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate virtualenv from current version (verbose)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUALENV_VERBOSE_ACTIVATE=1
|
|
||||||
|
|
||||||
stub pyenv-version-name "echo venv"
|
|
||||||
stub pyenv-virtualenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
|
||||||
stub pyenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" PYENV_VERSION="venv" run pyenv-sh-activate --verbose
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
pyenv-virtualenv: activate venv
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
|
||||||
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(venv) \${PS1}";
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate virtualenv from current version (without pyenv-virtualenv-init)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=
|
|
||||||
|
|
||||||
stub pyenv-version-name "echo venv"
|
|
||||||
stub pyenv-virtualenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
|
||||||
stub pyenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" PYENV_VERSION="venv" run pyenv-sh-activate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
export PYENV_VERSION="venv";
|
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
|
||||||
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(venv) \${PS1}";
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "activate virtualenv from current version (fish)" {
|
@test "activate virtualenv from current version (fish)" {
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
stub pyenv-version-name "echo venv"
|
stub pyenv-version-name "echo venv"
|
||||||
stub pyenv-virtualenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
stub pyenv-virtualenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
||||||
stub pyenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
stub pyenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" PYENV_VERSION="venv" run pyenv-sh-activate
|
PYENV_SHELL="fish" PYENV_VERSION="venv" run pyenv-sh-activate
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
set -gx PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
|
||||||
set -gx VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
|
||||||
pyenv-virtualenv: prompt changing not working for fish.
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate virtualenv from current version (fish) (without pyenv-virtualenv-init)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=
|
|
||||||
|
|
||||||
stub pyenv-version-name "echo venv"
|
|
||||||
stub pyenv-virtualenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
|
||||||
stub pyenv-prefix "venv : echo \"${PYENV_ROOT}/versions/venv\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" PYENV_VERSION="venv" run pyenv-sh-activate
|
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
pyenv shell "venv"
|
||||||
set -gx PYENV_VERSION "venv";
|
. "${PYENV_ROOT}/versions/venv/bin/activate.fish"
|
||||||
set -gx PYENV_ACTIVATE_SHELL 1;
|
|
||||||
set -gx PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
|
||||||
set -gx VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
|
||||||
pyenv-virtualenv: prompt changing not working for fish.
|
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "activate virtualenv from command-line argument" {
|
@test "activate virtualenv from command-line argument" {
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
stub pyenv-virtualenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
stub pyenv-virtualenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
||||||
stub pyenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
stub pyenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" PYENV_VERSION="venv" run pyenv-sh-activate "venv27"
|
run pyenv-sh-activate "venv27"
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
export PYENV_VERSION="venv27";
|
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
|
||||||
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(venv27) \${PS1}";
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate virtualenv from command-line argument (without pyenv-virtualenv-init)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=
|
|
||||||
|
|
||||||
stub pyenv-virtualenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
|
||||||
stub pyenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" PYENV_VERSION="venv" run pyenv-sh-activate "venv27"
|
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
pyenv shell "venv27"
|
||||||
export PYENV_VERSION="venv27";
|
source "${PYENV_ROOT}/versions/venv27/bin/activate"
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
|
||||||
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(venv27) \${PS1}";
|
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate virtualenv from command-line argument (fish)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
stub pyenv-virtualenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
|
||||||
stub pyenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" PYENV_VERSION="venv" run pyenv-sh-activate "venv27"
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
set -gx PYENV_VERSION "venv27";
|
|
||||||
set -gx PYENV_ACTIVATE_SHELL 1;
|
|
||||||
set -gx PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
|
||||||
set -gx VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
|
||||||
pyenv-virtualenv: prompt changing not working for fish.
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate virtualenv from command-line argument (fish) (without pyenv-virtualenv-init)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=
|
|
||||||
|
|
||||||
stub pyenv-virtualenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
|
||||||
stub pyenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" PYENV_VERSION="venv" run pyenv-sh-activate "venv27"
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
set -gx PYENV_VERSION "venv27";
|
|
||||||
set -gx PYENV_ACTIVATE_SHELL 1;
|
|
||||||
set -gx PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
|
||||||
set -gx VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
|
||||||
pyenv-virtualenv: prompt changing not working for fish.
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "unset invokes deactivate" {
|
@test "unset invokes deactivate" {
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
|
|
||||||
stub pyenv-sh-deactivate " : echo deactivated"
|
|
||||||
|
|
||||||
run pyenv-sh-activate --unset
|
run pyenv-sh-activate --unset
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
pyenv deactivate
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "should fail if the version is not a virtualenv" {
|
@test "should fail if the version is not a virtualenv" {
|
||||||
stub pyenv-virtualenv-prefix "3.3.3 : false"
|
stub pyenv-virtualenv-prefix "3.3.3 : false"
|
||||||
stub pyenv-version-name " : echo 3.3.3"
|
|
||||||
stub pyenv-virtualenv-prefix "3.3.3/envs/3.3.3 : false"
|
|
||||||
|
|
||||||
run pyenv-sh-activate "3.3.3"
|
run pyenv-sh-activate "3.3.3"
|
||||||
|
|
||||||
assert_failure
|
|
||||||
assert_output <<EOS
|
|
||||||
pyenv-virtualenv: version \`3.3.3' is not a virtualenv
|
|
||||||
false
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-version-name
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "should fail if the version is not a virtualenv (quiet)" {
|
|
||||||
stub pyenv-virtualenv-prefix "3.3.3 : false"
|
|
||||||
stub pyenv-version-name " : echo 3.3.3"
|
|
||||||
stub pyenv-virtualenv-prefix "3.3.3/envs/3.3.3 : false"
|
|
||||||
|
|
||||||
run pyenv-sh-activate --quiet "3.3.3"
|
|
||||||
|
|
||||||
assert_failure
|
assert_failure
|
||||||
assert_output <<EOS
|
|
||||||
false
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-version-name
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "should fail if there are multiple versions" {
|
@test "should fail if there are multiple versions" {
|
||||||
stub pyenv-virtualenv-prefix "venv : true"
|
|
||||||
stub pyenv-virtualenv-prefix "venv27 : true"
|
|
||||||
|
|
||||||
run pyenv-sh-activate "venv" "venv27"
|
run pyenv-sh-activate "venv" "venv27"
|
||||||
|
|
||||||
assert_failure
|
assert_failure
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: cannot activate multiple versions at once: venv venv27
|
pyenv-virtualenv: cannot activate multiple versions at once: venv venv27
|
||||||
false
|
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "should fail if there are multiple virtualenvs (quiet)" {
|
|
||||||
stub pyenv-virtualenv-prefix "venv : true"
|
|
||||||
stub pyenv-virtualenv-prefix "venv27 : true"
|
|
||||||
|
|
||||||
run pyenv-sh-activate --quiet "venv" "venv27"
|
|
||||||
|
|
||||||
assert_failure
|
|
||||||
assert_output <<EOS
|
|
||||||
false
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "should fail if the first version is not a virtualenv" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
stub pyenv-virtualenv-prefix "2.7.10 : false"
|
|
||||||
stub pyenv-version-name " : echo 2.7.10"
|
|
||||||
stub pyenv-virtualenv-prefix "2.7.10/envs/2.7.10 : false"
|
|
||||||
|
|
||||||
run pyenv-sh-activate "2.7.10" "venv27"
|
|
||||||
|
|
||||||
assert_failure
|
|
||||||
assert_output <<EOS
|
|
||||||
pyenv-virtualenv: version \`2.7.10' is not a virtualenv
|
|
||||||
false
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-version-name
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate if the first virtualenv is a virtualenv" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
stub pyenv-virtualenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
|
||||||
stub pyenv-virtualenv-prefix "2.7.10 : false"
|
|
||||||
stub pyenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-activate "venv27" "2.7.10"
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
export PYENV_VERSION="venv27:2.7.10";
|
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
|
||||||
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(venv27) \${PS1}";
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "should fail if activate is invoked as a command" {
|
@test "should fail if activate is invoked as a command" {
|
||||||
|
|||||||
@@ -1,169 +0,0 @@
|
|||||||
#!/usr/bin/env bats
|
|
||||||
|
|
||||||
load test_helper
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
export HOME="${TMP}"
|
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
|
||||||
unset PYENV_VERSION
|
|
||||||
unset PYENV_ACTIVATE_SHELL
|
|
||||||
unset PYENV_VIRTUAL_ENV
|
|
||||||
unset VIRTUAL_ENV
|
|
||||||
unset CONDA_DEFAULT_ENV
|
|
||||||
unset PYTHONHOME
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME
|
|
||||||
unset PYENV_VIRTUALENV_VERBOSE_ACTIVATE
|
|
||||||
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
|
||||||
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
|
||||||
unset VIRTUAL_ENV_DISABLE_PROMPT
|
|
||||||
unset _OLD_VIRTUAL_PS1
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate conda root from current version" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
setup_conda "anaconda-2.3.0"
|
|
||||||
stub pyenv-version-name "echo anaconda-2.3.0"
|
|
||||||
stub pyenv-virtualenv-prefix "anaconda-2.3.0 : echo \"${PYENV_ROOT}/versions/anaconda-2.3.0\""
|
|
||||||
stub pyenv-prefix "anaconda-2.3.0 : echo \"${PYENV_ROOT}/versions/anaconda-2.3.0\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" PYENV_VERSION="anaconda-2.3.0" run pyenv-sh-activate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0";
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0";
|
|
||||||
export CONDA_DEFAULT_ENV="root";
|
|
||||||
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(anaconda-2.3.0) \${PS1}";
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
teardown_conda "anaconda-2.3.0"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate conda root from current version (fish)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
setup_conda "anaconda-2.3.0"
|
|
||||||
stub pyenv-version-name "echo anaconda-2.3.0"
|
|
||||||
stub pyenv-virtualenv-prefix "anaconda-2.3.0 : echo \"${PYENV_ROOT}/versions/anaconda-2.3.0\""
|
|
||||||
stub pyenv-prefix "anaconda-2.3.0 : echo \"${PYENV_ROOT}/versions/anaconda-2.3.0\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" PYENV_VERSION="anaconda-2.3.0" run pyenv-sh-activate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
set -gx PYENV_VIRTUAL_ENV "${TMP}/pyenv/versions/anaconda-2.3.0";
|
|
||||||
set -gx VIRTUAL_ENV "${TMP}/pyenv/versions/anaconda-2.3.0";
|
|
||||||
set -gx CONDA_DEFAULT_ENV "root";
|
|
||||||
pyenv-virtualenv: prompt changing not working for fish.
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
teardown_conda "anaconda-2.3.0"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate conda root from command-line argument" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
setup_conda "anaconda-2.3.0"
|
|
||||||
setup_conda "miniconda-3.9.1"
|
|
||||||
stub pyenv-virtualenv-prefix "miniconda-3.9.1 : echo \"${PYENV_ROOT}/versions/miniconda-3.9.1\""
|
|
||||||
stub pyenv-prefix "miniconda-3.9.1 : echo \"${PYENV_ROOT}/versions/miniconda-3.9.1\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" PYENV_VERSION="anaconda-2.3.0" run pyenv-sh-activate "miniconda-3.9.1"
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
export PYENV_VERSION="miniconda-3.9.1";
|
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/miniconda-3.9.1";
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/miniconda-3.9.1";
|
|
||||||
export CONDA_DEFAULT_ENV="root";
|
|
||||||
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(miniconda-3.9.1) \${PS1}";
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
teardown_conda "anaconda-2.3.0"
|
|
||||||
teardown_conda "miniconda-3.9.1"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate conda env from current version" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
setup_conda "anaconda-2.3.0" "foo"
|
|
||||||
stub pyenv-version-name "echo anaconda-2.3.0/envs/foo"
|
|
||||||
stub pyenv-virtualenv-prefix "anaconda-2.3.0/envs/foo : echo \"${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo\""
|
|
||||||
stub pyenv-prefix "anaconda-2.3.0/envs/foo : echo \"${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" PYENV_VERSION="anaconda-2.3.0/envs/foo" run pyenv-sh-activate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo";
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo";
|
|
||||||
export CONDA_DEFAULT_ENV="foo";
|
|
||||||
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(anaconda-2.3.0/envs/foo) \${PS1}";
|
|
||||||
. "${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo/etc/conda/activate.d/activate.sh";
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
teardown_conda "anaconda-2.3.0" "foo"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "activate conda env from command-line argument" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
|
|
||||||
setup_conda "anaconda-2.3.0" "foo"
|
|
||||||
setup_conda "miniconda-3.9.1" "bar"
|
|
||||||
stub pyenv-virtualenv-prefix "miniconda-3.9.1/envs/bar : echo \"${PYENV_ROOT}/versions/miniconda-3.9.1\""
|
|
||||||
stub pyenv-prefix "miniconda-3.9.1/envs/bar : echo \"${PYENV_ROOT}/versions/miniconda-3.9.1/envs/bar\""
|
|
||||||
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" PYENV_VERSION="anaconda-2.3.0/envs/foo" run pyenv-sh-activate "miniconda-3.9.1/envs/bar"
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
deactivated
|
|
||||||
export PYENV_VERSION="miniconda-3.9.1/envs/bar";
|
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/miniconda-3.9.1/envs/bar";
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/miniconda-3.9.1/envs/bar";
|
|
||||||
export CONDA_DEFAULT_ENV="bar";
|
|
||||||
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
|
||||||
export PS1="(miniconda-3.9.1/envs/bar) \${PS1}";
|
|
||||||
. "${PYENV_ROOT}/versions/miniconda-3.9.1/envs/bar/etc/conda/activate.d/activate.sh";
|
|
||||||
EOS
|
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-sh-deactivate
|
|
||||||
teardown_conda "anaconda-2.3.0" "foo"
|
|
||||||
teardown_conda "miniconda-3.9.1" "bar"
|
|
||||||
}
|
|
||||||
@@ -1,121 +0,0 @@
|
|||||||
#!/usr/bin/env bats
|
|
||||||
|
|
||||||
load test_helper
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
|
||||||
unset PYENV_VERSION
|
|
||||||
unset PYENV_ACTIVATE_SHELL
|
|
||||||
unset PYENV_VIRTUAL_ENV
|
|
||||||
unset VIRTUAL_ENV
|
|
||||||
unset CONDA_DEFAULT_ENV
|
|
||||||
unset PYTHONHOME
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME
|
|
||||||
unset PYENV_VIRTUALENV_VERBOSE_ACTIVATE
|
|
||||||
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
|
||||||
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
|
||||||
unset VIRTUAL_ENV_DISABLE_PROMPT
|
|
||||||
unset _OLD_VIRTUAL_PS1
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate conda root" {
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
export CONDA_DEFAULT_ENV="root"
|
|
||||||
|
|
||||||
setup_conda "anaconda-2.3.0"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-deactivate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
|
||||||
unset VIRTUAL_ENV;
|
|
||||||
unset CONDA_DEFAULT_ENV;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
|
||||||
export PATH="\${_OLD_VIRTUAL_PATH}";
|
|
||||||
unset _OLD_VIRTUAL_PATH;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PYTHONHOME}" ]; then
|
|
||||||
export PYTHONHOME="\${_OLD_VIRTUAL_PYTHONHOME}";
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PS1}" ]; then
|
|
||||||
export PS1="\${_OLD_VIRTUAL_PS1}";
|
|
||||||
unset _OLD_VIRTUAL_PS1;
|
|
||||||
fi;
|
|
||||||
if declare -f deactivate 1>/dev/null 2>&1; then
|
|
||||||
unset -f deactivate;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
|
|
||||||
teardown_conda "anaconda-2.3.0"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate conda root (fish)" {
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
export CONDA_DEFAULT_ENV="root"
|
|
||||||
|
|
||||||
setup_conda "anaconda-2.3.0"
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" run pyenv-sh-deactivate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
set -e PYENV_VIRTUAL_ENV;
|
|
||||||
set -e VIRTUAL_ENV;
|
|
||||||
set -e CONDA_DEFAULT_ENV;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
|
||||||
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
|
||||||
end;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
|
||||||
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
end;
|
|
||||||
if functions -q deactivate;
|
|
||||||
functions -e deactivate;
|
|
||||||
end;
|
|
||||||
EOS
|
|
||||||
|
|
||||||
teardown_conda "anaconda-2.3.0"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate conda env" {
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
export CONDA_DEFAULT_ENV="foo"
|
|
||||||
|
|
||||||
setup_conda "anaconda-2.3.0" "foo"
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-deactivate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
. "${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo/etc/conda/deactivate.d/deactivate.sh";
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
|
||||||
unset VIRTUAL_ENV;
|
|
||||||
unset CONDA_DEFAULT_ENV;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
|
||||||
export PATH="\${_OLD_VIRTUAL_PATH}";
|
|
||||||
unset _OLD_VIRTUAL_PATH;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PYTHONHOME}" ]; then
|
|
||||||
export PYTHONHOME="\${_OLD_VIRTUAL_PYTHONHOME}";
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PS1}" ]; then
|
|
||||||
export PS1="\${_OLD_VIRTUAL_PS1}";
|
|
||||||
unset _OLD_VIRTUAL_PS1;
|
|
||||||
fi;
|
|
||||||
if declare -f deactivate 1>/dev/null 2>&1; then
|
|
||||||
unset -f deactivate;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
|
|
||||||
teardown_conda "anaconda-2.3.0" "foo"
|
|
||||||
}
|
|
||||||
@@ -1,41 +0,0 @@
|
|||||||
#!/usr/bin/env bats
|
|
||||||
|
|
||||||
load test_helper
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "display conda root" {
|
|
||||||
setup_conda "anaconda-2.3.0"
|
|
||||||
stub pyenv-version-name "echo anaconda-2.3.0"
|
|
||||||
stub pyenv-prefix "anaconda-2.3.0 : echo \"${PYENV_ROOT}/versions/anaconda-2.3.0\""
|
|
||||||
|
|
||||||
PYENV_VERSION="anaconda-2.3.0" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
${PYENV_ROOT}/versions/anaconda-2.3.0
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
teardown_conda "anaconda-2.3.0"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "display conda env" {
|
|
||||||
setup_conda "anaconda-2.3.0" "foo"
|
|
||||||
stub pyenv-version-name "echo anaconda-2.3.0/envs/foo"
|
|
||||||
stub pyenv-prefix "anaconda-2.3.0/envs/foo : echo \"${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo\""
|
|
||||||
|
|
||||||
PYENV_VERSION="anaconda-2.3.0/envs/foo" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
teardown_conda "anaconda-2.3.0" "foo"
|
|
||||||
}
|
|
||||||
@@ -1,90 +0,0 @@
|
|||||||
#!/usr/bin/env bats
|
|
||||||
|
|
||||||
load test_helper
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
|
||||||
}
|
|
||||||
|
|
||||||
stub_pyenv() {
|
|
||||||
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-hooks "virtualenv : echo"
|
|
||||||
stub pyenv-rehash " : echo rehashed"
|
|
||||||
}
|
|
||||||
|
|
||||||
unstub_pyenv() {
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-hooks
|
|
||||||
unstub pyenv-rehash
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "create virtualenv by conda create" {
|
|
||||||
export PYENV_VERSION="miniconda3-3.16.0"
|
|
||||||
setup_conda "${PYENV_VERSION}"
|
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-virtualenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-exec "conda * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=miniconda3-3.16.0 conda create --name venv --yes python
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub_pyenv
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
|
||||||
teardown_m_venv "miniconda3-3.16.0"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "create virtualenv by conda create with -p" {
|
|
||||||
export PYENV_VERSION="miniconda3-3.16.0"
|
|
||||||
setup_conda "${PYENV_VERSION}"
|
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-virtualenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-exec "conda * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv -p python3.5 venv
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=miniconda3-3.16.0 conda create --name venv --yes python=3.5 python
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub_pyenv
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
|
||||||
teardown_m_venv "miniconda3-3.16.0"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "create virtualenv by conda create with --python" {
|
|
||||||
export PYENV_VERSION="miniconda3-3.16.0"
|
|
||||||
setup_conda "${PYENV_VERSION}"
|
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-virtualenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-exec "conda * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv --python=python3.5 venv
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=miniconda3-3.16.0 conda create --name venv --yes python=3.5 python
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub_pyenv
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
|
||||||
teardown_m_venv "miniconda3-3.16.0"
|
|
||||||
}
|
|
||||||
@@ -4,367 +4,25 @@ load test_helper
|
|||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
export PYENV_ROOT="${TMP}/pyenv"
|
||||||
unset PYENV_VERSION
|
|
||||||
unset PYENV_ACTIVATE_SHELL
|
|
||||||
unset PYENV_VIRTUAL_ENV
|
|
||||||
unset VIRTUAL_ENV
|
|
||||||
unset CONDA_DEFAULT_ENV
|
|
||||||
unset PYTHONHOME
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME
|
|
||||||
unset PYENV_VIRTUALENV_VERBOSE_ACTIVATE
|
|
||||||
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
|
||||||
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
|
||||||
unset VIRTUAL_ENV_DISABLE_PROMPT
|
|
||||||
unset _OLD_VIRTUAL_PS1
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "deactivate virtualenv" {
|
@test "deactivate virtualenv" {
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-deactivate
|
PYENV_SHELL="bash" run pyenv-sh-deactivate
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
unset PYENV_VIRTUAL_ENV;
|
declare -f deactivate 1>/dev/null 2>&1 && deactivate
|
||||||
unset VIRTUAL_ENV;
|
pyenv shell --unset
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
|
||||||
export PATH="\${_OLD_VIRTUAL_PATH}";
|
|
||||||
unset _OLD_VIRTUAL_PATH;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PYTHONHOME}" ]; then
|
|
||||||
export PYTHONHOME="\${_OLD_VIRTUAL_PYTHONHOME}";
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PS1}" ]; then
|
|
||||||
export PS1="\${_OLD_VIRTUAL_PS1}";
|
|
||||||
unset _OLD_VIRTUAL_PS1;
|
|
||||||
fi;
|
|
||||||
if declare -f deactivate 1>/dev/null 2>&1; then
|
|
||||||
unset -f deactivate;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate virtualenv (quiet)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-deactivate --quit
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
|
||||||
unset VIRTUAL_ENV;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
|
||||||
export PATH="\${_OLD_VIRTUAL_PATH}";
|
|
||||||
unset _OLD_VIRTUAL_PATH;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PYTHONHOME}" ]; then
|
|
||||||
export PYTHONHOME="\${_OLD_VIRTUAL_PYTHONHOME}";
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PS1}" ]; then
|
|
||||||
export PS1="\${_OLD_VIRTUAL_PS1}";
|
|
||||||
unset _OLD_VIRTUAL_PS1;
|
|
||||||
fi;
|
|
||||||
if declare -f deactivate 1>/dev/null 2>&1; then
|
|
||||||
unset -f deactivate;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate virtualenv (verbose)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
export PYENV_VIRTUALENV_VERBOSE_ACTIVATE=1
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-deactivate --verbose
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
pyenv-virtualenv: deactivate venv
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
|
||||||
unset VIRTUAL_ENV;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
|
||||||
export PATH="\${_OLD_VIRTUAL_PATH}";
|
|
||||||
unset _OLD_VIRTUAL_PATH;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PYTHONHOME}" ]; then
|
|
||||||
export PYTHONHOME="\${_OLD_VIRTUAL_PYTHONHOME}";
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PS1}" ]; then
|
|
||||||
export PS1="\${_OLD_VIRTUAL_PS1}";
|
|
||||||
unset _OLD_VIRTUAL_PS1;
|
|
||||||
fi;
|
|
||||||
if declare -f deactivate 1>/dev/null 2>&1; then
|
|
||||||
unset -f deactivate;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate virtualenv (quiet)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-deactivate --quiet
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
|
||||||
unset VIRTUAL_ENV;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
|
||||||
export PATH="\${_OLD_VIRTUAL_PATH}";
|
|
||||||
unset _OLD_VIRTUAL_PATH;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PYTHONHOME}" ]; then
|
|
||||||
export PYTHONHOME="\${_OLD_VIRTUAL_PYTHONHOME}";
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PS1}" ]; then
|
|
||||||
export PS1="\${_OLD_VIRTUAL_PS1}";
|
|
||||||
unset _OLD_VIRTUAL_PS1;
|
|
||||||
fi;
|
|
||||||
if declare -f deactivate 1>/dev/null 2>&1; then
|
|
||||||
unset -f deactivate;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate virtualenv (with shell activation)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=1
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-deactivate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
unset PYENV_VERSION;
|
|
||||||
unset PYENV_ACTIVATE_SHELL;
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
|
||||||
unset VIRTUAL_ENV;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
|
||||||
export PATH="\${_OLD_VIRTUAL_PATH}";
|
|
||||||
unset _OLD_VIRTUAL_PATH;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PYTHONHOME}" ]; then
|
|
||||||
export PYTHONHOME="\${_OLD_VIRTUAL_PYTHONHOME}";
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PS1}" ]; then
|
|
||||||
export PS1="\${_OLD_VIRTUAL_PS1}";
|
|
||||||
unset _OLD_VIRTUAL_PS1;
|
|
||||||
fi;
|
|
||||||
if declare -f deactivate 1>/dev/null 2>&1; then
|
|
||||||
unset -f deactivate;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate virtualenv (with shell activation) (quiet)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=1
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-deactivate --quiet
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
unset PYENV_VERSION;
|
|
||||||
unset PYENV_ACTIVATE_SHELL;
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
|
||||||
unset VIRTUAL_ENV;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
|
||||||
export PATH="\${_OLD_VIRTUAL_PATH}";
|
|
||||||
unset _OLD_VIRTUAL_PATH;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PYTHONHOME}" ]; then
|
|
||||||
export PYTHONHOME="\${_OLD_VIRTUAL_PYTHONHOME}";
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PS1}" ]; then
|
|
||||||
export PS1="\${_OLD_VIRTUAL_PS1}";
|
|
||||||
unset _OLD_VIRTUAL_PS1;
|
|
||||||
fi;
|
|
||||||
if declare -f deactivate 1>/dev/null 2>&1; then
|
|
||||||
unset -f deactivate;
|
|
||||||
fi;
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate virtualenv which has been activated manually" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-deactivate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
|
||||||
unset VIRTUAL_ENV;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
|
||||||
export PATH="\${_OLD_VIRTUAL_PATH}";
|
|
||||||
unset _OLD_VIRTUAL_PATH;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PYTHONHOME}" ]; then
|
|
||||||
export PYTHONHOME="\${_OLD_VIRTUAL_PYTHONHOME}";
|
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
fi;
|
|
||||||
if [ -n "\${_OLD_VIRTUAL_PS1}" ]; then
|
|
||||||
export PS1="\${_OLD_VIRTUAL_PS1}";
|
|
||||||
unset _OLD_VIRTUAL_PS1;
|
|
||||||
fi;
|
|
||||||
if declare -f deactivate 1>/dev/null 2>&1; then
|
|
||||||
unset -f deactivate;
|
|
||||||
fi;
|
|
||||||
EOS
|
EOS
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "deactivate virtualenv (fish)" {
|
@test "deactivate virtualenv (fish)" {
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" run pyenv-sh-deactivate
|
PYENV_SHELL="fish" run pyenv-sh-deactivate
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
set -e PYENV_VIRTUAL_ENV;
|
functions -q deactivate; and deactivate
|
||||||
set -e VIRTUAL_ENV;
|
pyenv shell --unset
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
|
||||||
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
|
||||||
end;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
|
||||||
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
end;
|
|
||||||
if functions -q deactivate;
|
|
||||||
functions -e deactivate;
|
|
||||||
end;
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate virtualenv (fish) (quiet)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" run pyenv-sh-deactivate --quiet
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
set -e PYENV_VIRTUAL_ENV;
|
|
||||||
set -e VIRTUAL_ENV;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
|
||||||
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
|
||||||
end;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
|
||||||
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
end;
|
|
||||||
if functions -q deactivate;
|
|
||||||
functions -e deactivate;
|
|
||||||
end;
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate virtualenv (fish) (with shell activation)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=1
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" run pyenv-sh-deactivate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
set -e PYENV_VERSION;
|
|
||||||
set -e PYENV_ACTIVATE_SHELL;
|
|
||||||
set -e PYENV_VIRTUAL_ENV;
|
|
||||||
set -e VIRTUAL_ENV;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
|
||||||
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
|
||||||
end;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
|
||||||
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
end;
|
|
||||||
if functions -q deactivate;
|
|
||||||
functions -e deactivate;
|
|
||||||
end;
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate virtualenv (fish) (with shell activation) (quiet)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=1
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" run pyenv-sh-deactivate --quiet
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
set -e PYENV_VERSION;
|
|
||||||
set -e PYENV_ACTIVATE_SHELL;
|
|
||||||
set -e PYENV_VIRTUAL_ENV;
|
|
||||||
set -e VIRTUAL_ENV;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
|
||||||
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
|
||||||
end;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
|
||||||
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
end;
|
|
||||||
if functions -q deactivate;
|
|
||||||
functions -e deactivate;
|
|
||||||
end;
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "deactivate virtualenv which has been activated manually (fish)" {
|
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
|
||||||
export PYENV_ACTIVATE_SHELL=
|
|
||||||
|
|
||||||
PYENV_SHELL="fish" run pyenv-sh-deactivate
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
set -e PYENV_VIRTUAL_ENV;
|
|
||||||
set -e VIRTUAL_ENV;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
|
||||||
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
|
||||||
end;
|
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
|
||||||
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
|
||||||
end;
|
|
||||||
if functions -q deactivate;
|
|
||||||
functions -e deactivate;
|
|
||||||
end;
|
|
||||||
EOS
|
EOS
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,88 +0,0 @@
|
|||||||
#!/usr/bin/env bats
|
|
||||||
|
|
||||||
load test_helper
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "delete virtualenv" {
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/venv27"
|
|
||||||
|
|
||||||
stub pyenv-virtualenv-prefix "venv27 : true"
|
|
||||||
stub pyenv-rehash "true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv-delete -f "venv27"
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-rehash
|
|
||||||
|
|
||||||
[ ! -d "${PYENV_ROOT}/versions/venv27" ]
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "delete virtualenv by symlink" {
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/2.7.11/envs/venv27"
|
|
||||||
ln -fs "${PYENV_ROOT}/versions/2.7.11/envs/venv27" "${PYENV_ROOT}/versions/venv27"
|
|
||||||
|
|
||||||
stub pyenv-rehash "true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv-delete -f "venv27"
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub pyenv-rehash
|
|
||||||
|
|
||||||
[ ! -d "${PYENV_ROOT}/versions/2.7.11/envs/venv27" ]
|
|
||||||
[ ! -L "${PYENV_ROOT}/versions/venv27" ]
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "delete virtualenv with symlink" {
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/2.7.11/envs/venv27"
|
|
||||||
ln -fs "${PYENV_ROOT}/versions/2.7.11/envs/venv27" "${PYENV_ROOT}/versions/venv27"
|
|
||||||
|
|
||||||
stub pyenv-rehash "true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv-delete -f "2.7.11/envs/venv27"
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub pyenv-rehash
|
|
||||||
|
|
||||||
[ ! -d "${PYENV_ROOT}/versions/2.7.11/envs/venv27" ]
|
|
||||||
[ ! -L "${PYENV_ROOT}/versions/venv27" ]
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "not delete virtualenv with different symlink" {
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/2.7.8/envs/venv27"
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/2.7.11/envs/venv27"
|
|
||||||
ln -fs "${PYENV_ROOT}/versions/2.7.8/envs/venv27" "${PYENV_ROOT}/versions/venv27"
|
|
||||||
|
|
||||||
stub pyenv-rehash "true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv-delete -f "2.7.11/envs/venv27"
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub pyenv-rehash
|
|
||||||
|
|
||||||
[ ! -d "${PYENV_ROOT}/versions/2.7.11/envs/venv27" ]
|
|
||||||
[ -L "${PYENV_ROOT}/versions/venv27" ]
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "not delete virtualenv with same name" {
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/2.7.11/envs/venv27"
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/venv27"
|
|
||||||
|
|
||||||
stub pyenv-rehash "true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv-delete -f "2.7.11/envs/venv27"
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub pyenv-rehash
|
|
||||||
|
|
||||||
[ ! -d "${PYENV_ROOT}/versions/2.7.11/envs/venv27" ]
|
|
||||||
[ -d "${PYENV_ROOT}/versions/venv27" ]
|
|
||||||
}
|
|
||||||
@@ -1,47 +0,0 @@
|
|||||||
#!/usr/bin/env bats
|
|
||||||
|
|
||||||
load test_helper
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
export PYENV_ROOT="${TMP}/envs/pyenv"
|
|
||||||
}
|
|
||||||
|
|
||||||
stub_pyenv() {
|
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-hooks "virtualenv : echo"
|
|
||||||
stub pyenv-rehash " : echo rehashed"
|
|
||||||
}
|
|
||||||
|
|
||||||
unstub_pyenv() {
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-hooks
|
|
||||||
unstub pyenv-rehash
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "path should be handled properly even if there is 'envs' in PYENV_ROOT" {
|
|
||||||
export PYENV_VERSION="3.5.1"
|
|
||||||
setup_m_venv "3.5.1"
|
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-version-name "echo '${PYENV_VERSION}'"
|
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
|
||||||
stub pyenv-exec "python -m venv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";mkdir -p \${PYENV_ROOT}/versions/3.5.1/envs/venv/bin"
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";touch \${PYENV_ROOT}/versions/3.5.1/envs/venv/bin/pip"
|
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=3.5.1 python -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
|
||||||
PYENV_VERSION=3.5.1/envs/venv python -s -m ensurepip
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
assert [ -e "${PYENV_ROOT}/versions/3.5.1/envs/venv/bin/pip" ]
|
|
||||||
|
|
||||||
unstub_pyenv
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
|
||||||
teardown_m_venv "3.5.1"
|
|
||||||
}
|
|
||||||
@@ -13,30 +13,21 @@ setup() {
|
|||||||
before_virtualenv 'echo before: \$VIRTUALENV_PATH'
|
before_virtualenv 'echo before: \$VIRTUALENV_PATH'
|
||||||
after_virtualenv 'echo after: \$STATUS'
|
after_virtualenv 'echo after: \$STATUS'
|
||||||
OUT
|
OUT
|
||||||
setup_version "3.5.1"
|
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/\${PYENV_VERSION}'"
|
||||||
create_executable "3.5.1" "virtualenv"
|
stub pyenv-which "virtualenv : echo '${PYENV_ROOT}/versions/bin/virtualenv'" \
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.5.1'"
|
"pyvenv : false"
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.5.1'"
|
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
|
||||||
stub pyenv-hooks "virtualenv : echo '$HOOK_PATH'/virtualenv.bash"
|
stub pyenv-hooks "virtualenv : echo '$HOOK_PATH'/virtualenv.bash"
|
||||||
stub pyenv-exec "echo PYENV_VERSION=3.5.1 \"\$@\""
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "echo PYENV_VERSION=3.5.1 \"\$@\""
|
|
||||||
stub pyenv-rehash "echo rehashed"
|
stub pyenv-rehash "echo rehashed"
|
||||||
|
|
||||||
run pyenv-virtualenv "3.5.1" venv
|
mkdir -p "${PYENV_ROOT}/versions/3.2.1"
|
||||||
|
run pyenv-virtualenv "3.2.1" venv
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<-OUT
|
assert_output <<-OUT
|
||||||
before: ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
before: ${PYENV_ROOT}/versions/venv
|
||||||
PYENV_VERSION=3.5.1 virtualenv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/venv
|
||||||
PYENV_VERSION=3.5.1 python -s -m ensurepip
|
|
||||||
after: 0
|
after: 0
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-hooks
|
|
||||||
unstub pyenv-exec
|
|
||||||
unstub pyenv-rehash
|
|
||||||
teardown_version "3.5.1"
|
|
||||||
}
|
}
|
||||||
|
|||||||
110
test/init.bats
110
test/init.bats
@@ -1,110 +0,0 @@
|
|||||||
#!/usr/bin/env bats
|
|
||||||
|
|
||||||
load test_helper
|
|
||||||
|
|
||||||
@test "detect parent shell" {
|
|
||||||
unset PYENV_SHELL
|
|
||||||
SHELL=/bin/false run pyenv-virtualenv-init -
|
|
||||||
assert_success
|
|
||||||
assert_output_contains ' PROMPT_COMMAND="_pyenv_virtualenv_hook;$PROMPT_COMMAND";'
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "detect parent shell from script (sh)" {
|
|
||||||
unset PYENV_SHELL
|
|
||||||
printf '#!/bin/sh\necho "$(pyenv-virtualenv-init -)"' > "${TMP}/script.sh"
|
|
||||||
chmod +x ${TMP}/script.sh
|
|
||||||
run ${TMP}/script.sh
|
|
||||||
assert_success
|
|
||||||
assert_output_contains_not ' PROMPT_COMMAND="_pyenv_virtualenv_hook;$PROMPT_COMMAND";'
|
|
||||||
rm -f "${TMP}/script.sh"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "detect parent shell from script (bash)" {
|
|
||||||
unset PYENV_SHELL
|
|
||||||
printf '#!/bin/bash\necho "$(pyenv-virtualenv-init -)"' > "${TMP}/script.sh"
|
|
||||||
chmod +x ${TMP}/script.sh
|
|
||||||
run ${TMP}/script.sh
|
|
||||||
assert_success
|
|
||||||
assert_output_contains ' PROMPT_COMMAND="_pyenv_virtualenv_hook;$PROMPT_COMMAND";'
|
|
||||||
rm -f "${TMP}/script.sh"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "sh-compatible instructions" {
|
|
||||||
run pyenv-virtualenv-init bash
|
|
||||||
assert [ "$status" -eq 1 ]
|
|
||||||
assert_output_contains 'eval "$(pyenv virtualenv-init -)"'
|
|
||||||
|
|
||||||
run pyenv-virtualenv-init zsh
|
|
||||||
assert [ "$status" -eq 1 ]
|
|
||||||
assert_output_contains 'eval "$(pyenv virtualenv-init -)"'
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "fish instructions" {
|
|
||||||
run pyenv-virtualenv-init fish
|
|
||||||
assert [ "$status" -eq 1 ]
|
|
||||||
assert_output_contains 'status --is-interactive; and source (pyenv virtualenv-init -|psub)'
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "outputs bash-specific syntax" {
|
|
||||||
export PYENV_VIRTUALENV_ROOT="${TMP}/pyenv/plugins/pyenv-virtualenv"
|
|
||||||
run pyenv-virtualenv-init - bash
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
export PATH="${TMP}/pyenv/plugins/pyenv-virtualenv/shims:\${PATH}";
|
|
||||||
export PYENV_VIRTUALENV_INIT=1;
|
|
||||||
_pyenv_virtualenv_hook() {
|
|
||||||
local ret=\$?
|
|
||||||
if [ -n "\$VIRTUAL_ENV" ]; then
|
|
||||||
eval "\$(pyenv sh-activate --quiet || pyenv sh-deactivate --quiet || true)" || true
|
|
||||||
else
|
|
||||||
eval "\$(pyenv sh-activate --quiet || true)" || true
|
|
||||||
fi
|
|
||||||
return \$ret
|
|
||||||
};
|
|
||||||
if ! [[ "\$PROMPT_COMMAND" =~ _pyenv_virtualenv_hook ]]; then
|
|
||||||
PROMPT_COMMAND="_pyenv_virtualenv_hook;\$PROMPT_COMMAND";
|
|
||||||
fi
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "outputs fish-specific syntax" {
|
|
||||||
export PYENV_VIRTUALENV_ROOT="${TMP}/pyenv/plugins/pyenv-virtualenv"
|
|
||||||
run pyenv-virtualenv-init - fish
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
set -gx PATH '${TMP}/pyenv/plugins/pyenv-virtualenv/shims' \$PATH;
|
|
||||||
set -gx PYENV_VIRTUALENV_INIT 1;
|
|
||||||
function _pyenv_virtualenv_hook --on-event fish_prompt;
|
|
||||||
set -l ret \$status
|
|
||||||
if [ -n "\$VIRTUAL_ENV" ]
|
|
||||||
pyenv activate --quiet; or pyenv deactivate --quiet; or true
|
|
||||||
else
|
|
||||||
pyenv activate --quiet; or true
|
|
||||||
end
|
|
||||||
return \$ret
|
|
||||||
end
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "outputs zsh-specific syntax" {
|
|
||||||
export PYENV_VIRTUALENV_ROOT="${TMP}/pyenv/plugins/pyenv-virtualenv"
|
|
||||||
run pyenv-virtualenv-init - zsh
|
|
||||||
assert_success
|
|
||||||
assert_output <<EOS
|
|
||||||
export PATH="${TMP}/pyenv/plugins/pyenv-virtualenv/shims:\${PATH}";
|
|
||||||
export PYENV_VIRTUALENV_INIT=1;
|
|
||||||
_pyenv_virtualenv_hook() {
|
|
||||||
local ret=\$?
|
|
||||||
if [ -n "\$VIRTUAL_ENV" ]; then
|
|
||||||
eval "\$(pyenv sh-activate --quiet || pyenv sh-deactivate --quiet || true)" || true
|
|
||||||
else
|
|
||||||
eval "\$(pyenv sh-activate --quiet || true)" || true
|
|
||||||
fi
|
|
||||||
return \$ret
|
|
||||||
};
|
|
||||||
typeset -g -a precmd_functions
|
|
||||||
if [[ -z \$precmd_functions[(r)_pyenv_virtualenv_hook] ]]; then
|
|
||||||
precmd_functions=(_pyenv_virtualenv_hook \$precmd_functions);
|
|
||||||
fi
|
|
||||||
EOS
|
|
||||||
}
|
|
||||||
@@ -9,12 +9,9 @@ load test_helper
|
|||||||
|
|
||||||
cd usr
|
cd usr
|
||||||
|
|
||||||
assert [ -x bin/pyenv-activate ]
|
|
||||||
assert [ -x bin/pyenv-deactivate ]
|
|
||||||
assert [ -x bin/pyenv-sh-activate ]
|
assert [ -x bin/pyenv-sh-activate ]
|
||||||
assert [ -x bin/pyenv-sh-deactivate ]
|
assert [ -x bin/pyenv-sh-deactivate ]
|
||||||
assert [ -x bin/pyenv-virtualenv ]
|
assert [ -x bin/pyenv-virtualenv ]
|
||||||
assert [ -x bin/pyenv-virtualenv-init ]
|
|
||||||
assert [ -x bin/pyenv-virtualenv-prefix ]
|
assert [ -x bin/pyenv-virtualenv-prefix ]
|
||||||
assert [ -x bin/pyenv-virtualenvs ]
|
assert [ -x bin/pyenv-virtualenvs ]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,76 +0,0 @@
|
|||||||
#!/usr/bin/env bats
|
|
||||||
|
|
||||||
load test_helper
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
|
||||||
}
|
|
||||||
|
|
||||||
stub_pyenv() {
|
|
||||||
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-hooks "virtualenv : echo"
|
|
||||||
stub pyenv-rehash " : echo rehashed"
|
|
||||||
}
|
|
||||||
|
|
||||||
unstub_pyenv() {
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-hooks
|
|
||||||
unstub pyenv-rehash
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "install pip with ensurepip" {
|
|
||||||
export PYENV_VERSION="3.5.1"
|
|
||||||
setup_m_venv "3.5.1"
|
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
|
||||||
stub pyenv-exec "python -m venv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";mkdir -p \${PYENV_ROOT}/versions/3.5.1/envs/venv/bin"
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";touch \${PYENV_ROOT}/versions/3.5.1/envs/venv/bin/pip"
|
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=3.5.1 python -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
|
||||||
PYENV_VERSION=3.5.1/envs/venv python -s -m ensurepip
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
assert [ -e "${PYENV_ROOT}/versions/3.5.1/envs/venv/bin/pip" ]
|
|
||||||
|
|
||||||
unstub_pyenv
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
|
||||||
teardown_m_venv "3.5.1"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "install pip without using ensurepip" {
|
|
||||||
export PYENV_VERSION="3.3.6"
|
|
||||||
setup_m_venv "3.3.6"
|
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
|
||||||
stub pyenv-exec "python -m venv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";mkdir -p \${PYENV_ROOT}/versions/3.3.6/envs/venv/bin"
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
|
||||||
stub pyenv-exec "python -s */get-pip.py : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";touch \${PYENV_ROOT}/versions/3.3.6/envs/venv/bin/pip"
|
|
||||||
stub curl true
|
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=3.3.6 python -m venv ${PYENV_ROOT}/versions/3.3.6/envs/venv
|
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
|
||||||
PYENV_VERSION=3.3.6/envs/venv python -s ${TMP}/pyenv/cache/get-pip.py
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
assert [ -e "${PYENV_ROOT}/versions/3.3.6/envs/venv/bin/pip" ]
|
|
||||||
|
|
||||||
unstub_pyenv
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
|
||||||
teardown_m_venv "3.3.6"
|
|
||||||
}
|
|
||||||
246
test/prefix.bats
246
test/prefix.bats
@@ -1,246 +0,0 @@
|
|||||||
#!/usr/bin/env bats
|
|
||||||
|
|
||||||
load test_helper
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
|
||||||
}
|
|
||||||
|
|
||||||
create_version() {
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/$1/bin"
|
|
||||||
touch "${PYENV_ROOT}/versions/$1/bin/python"
|
|
||||||
chmod +x "${PYENV_ROOT}/versions/$1/bin/python"
|
|
||||||
}
|
|
||||||
|
|
||||||
remove_version() {
|
|
||||||
rm -fr "${PYENV_ROOT}/versions/$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
create_virtualenv() {
|
|
||||||
create_version "$1"
|
|
||||||
create_version "${2:-$1}"
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/$1/lib/python${2:-$1}"
|
|
||||||
echo "${PYENV_ROOT}/versions/${2:-$1}" > "${PYENV_ROOT}/versions/$1/lib/python${2:-$1}/orig-prefix.txt"
|
|
||||||
touch "${PYENV_ROOT}/versions/$1/bin/activate"
|
|
||||||
}
|
|
||||||
|
|
||||||
create_virtualenv_jython() {
|
|
||||||
create_version "$1"
|
|
||||||
create_version "${2:-$1}"
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/$1/Lib/"
|
|
||||||
echo "${PYENV_ROOT}/versions/${2:-$1}" > "${PYENV_ROOT}/versions/$1/Lib/orig-prefix.txt"
|
|
||||||
touch "${PYENV_ROOT}/versions/$1/bin/activate"
|
|
||||||
}
|
|
||||||
|
|
||||||
create_virtualenv_pypy() {
|
|
||||||
create_version "$1"
|
|
||||||
create_version "${2:-$1}"
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/$1/lib-python/${2:-$1}"
|
|
||||||
echo "${PYENV_ROOT}/versions/${2:-$1}" > "${PYENV_ROOT}/versions/$1/lib-python/${2:-$1}/orig-prefix.txt"
|
|
||||||
touch "${PYENV_ROOT}/versions/$1/bin/activate"
|
|
||||||
}
|
|
||||||
|
|
||||||
remove_virtualenv() {
|
|
||||||
remove_version "$1"
|
|
||||||
remove_version "${2:-$1}"
|
|
||||||
}
|
|
||||||
|
|
||||||
create_m_venv() {
|
|
||||||
create_version "$1"
|
|
||||||
create_version "${2:-$1}"
|
|
||||||
echo "home = ${PYENV_ROOT}/versions/${2:-$1}/bin" > "${PYENV_ROOT}/versions/$1/pyvenv.cfg"
|
|
||||||
touch "${PYENV_ROOT}/versions/$1/bin/activate"
|
|
||||||
}
|
|
||||||
|
|
||||||
remove_m_venv() {
|
|
||||||
remove_version "${2:-$1}"
|
|
||||||
}
|
|
||||||
|
|
||||||
create_conda() {
|
|
||||||
create_version "$1"
|
|
||||||
create_version "${2:-$1}"
|
|
||||||
touch "${PYENV_ROOT}/versions/$1/bin/conda"
|
|
||||||
touch "${PYENV_ROOT}/versions/$1/bin/activate"
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/${2:-$1}/bin"
|
|
||||||
touch "${PYENV_ROOT}/versions/${2:-$1}/bin/conda"
|
|
||||||
touch "${PYENV_ROOT}/versions/${2:-$1}/bin/activate"
|
|
||||||
}
|
|
||||||
|
|
||||||
remove_conda() {
|
|
||||||
remove_version "${2:-$1}"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "display prefix of virtualenv created by virtualenv" {
|
|
||||||
stub pyenv-version-name "echo foo"
|
|
||||||
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\""
|
|
||||||
create_virtualenv "foo" "2.7.11"
|
|
||||||
|
|
||||||
PYENV_VERSION="foo" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
${PYENV_ROOT}/versions/2.7.11
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
remove_virtualenv "foo" "2.7.11"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "display prefix of virtualenv created by virtualenv (pypy)" {
|
|
||||||
stub pyenv-version-name "echo foo"
|
|
||||||
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\""
|
|
||||||
create_virtualenv_pypy "foo" "pypy-4.0.1"
|
|
||||||
|
|
||||||
PYENV_VERSION="foo" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
${PYENV_ROOT}/versions/pypy-4.0.1
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
remove_virtualenv "foo" "pypy-4.0.1"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "display prefix of virtualenv created by virtualenv (jython)" {
|
|
||||||
stub pyenv-version-name "echo foo"
|
|
||||||
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\""
|
|
||||||
create_virtualenv_jython "foo" "jython-2.7.0"
|
|
||||||
|
|
||||||
PYENV_VERSION="foo" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
${PYENV_ROOT}/versions/jython-2.7.0
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
remove_virtualenv "foo" "jython-2.7.0"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "display prefixes of virtualenv created by virtualenv" {
|
|
||||||
stub pyenv-version-name "echo foo:bar"
|
|
||||||
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\"" \
|
|
||||||
"bar : echo \"${PYENV_ROOT}/versions/bar\""
|
|
||||||
create_virtualenv "foo" "2.7.11"
|
|
||||||
create_virtualenv "bar" "3.5.1"
|
|
||||||
|
|
||||||
PYENV_VERSION="foo:bar" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
${PYENV_ROOT}/versions/2.7.11:${PYENV_ROOT}/versions/3.5.1
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
remove_virtualenv "foo" "2.7.11"
|
|
||||||
remove_virtualenv "bar" "3.5.1"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "display prefix of virtualenv created by venv" {
|
|
||||||
stub pyenv-version-name "echo foo"
|
|
||||||
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\""
|
|
||||||
create_m_venv "foo" "3.3.6"
|
|
||||||
|
|
||||||
PYENV_VERSION="foo" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
${PYENV_ROOT}/versions/3.3.6
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
remove_m_venv "foo" "3.3.6"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "display prefixes of virtualenv created by venv" {
|
|
||||||
stub pyenv-version-name "echo foo:bar"
|
|
||||||
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\"" \
|
|
||||||
"bar : echo \"${PYENV_ROOT}/versions/bar\""
|
|
||||||
create_m_venv "foo" "3.3.6"
|
|
||||||
create_m_venv "bar" "3.4.4"
|
|
||||||
|
|
||||||
PYENV_VERSION="foo:bar" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
${PYENV_ROOT}/versions/3.3.6:${PYENV_ROOT}/versions/3.4.4
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
remove_m_venv "foo" "3.3.6"
|
|
||||||
remove_m_venv "bar" "3.4.4"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "display prefix of virtualenv created by conda" {
|
|
||||||
stub pyenv-version-name "echo miniconda3-3.16.0/envs/foo"
|
|
||||||
stub pyenv-prefix "miniconda3-3.16.0/envs/foo : echo \"${PYENV_ROOT}/versions/miniconda3-3.16.0/envs/foo\""
|
|
||||||
create_conda "miniconda3-3.16.0/envs/foo" "miniconda3-3.16.0"
|
|
||||||
|
|
||||||
PYENV_VERSION="miniconda3-3.16.0/envs/foo" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
${PYENV_ROOT}/versions/miniconda3-3.16.0/envs/foo
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
remove_conda "miniconda3-3.16.0/envs/foo" "miniconda3-3.16.0"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "should fail if the version is the system" {
|
|
||||||
stub pyenv-version-name "echo system"
|
|
||||||
|
|
||||||
PYENV_VERSION="system" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_failure
|
|
||||||
assert_output <<OUT
|
|
||||||
pyenv-virtualenv: version \`system' is not a virtualenv
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "should fail if the version is not a virtualenv" {
|
|
||||||
stub pyenv-version-name "echo 3.4.4"
|
|
||||||
stub pyenv-prefix "3.4.4 : echo \"${PYENV_ROOT}/versions/3.4.4\""
|
|
||||||
create_version "3.4.4"
|
|
||||||
|
|
||||||
PYENV_VERSION="3.4.4" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_failure
|
|
||||||
assert_output <<OUT
|
|
||||||
pyenv-virtualenv: version \`3.4.4' is not a virtualenv
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
remove_version "3.4.4"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "should fail if one of the versions is not a virtualenv" {
|
|
||||||
stub pyenv-version-name "echo venv33:3.4.4"
|
|
||||||
stub pyenv-prefix "venv33 : echo \"${PYENV_ROOT}/versions/venv33\"" \
|
|
||||||
"3.4.4 : echo \"${PYENV_ROOT}/versions/3.4.4\""
|
|
||||||
create_virtualenv "venv33" "3.3.6"
|
|
||||||
create_version "3.4.4"
|
|
||||||
|
|
||||||
PYENV_VERSION="venv33:3.4.4" run pyenv-virtualenv-prefix
|
|
||||||
|
|
||||||
assert_failure
|
|
||||||
assert_output <<OUT
|
|
||||||
pyenv-virtualenv: version \`3.4.4' is not a virtualenv
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
remove_virtualenv "venv33" "3.3.6"
|
|
||||||
remove_version "3.4.4"
|
|
||||||
}
|
|
||||||
104
test/python.bats
104
test/python.bats
@@ -1,104 +0,0 @@
|
|||||||
#!/usr/bin/env bats
|
|
||||||
|
|
||||||
load test_helper
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
|
||||||
export PYENV_VERSION="2.7.8"
|
|
||||||
setup_version "2.7.8"
|
|
||||||
create_executable "2.7.8" "virtualenv"
|
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-hooks "virtualenv : echo"
|
|
||||||
stub pyenv-rehash " : true"
|
|
||||||
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
|
||||||
stub curl true
|
|
||||||
}
|
|
||||||
|
|
||||||
teardown() {
|
|
||||||
unstub curl
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-hooks
|
|
||||||
unstub pyenv-rehash
|
|
||||||
teardown_version "2.7.8"
|
|
||||||
rm -fr "$TMP"/*
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "resolve python executable from enabled version" {
|
|
||||||
remove_executable "2.7.7" "python2.7"
|
|
||||||
create_executable "2.7.8" "python2.7"
|
|
||||||
remove_executable "2.7.9" "python2.7"
|
|
||||||
|
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
|
||||||
stub pyenv-exec "virtualenv --verbose * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
|
||||||
stub pyenv-which "python2.7 : echo ${PYENV_ROOT}/versions/2.7.8/bin/python2.7"
|
|
||||||
|
|
||||||
run pyenv-virtualenv --verbose --python=python2.7 venv
|
|
||||||
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=2.7.8 virtualenv --verbose --python=${PYENV_ROOT}/versions/2.7.8/bin/python2.7 ${PYENV_ROOT}/versions/2.7.8/envs/venv
|
|
||||||
OUT
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub pyenv-which
|
|
||||||
unstub pyenv-exec
|
|
||||||
|
|
||||||
remove_executable "2.7.7" "python2.7"
|
|
||||||
remove_executable "2.7.8" "python2.7"
|
|
||||||
remove_executable "2.7.9" "python2.7"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "resolve python executable from other versions" {
|
|
||||||
remove_executable "2.7.7" "python2.7"
|
|
||||||
remove_executable "2.7.8" "python2.7"
|
|
||||||
create_executable "2.7.9" "python2.7"
|
|
||||||
|
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
|
||||||
stub pyenv-exec "virtualenv --verbose * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
|
||||||
stub pyenv-which "python2.7 : false"
|
|
||||||
stub pyenv-whence "python2.7 : echo 2.7.7; echo 2.7.8; echo 2.7.9"
|
|
||||||
stub pyenv-which "python2.7 : echo ${PYENV_ROOT}/versions/2.7.9/bin/python2.7"
|
|
||||||
|
|
||||||
run pyenv-virtualenv --verbose --python=python2.7 venv
|
|
||||||
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=2.7.8 virtualenv --verbose --python=${PYENV_ROOT}/versions/2.7.9/bin/python2.7 ${PYENV_ROOT}/versions/2.7.8/envs/venv
|
|
||||||
OUT
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub pyenv-which
|
|
||||||
unstub pyenv-whence
|
|
||||||
unstub pyenv-exec
|
|
||||||
|
|
||||||
remove_executable "2.7.7" "python2.7"
|
|
||||||
remove_executable "2.7.8" "python2.7"
|
|
||||||
remove_executable "2.7.9" "python2.7"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "cannot resolve python executable" {
|
|
||||||
remove_executable "2.7.7" "python2.7"
|
|
||||||
remove_executable "2.7.8" "python2.7"
|
|
||||||
remove_executable "2.7.9" "python2.7"
|
|
||||||
|
|
||||||
stub pyenv-which "python2.7 : false"
|
|
||||||
stub pyenv-whence "python2.7 : false"
|
|
||||||
stub pyenv-which "python2.7 : false"
|
|
||||||
|
|
||||||
run pyenv-virtualenv --verbose --python=python2.7 venv
|
|
||||||
|
|
||||||
assert_output <<OUT
|
|
||||||
pyenv-virtualenv: \`python2.7' is not installed in pyenv.
|
|
||||||
OUT
|
|
||||||
assert_failure
|
|
||||||
|
|
||||||
unstub pyenv-which
|
|
||||||
unstub pyenv-whence
|
|
||||||
|
|
||||||
remove_executable "2.7.7" "python2.7"
|
|
||||||
remove_executable "2.7.8" "python2.7"
|
|
||||||
remove_executable "2.7.9" "python2.7"
|
|
||||||
}
|
|
||||||
235
test/pyvenv.bats
235
test/pyvenv.bats
@@ -7,166 +7,185 @@ setup() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
stub_pyenv() {
|
stub_pyenv() {
|
||||||
|
export PYENV_VERSION="$1"
|
||||||
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/\${PYENV_VERSION}'"
|
||||||
stub pyenv-hooks "virtualenv : echo"
|
stub pyenv-hooks "virtualenv : echo"
|
||||||
stub pyenv-rehash " : echo rehashed"
|
stub pyenv-rehash " : echo rehashed"
|
||||||
}
|
}
|
||||||
|
|
||||||
unstub_pyenv() {
|
unstub_pyenv() {
|
||||||
|
unset PYENV_VERSION
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
unstub pyenv-hooks
|
unstub pyenv-hooks
|
||||||
unstub pyenv-rehash
|
unstub pyenv-rehash
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "use venv if virtualenv is not available" {
|
create_executable() {
|
||||||
export PYENV_VERSION="3.5.1"
|
mkdir -p "${PYENV_ROOT}/versions/$1/bin"
|
||||||
setup_m_venv "3.5.1"
|
touch "${PYENV_ROOT}/versions/$1/bin/$2"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
chmod +x "${PYENV_ROOT}/versions/$1/bin/$2"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
|
||||||
stub pyenv-exec "python -m venv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=3.5.1 python -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub_pyenv
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
|
||||||
teardown_m_venv "3.5.1"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "not use venv if virtualenv is available" {
|
remove_executable() {
|
||||||
export PYENV_VERSION="3.5.1"
|
rm -f "${PYENV_ROOT}/versions/$1/bin/$2"
|
||||||
setup_m_venv "3.5.1"
|
|
||||||
create_executable "3.5.1" "virtualenv"
|
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=3.5.1 virtualenv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub_pyenv
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
|
||||||
teardown_m_venv "3.5.1"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "install virtualenv if venv is not avaialble" {
|
@test "use pyvenv if virtualenv is not available" {
|
||||||
export PYENV_VERSION="3.2.1"
|
stub_pyenv "3.4.0"
|
||||||
setup_version "3.2.1"
|
stub pyenv-which "virtualenv : false" \
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
"pyvenv : echo '${PYENV_ROOT}/versions/bin/pyvenv'"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\"" \
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
"bin=\"${PYENV_ROOT}/versions/venv/bin\";mkdir -p \"\$bin\";touch \"\$bin/pip3.4\";echo PYENV_VERSION=\${PYENV_VERSION} ensurepip" \
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
"echo pip3.4"
|
||||||
stub pyenv-exec "pip install virtualenv* : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-prefix "venv : echo '${PYENV_ROOT}/versions/venv'"
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
|
unstub_pyenv
|
||||||
|
unstub pyenv-which
|
||||||
|
unstub pyenv-exec
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.2.1 pip install virtualenv==13.1.2
|
PYENV_VERSION=3.4.0 pyvenv ${PYENV_ROOT}/versions/venv
|
||||||
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/3.2.1/envs/venv
|
PYENV_VERSION=venv ensurepip
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -e "${PYENV_ROOT}/versions/venv/bin/pip" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "not use pyvenv if virtualenv is available" {
|
||||||
|
stub_pyenv "3.4.0"
|
||||||
|
stub pyenv-which "virtualenv : echo '${PYENV_ROOT}/versions/bin/virtualenv'" \
|
||||||
|
"pyvenv : echo '${PYENV_ROOT}/versions/bin/pyvenv"
|
||||||
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
|
|
||||||
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-which
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_version "3.2.1"
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
PYENV_VERSION=3.4.0 virtualenv ${PYENV_ROOT}/versions/venv
|
||||||
|
rehashed
|
||||||
|
OUT
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "install virtualenv if pyvenv is not avaialble" {
|
||||||
|
stub_pyenv "3.2.1"
|
||||||
|
stub pyenv-which "virtualenv : false" \
|
||||||
|
"pyvenv : false"
|
||||||
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\"" \
|
||||||
|
"echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
|
|
||||||
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
|
unstub_pyenv
|
||||||
|
unstub pyenv-which
|
||||||
|
unstub pyenv-exec
|
||||||
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
PYENV_VERSION=3.2.1 pip install virtualenv
|
||||||
|
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/venv
|
||||||
|
rehashed
|
||||||
|
OUT
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "install virtualenv if -p has given" {
|
@test "install virtualenv if -p has given" {
|
||||||
export PYENV_VERSION="3.5.1"
|
stub_pyenv "3.4.0"
|
||||||
setup_m_venv "3.5.1"
|
stub pyenv-which "virtualenv : false"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
stub pyenv-which "pyvenv : echo '${PYENV_ROOT}/versions/bin/pyvenv'"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
|
||||||
stub pyenv-exec "pip install virtualenv : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv -p ${TMP}/python3 venv
|
run pyenv-virtualenv -p python3 venv
|
||||||
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=3.5.1 pip install virtualenv
|
|
||||||
PYENV_VERSION=3.5.1 virtualenv --python=${TMP}/python3 ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-which
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_m_venv "3.5.1"
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
PYENV_VERSION=3.4.0 pip install virtualenv
|
||||||
|
PYENV_VERSION=3.4.0 virtualenv --python=python3 ${PYENV_ROOT}/versions/venv
|
||||||
|
rehashed
|
||||||
|
OUT
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "install virtualenv if --python has given" {
|
@test "install virtualenv if --python has given" {
|
||||||
export PYENV_VERSION="3.5.1"
|
stub_pyenv "3.4.0"
|
||||||
setup_m_venv "3.5.1"
|
stub pyenv-which "virtualenv : false"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
stub pyenv-which "pyvenv : echo '${PYENV_ROOT}/versions/bin/pyvenv'"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
|
||||||
stub pyenv-exec "pip install virtualenv : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
|
||||||
|
|
||||||
run pyenv-virtualenv --python=${TMP}/python3 venv
|
run pyenv-virtualenv --python=python3 venv
|
||||||
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=3.5.1 pip install virtualenv
|
|
||||||
PYENV_VERSION=3.5.1 virtualenv --python=${TMP}/python3 ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-which
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_m_venv "3.5.1"
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
PYENV_VERSION=3.4.0 pip install virtualenv
|
||||||
|
PYENV_VERSION=3.4.0 virtualenv --python=python3 ${PYENV_ROOT}/versions/venv
|
||||||
|
rehashed
|
||||||
|
OUT
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "install virtualenv with unsetting troublesome pip options" {
|
@test "install virtualenv with unsetting troublesome pip options" {
|
||||||
export PYENV_VERSION="3.2.1"
|
stub_pyenv "3.2.1"
|
||||||
setup_version "3.2.1"
|
stub pyenv-which "virtualenv : false" \
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
"pyvenv : false"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-exec "echo PIP_REQUIRE_VENV=\${PIP_REQUIRE_VENV} PYENV_VERSION=\${PYENV_VERSION} \"\$@\"" \
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
"echo PIP_REQUIRE_VENV=\${PIP_REQUIRE_VENV} PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
|
||||||
stub pyenv-exec "pip install virtualenv* : echo PIP_REQUIRE_VENV=\${PIP_REQUIRE_VENV} PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "virtualenv * : echo PIP_REQUIRE_VENV=\${PIP_REQUIRE_VENV} PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
|
|
||||||
PIP_REQUIRE_VENV="true" run pyenv-virtualenv venv
|
PIP_REQUIRE_VENV="true" run pyenv-virtualenv venv
|
||||||
|
|
||||||
|
unstub_pyenv
|
||||||
|
unstub pyenv-which
|
||||||
|
unstub pyenv-exec
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PIP_REQUIRE_VENV= PYENV_VERSION=3.2.1 pip install virtualenv==13.1.2
|
PIP_REQUIRE_VENV= PYENV_VERSION=3.2.1 pip install virtualenv
|
||||||
PIP_REQUIRE_VENV= PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/3.2.1/envs/venv
|
PIP_REQUIRE_VENV= PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/venv
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "install pip without using ensurepip" {
|
||||||
|
stub_pyenv "3.3.0"
|
||||||
|
stub pyenv-which "virtualenv : false" \
|
||||||
|
"pyvenv : echo '${PYENV_ROOT}/versions/bin/pyvenv'" \
|
||||||
|
"pip : echo no pip; false"
|
||||||
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\"" \
|
||||||
|
"echo PYENV_VERSION=\${PYENV_VERSION} no ensurepip; false" \
|
||||||
|
"echo PYENV_VERSION=\${PYENV_VERSION} no setuptools; false" \
|
||||||
|
"echo PYENV_VERSION=\${PYENV_VERSION} setuptools" \
|
||||||
|
"bin=\"${PYENV_ROOT}/versions/venv/bin\";mkdir -p \"\$bin\";touch \"\$bin/pip\";echo PYENV_VERSION=\${PYENV_VERSION} pip"
|
||||||
|
stub curl "echo ez_setup.py" \
|
||||||
|
"echo get_pip.py"
|
||||||
|
|
||||||
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-which
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_version "3.2.1"
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
PYENV_VERSION=3.3.0 pyvenv ${PYENV_ROOT}/versions/venv
|
||||||
|
PYENV_VERSION=venv no ensurepip
|
||||||
|
PYENV_VERSION=venv setuptools
|
||||||
|
PYENV_VERSION=venv pip
|
||||||
|
rehashed
|
||||||
|
OUT
|
||||||
|
assert [ -e "${PYENV_ROOT}/versions/venv/bin/pip" ]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -96,75 +96,3 @@ assert_output_contains() {
|
|||||||
} | flunk
|
} | flunk
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
assert_output_contains_not() {
|
|
||||||
local expected="$1"
|
|
||||||
echo "$output" | grep -F "$expected" >/dev/null && {
|
|
||||||
{ echo "expected output to not contain $expected"
|
|
||||||
echo "actual: $output"
|
|
||||||
} | flunk; return
|
|
||||||
}
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
create_executable() {
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/$1/bin"
|
|
||||||
touch "${PYENV_ROOT}/versions/$1/bin/$2"
|
|
||||||
chmod +x "${PYENV_ROOT}/versions/$1/bin/$2"
|
|
||||||
}
|
|
||||||
|
|
||||||
remove_executable() {
|
|
||||||
rm -f "${PYENV_ROOT}/versions/$1/bin/$2"
|
|
||||||
}
|
|
||||||
|
|
||||||
setup_version() {
|
|
||||||
create_executable "$1" "python"
|
|
||||||
remove_executable "$1" "activate"
|
|
||||||
remove_executable "$1" "conda"
|
|
||||||
}
|
|
||||||
|
|
||||||
teardown_version() {
|
|
||||||
rm -fr "${PYENV_ROOT}/versions/$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
setup_virtualenv() {
|
|
||||||
create_executable "$1" "python"
|
|
||||||
create_executable "$1" "activate"
|
|
||||||
remove_executable "$1" "conda"
|
|
||||||
}
|
|
||||||
|
|
||||||
teardown_virtualenv() {
|
|
||||||
rm -fr "${PYENV_ROOT}/versions/$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
setup_m_venv() {
|
|
||||||
create_executable "$1" "python"
|
|
||||||
create_executable "$1" "activate"
|
|
||||||
remove_executable "$1" "conda"
|
|
||||||
}
|
|
||||||
|
|
||||||
teardown_m_venv() {
|
|
||||||
rm -fr "${PYENV_ROOT}/versions/$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
setup_conda() {
|
|
||||||
create_executable "$1" "python"
|
|
||||||
create_executable "$1" "activate"
|
|
||||||
create_executable "$1" "conda"
|
|
||||||
local conda="$1"
|
|
||||||
shift 1
|
|
||||||
local env
|
|
||||||
for env; do
|
|
||||||
create_executable "${conda}/envs/${env}" "python"
|
|
||||||
create_executable "${conda}/envs/${env}" "activate"
|
|
||||||
create_executable "${conda}/envs/${env}" "conda"
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/${conda}/envs/${env}/etc/conda/activate.d"
|
|
||||||
touch "${PYENV_ROOT}/versions/${conda}/envs/${env}/etc/conda/activate.d/activate.sh"
|
|
||||||
mkdir -p "${PYENV_ROOT}/versions/${conda}/envs/${env}/etc/conda/deactivate.d"
|
|
||||||
touch "${PYENV_ROOT}/versions/${conda}/envs/${env}/etc/conda/deactivate.d/deactivate.sh"
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
teardown_conda() {
|
|
||||||
rm -fr "${PYENV_ROOT}/versions/$1"
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -4,34 +4,34 @@ load test_helper
|
|||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
export PYENV_ROOT="${TMP}/pyenv"
|
export PYENV_ROOT="${TMP}/pyenv"
|
||||||
|
export PYENV_VIRTUALENV_VERSION="20140421"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "display virtualenv version" {
|
@test "display virtualenv version" {
|
||||||
setup_virtualenv "2.7.7"
|
stub pyenv-which "virtualenv : true"
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/2.7.7'"
|
stub pyenv-which "pyvenv : true"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
|
||||||
stub pyenv-exec "virtualenv --version : echo \"1.11\""
|
stub pyenv-exec "virtualenv --version : echo \"1.11\""
|
||||||
|
|
||||||
run pyenv-virtualenv --version
|
run pyenv-virtualenv --version
|
||||||
|
|
||||||
assert_success
|
unstub pyenv-which
|
||||||
[[ "$output" == "pyenv-virtualenv "?.?.?" (virtualenv 1.11)" ]]
|
|
||||||
|
|
||||||
unstub pyenv-prefix
|
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_virtualenv "2.7.7"
|
|
||||||
|
assert_success
|
||||||
|
assert_output "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (virtualenv 1.11)"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "display venv version" {
|
@test "display pyvenv version" {
|
||||||
setup_m_venv "3.4.1"
|
stub pyenv-which "virtualenv : false"
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.4.1'"
|
stub pyenv-which "pyvenv : echo \"${PYENV_ROOT}/versions/3.3.3/bin/pyvenv\""
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
stub pyenv-which "pyvenv : echo \"${PYENV_ROOT}/versions/3.3.3/bin/pyvenv\""
|
||||||
|
stub pyenv-root "echo \"${PYENV_ROOT}\""
|
||||||
|
|
||||||
run pyenv-virtualenv --version
|
run pyenv-virtualenv --version
|
||||||
|
|
||||||
assert_success
|
unstub pyenv-which
|
||||||
[[ "$output" == "pyenv-virtualenv "?.?.?" (python -m venv)" ]]
|
unstub pyenv-root
|
||||||
|
|
||||||
unstub pyenv-prefix
|
assert_success
|
||||||
teardown_m_venv "3.4.1"
|
assert_output "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (pyvenv 3.3.3)"
|
||||||
}
|
}
|
||||||
|
|||||||
145
test/virtualenv-prefix.bats
Normal file
145
test/virtualenv-prefix.bats
Normal file
@@ -0,0 +1,145 @@
|
|||||||
|
#!/usr/bin/env bats
|
||||||
|
|
||||||
|
load test_helper
|
||||||
|
|
||||||
|
setup() {
|
||||||
|
export PYENV_ROOT="${TMP}/pyenv"
|
||||||
|
}
|
||||||
|
|
||||||
|
create_virtualenv() {
|
||||||
|
mkdir -p "${PYENV_ROOT}/versions/$1/bin"
|
||||||
|
touch "${PYENV_ROOT}/versions/$1/bin/activate"
|
||||||
|
}
|
||||||
|
|
||||||
|
remove_virtualenv() {
|
||||||
|
rm -fr "${PYENV_ROOT}/versions/$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "display prefix with using sys.real_prefix" {
|
||||||
|
stub pyenv-version-name "echo venv27"
|
||||||
|
stub pyenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
||||||
|
stub pyenv-exec "echo \"${PYENV_ROOT}/versions/2.7.6\""
|
||||||
|
create_virtualenv "venv27"
|
||||||
|
|
||||||
|
PYENV_VERSION="venv27" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
|
unstub pyenv-version-name
|
||||||
|
unstub pyenv-prefix
|
||||||
|
unstub pyenv-exec
|
||||||
|
remove_virtualenv "venv27"
|
||||||
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
${PYENV_ROOT}/versions/2.7.6
|
||||||
|
OUT
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "display prefixes with using sys.real_prefix" {
|
||||||
|
stub pyenv-version-name "echo venv27:venv32"
|
||||||
|
stub pyenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\"" \
|
||||||
|
"venv32 : echo \"${PYENV_ROOT}/versions/venv32\""
|
||||||
|
stub pyenv-exec "echo \"${PYENV_ROOT}/versions/2.7.6\"" \
|
||||||
|
"echo \"${PYENV_ROOT}/versions/3.2.1\""
|
||||||
|
create_virtualenv "venv27"
|
||||||
|
create_virtualenv "venv32"
|
||||||
|
|
||||||
|
PYENV_VERSION="venv27:venv32" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
|
unstub pyenv-version-name
|
||||||
|
unstub pyenv-prefix
|
||||||
|
unstub pyenv-exec
|
||||||
|
remove_virtualenv "venv27"
|
||||||
|
remove_virtualenv "venv32"
|
||||||
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
${PYENV_ROOT}/versions/2.7.6:${PYENV_ROOT}/versions/3.2.1
|
||||||
|
OUT
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "display prefix with using sys.base_prefix" {
|
||||||
|
stub pyenv-version-name "echo venv33"
|
||||||
|
stub pyenv-prefix "venv33 : echo \"${PYENV_ROOT}/versions/venv33\""
|
||||||
|
stub pyenv-exec "false" \
|
||||||
|
"echo \"${PYENV_ROOT}/versions/3.3.3\""
|
||||||
|
create_virtualenv "venv33"
|
||||||
|
|
||||||
|
PYENV_VERSION="venv33" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
|
unstub pyenv-version-name
|
||||||
|
unstub pyenv-prefix
|
||||||
|
unstub pyenv-exec
|
||||||
|
remove_virtualenv "venv33"
|
||||||
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
${PYENV_ROOT}/versions/3.3.3
|
||||||
|
OUT
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "display prefixes with using sys.base_prefix" {
|
||||||
|
stub pyenv-version-name "echo venv33:venv34"
|
||||||
|
stub pyenv-prefix "venv33 : echo \"${PYENV_ROOT}/versions/venv33\"" \
|
||||||
|
"venv34 : echo \"${PYENV_ROOT}/versions/venv34\""
|
||||||
|
stub pyenv-exec "false" \
|
||||||
|
"echo \"${PYENV_ROOT}/versions/3.3.3\"" \
|
||||||
|
"false" \
|
||||||
|
"echo \"${PYENV_ROOT}/versions/3.4.0\""
|
||||||
|
create_virtualenv "venv33"
|
||||||
|
create_virtualenv "venv34"
|
||||||
|
|
||||||
|
PYENV_VERSION="venv33:venv34" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
|
unstub pyenv-version-name
|
||||||
|
unstub pyenv-prefix
|
||||||
|
unstub pyenv-exec
|
||||||
|
remove_virtualenv "venv33"
|
||||||
|
remove_virtualenv "venv34"
|
||||||
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
${PYENV_ROOT}/versions/3.3.3:${PYENV_ROOT}/versions/3.4.0
|
||||||
|
OUT
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "should fail if the version is not a virtualenv" {
|
||||||
|
stub pyenv-version-name "echo 3.4.0"
|
||||||
|
stub pyenv-prefix "3.4.0 : echo \"${PYENV_ROOT}/versions/3.4.0\""
|
||||||
|
mkdir -p "${PYENV_ROOT}/versions/3.4.0"
|
||||||
|
|
||||||
|
PYENV_VERSION="3.4.0" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
|
unstub pyenv-version-name
|
||||||
|
unstub pyenv-prefix
|
||||||
|
rmdir "${PYENV_ROOT}/versions/3.4.0"
|
||||||
|
|
||||||
|
assert_failure
|
||||||
|
assert_output <<OUT
|
||||||
|
pyenv-virtualenv: version \`3.4.0' is not a virtualenv
|
||||||
|
OUT
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "should fail if one of the versions is not a virtualenv" {
|
||||||
|
stub pyenv-version-name "echo venv33:3.4.0"
|
||||||
|
stub pyenv-prefix "venv33 : echo \"${PYENV_ROOT}/versions/venv33\"" \
|
||||||
|
"3.4.0 : echo \"${PYENV_ROOT}/versions/3.4.0\""
|
||||||
|
stub pyenv-exec "false" \
|
||||||
|
"echo \"${PYENV_ROOT}/versions/3.3.3\""
|
||||||
|
create_virtualenv "venv33"
|
||||||
|
mkdir -p "${PYENV_ROOT}/versions/3.4.0"
|
||||||
|
|
||||||
|
PYENV_VERSION="venv33:3.4.0" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
|
unstub pyenv-version-name
|
||||||
|
unstub pyenv-prefix
|
||||||
|
unstub pyenv-exec
|
||||||
|
remove_virtualenv "venv33"
|
||||||
|
rmdir "${PYENV_ROOT}/versions/3.4.0"
|
||||||
|
|
||||||
|
assert_failure
|
||||||
|
assert_output <<OUT
|
||||||
|
pyenv-virtualenv: version \`3.4.0' is not a virtualenv
|
||||||
|
OUT
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -7,184 +7,88 @@ setup() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
stub_pyenv() {
|
stub_pyenv() {
|
||||||
setup_version "${PYENV_VERSION}"
|
export PYENV_VERSION="$1"
|
||||||
create_executable "${PYENV_VERSION}" "virtualenv"
|
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/\${PYENV_VERSION}'"
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-which "virtualenv : echo '${PYENV_ROOT}/versions/bin/virtualenv'" \
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
"pyvenv : false"
|
||||||
stub pyenv-hooks "virtualenv : echo"
|
stub pyenv-hooks "virtualenv : echo"
|
||||||
stub pyenv-rehash " : echo rehashed"
|
stub pyenv-rehash " : echo rehashed"
|
||||||
}
|
}
|
||||||
|
|
||||||
unstub_pyenv() {
|
unstub_pyenv() {
|
||||||
|
unset PYENV_VERSION
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
|
unstub pyenv-which
|
||||||
unstub pyenv-hooks
|
unstub pyenv-hooks
|
||||||
unstub pyenv-rehash
|
unstub pyenv-rehash
|
||||||
teardown_version "${PYENV_VERSION}"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "create virtualenv from given version" {
|
@test "create virtualenv from given version" {
|
||||||
export PYENV_VERSION="2.7.11"
|
stub_pyenv "3.2.1"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
|
||||||
stub curl true
|
|
||||||
|
|
||||||
run pyenv-virtualenv "2.7.11" "venv"
|
run pyenv-virtualenv "3.2.1" "venv"
|
||||||
|
|
||||||
|
unstub_pyenv
|
||||||
|
unstub pyenv-exec
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=2.7.11 virtualenv ${PYENV_ROOT}/versions/2.7.11/envs/venv
|
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/venv
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub_pyenv
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
|
||||||
unstub curl
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "create virtualenv from current version" {
|
@test "create virtualenv from current version" {
|
||||||
export PYENV_VERSION="2.7.11"
|
stub_pyenv "3.2.1"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
|
||||||
stub curl true
|
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=2.7.11 virtualenv ${PYENV_ROOT}/versions/2.7.11/envs/venv
|
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
unstub curl
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/venv
|
||||||
|
rehashed
|
||||||
|
OUT
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "create virtualenv with short options" {
|
@test "create virtualenv with short options" {
|
||||||
export PYENV_VERSION="2.7.11"
|
stub_pyenv "3.2.1"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
|
||||||
stub curl true
|
|
||||||
|
|
||||||
run pyenv-virtualenv -v -p ${TMP}/python venv
|
run pyenv-virtualenv -v -p python venv
|
||||||
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=2.7.11 virtualenv --verbose --python=${TMP}/python ${PYENV_ROOT}/versions/2.7.11/envs/venv
|
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
unstub curl
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<OUT
|
||||||
|
PYENV_VERSION=3.2.1 virtualenv --verbose --python=python ${PYENV_ROOT}/versions/venv
|
||||||
|
rehashed
|
||||||
|
OUT
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "create virtualenv with long options" {
|
@test "create virtualenv with long options" {
|
||||||
export PYENV_VERSION="2.7.11"
|
stub_pyenv "3.2.1"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
stub pyenv-version-name "echo \${PYENV_VERSION}"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-exec "echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
|
||||||
stub curl true
|
|
||||||
|
|
||||||
run pyenv-virtualenv --verbose --python=${TMP}/python venv
|
run pyenv-virtualenv --verbose --python=python venv
|
||||||
|
|
||||||
assert_output <<OUT
|
|
||||||
PYENV_VERSION=2.7.11 virtualenv --verbose --python=${TMP}/python ${PYENV_ROOT}/versions/2.7.11/envs/venv
|
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
|
||||||
rehashed
|
|
||||||
OUT
|
|
||||||
assert_success
|
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
unstub curl
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "no whitespace allowed in virtualenv name" {
|
|
||||||
run pyenv-virtualenv "2.7.11" "foo bar"
|
|
||||||
|
|
||||||
assert_failure
|
|
||||||
assert_output <<OUT
|
|
||||||
pyenv-virtualenv: no whitespace allowed in virtualenv name.
|
|
||||||
OUT
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "no tab allowed in virtualenv name" {
|
|
||||||
run pyenv-virtualenv "2.7.11" "foo bar baz"
|
|
||||||
|
|
||||||
assert_failure
|
|
||||||
assert_output <<OUT
|
|
||||||
pyenv-virtualenv: no whitespace allowed in virtualenv name.
|
|
||||||
OUT
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "system not allowed as virtualenv name" {
|
|
||||||
run pyenv-virtualenv "2.7.11" "system"
|
|
||||||
|
|
||||||
assert_failure
|
|
||||||
assert_output <<OUT
|
|
||||||
pyenv-virtualenv: \`system' is not allowed as virtualenv name.
|
|
||||||
OUT
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "no slash allowed in virtualenv name" {
|
|
||||||
run pyenv-virtualenv "2.7.11" "foo/bar"
|
|
||||||
|
|
||||||
assert_failure
|
|
||||||
assert_output <<OUT
|
|
||||||
pyenv-virtualenv: no slash allowed in virtualenv name.
|
|
||||||
OUT
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "slash allowed if it is the long name of the virtualenv" {
|
|
||||||
export PYENV_VERSION="2.7.11"
|
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
|
||||||
stub curl true
|
|
||||||
|
|
||||||
run pyenv-virtualenv "2.7.11" "2.7.11/envs/foo"
|
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=2.7.11 virtualenv ${PYENV_ROOT}/versions/2.7.11/envs/foo
|
PYENV_VERSION=3.2.1 virtualenv --verbose --python=python ${PYENV_ROOT}/versions/venv
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub_pyenv
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
unstub pyenv-exec
|
|
||||||
unstub curl
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ setup() {
|
|||||||
|
|
||||||
@test "list virtual environments only" {
|
@test "list virtual environments only" {
|
||||||
stub pyenv-version-name ": echo system"
|
stub pyenv-version-name ": echo system"
|
||||||
|
stub pyenv-versions "--bare : echo \"system\";echo \"2.7.6\";echo \"3.3.3\";echo \"venv27\";echo \"venv33\""
|
||||||
stub pyenv-virtualenv-prefix "2.7.6 : false"
|
stub pyenv-virtualenv-prefix "2.7.6 : false"
|
||||||
stub pyenv-virtualenv-prefix "3.3.3 : false"
|
stub pyenv-virtualenv-prefix "3.3.3 : false"
|
||||||
stub pyenv-virtualenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/2.7.6\""
|
stub pyenv-virtualenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/2.7.6\""
|
||||||
@@ -19,48 +20,49 @@ setup() {
|
|||||||
|
|
||||||
run pyenv-virtualenvs
|
run pyenv-virtualenvs
|
||||||
|
|
||||||
|
unstub pyenv-version-name
|
||||||
|
unstub pyenv-versions
|
||||||
|
unstub pyenv-virtualenv-prefix
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
venv27 (created from ${PYENV_ROOT}/versions/2.7.6)
|
venv27 (created from ${PYENV_ROOT}/versions/2.7.6)
|
||||||
venv33 (created from ${PYENV_ROOT}/versions/3.3.3)
|
venv33 (created from ${PYENV_ROOT}/versions/3.3.3)
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "list virtual environments with hit prefix" {
|
@test "list virtual environments with hit prefix" {
|
||||||
stub pyenv-version-name ": echo venv33"
|
stub pyenv-version-name ": echo venv33"
|
||||||
stub pyenv-virtualenv-prefix "2.7.6 : false"
|
stub pyenv-versions "--bare : echo \"system\";echo \"venv27\";echo \"venv33\""
|
||||||
stub pyenv-virtualenv-prefix "3.3.3 : false"
|
|
||||||
stub pyenv-virtualenv-prefix "venv27 : echo \"/usr\""
|
stub pyenv-virtualenv-prefix "venv27 : echo \"/usr\""
|
||||||
stub pyenv-virtualenv-prefix "venv33 : echo \"/usr\""
|
stub pyenv-virtualenv-prefix "venv33 : echo \"/usr\""
|
||||||
|
|
||||||
run pyenv-virtualenvs
|
run pyenv-virtualenvs
|
||||||
|
|
||||||
|
unstub pyenv-version-name
|
||||||
|
unstub pyenv-versions
|
||||||
|
unstub pyenv-virtualenv-prefix
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
venv27 (created from /usr)
|
venv27 (created from /usr)
|
||||||
* venv33 (created from /usr)
|
* venv33 (created from /usr)
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub pyenv-version-name
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "list virtual environments with --bare" {
|
@test "list virtual environments with --bare" {
|
||||||
stub pyenv-virtualenv-prefix "2.7.6 : false"
|
stub pyenv-versions "--bare : echo \"system\";echo \"venv27\";echo \"venv33\""
|
||||||
stub pyenv-virtualenv-prefix "3.3.3 : false"
|
|
||||||
stub pyenv-virtualenv-prefix "venv27 : echo \"/usr\""
|
stub pyenv-virtualenv-prefix "venv27 : echo \"/usr\""
|
||||||
stub pyenv-virtualenv-prefix "venv33 : echo \"/usr\""
|
stub pyenv-virtualenv-prefix "venv33 : echo \"/usr\""
|
||||||
|
|
||||||
run pyenv-virtualenvs --bare
|
run pyenv-virtualenvs --bare
|
||||||
|
|
||||||
|
unstub pyenv-versions
|
||||||
|
unstub pyenv-virtualenv-prefix
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
venv27
|
venv27
|
||||||
venv33
|
venv33
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user