mirror of
https://github.com/pyenv/pyenv-virtualenv.git
synced 2025-11-08 19:43:54 -05:00
Compare commits
61 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
294f64f76b | ||
|
|
e39b112676 | ||
|
|
74bba45b9c | ||
|
|
2d947be5d9 | ||
|
|
a9e1891e8b | ||
|
|
bfdeb31d78 | ||
|
|
e3203f795a | ||
|
|
6d90f61726 | ||
|
|
ed779fea14 | ||
|
|
e0a1e9b35c | ||
|
|
cec39359ec | ||
|
|
8c9f7fa766 | ||
|
|
be6d917f16 | ||
|
|
32718e80b9 | ||
|
|
8310e73b43 | ||
|
|
5d1dcaa94c | ||
|
|
aa9baa8e03 | ||
|
|
75e84742db | ||
|
|
829dd1c9cb | ||
|
|
42f8ed2dce | ||
|
|
a75aa66490 | ||
|
|
9a03eb5b9c | ||
|
|
e67dd07f1b | ||
|
|
077edc3b4d | ||
|
|
0b24ff557e | ||
|
|
6a3172ff47 | ||
|
|
894d4af8a3 | ||
|
|
980159f221 | ||
|
|
051cd5880c | ||
|
|
cfb8691fc5 | ||
|
|
74ff2ce7af | ||
|
|
b1d0d72343 | ||
|
|
219a527a78 | ||
|
|
393bcc36b8 | ||
|
|
5419dc7320 | ||
|
|
94b2c9d5d6 | ||
|
|
a0b17033fc | ||
|
|
e690650fd6 | ||
|
|
74bc08b7dc | ||
|
|
a22521e946 | ||
|
|
b4eb09d1dd | ||
|
|
52cb0b1086 | ||
|
|
1e66783091 | ||
|
|
b8dd4fcb53 | ||
|
|
4c8da67f02 | ||
|
|
c2ba4952ff | ||
|
|
927914b25f | ||
|
|
e339fde2f3 | ||
|
|
e83a1f12c2 | ||
|
|
2727087757 | ||
|
|
f64c8ed0dd | ||
|
|
e4d2c367cc | ||
|
|
c67762742a | ||
|
|
1593b0e6b0 | ||
|
|
862be21a32 | ||
|
|
252d6763f9 | ||
|
|
832244fe13 | ||
|
|
61a5c7f807 | ||
|
|
304dff741f | ||
|
|
53dd8bcf46 | ||
|
|
f9b1814b82 |
@@ -5,3 +5,10 @@ language: c
|
|||||||
notifications:
|
notifications:
|
||||||
email:
|
email:
|
||||||
on_success: never
|
on_success: never
|
||||||
|
deploy:
|
||||||
|
provider: releases
|
||||||
|
api_key:
|
||||||
|
secure: DsGAt0UmTSGVfsNJ6LmM+LvsV6FYmvX4FcET82XrskPiQW+N8+8JZR8WuZxfmwdJZu+dkkdoq6gYgL2xF7m4LxRG7aw3B5TtbMTrJQeW0hdtCSBwbbYyvwcp2m7ywE8lGAfZQITaGj1R6f2Cgh8cgtcrErjcF0KJsYlVlgNv+/M=
|
||||||
|
on:
|
||||||
|
repo: pyenv/pyenv-virtualenv
|
||||||
|
tags: true
|
||||||
|
|||||||
30
CHANGELOG.md
30
CHANGELOG.md
@@ -1,5 +1,33 @@
|
|||||||
## Version History
|
## Version History
|
||||||
|
|
||||||
|
#### 1.1.5
|
||||||
|
|
||||||
|
* Fix install script (#290, #302)
|
||||||
|
|
||||||
|
#### 1.1.4
|
||||||
|
|
||||||
|
* Support newer conda (#290)
|
||||||
|
* Prefer `python3.x` executable if avaialble (#206, #282, #296)
|
||||||
|
|
||||||
|
#### 1.1.3
|
||||||
|
|
||||||
|
* No code changes since 1.1.2
|
||||||
|
|
||||||
|
#### 1.1.2
|
||||||
|
|
||||||
|
* Use custom get-pip URL based on the target version (#253, #254, #255)
|
||||||
|
* Source conda 4.4.4 shell files (#251)
|
||||||
|
* Evaluate force flag before testing if venv exists (#232)
|
||||||
|
|
||||||
|
#### 1.1.1
|
||||||
|
|
||||||
|
* Set `CONDA_PREFIX` to make is useable in conda activate/deactivate scripts (#224)
|
||||||
|
* Generate `pydoc` executable after creating new virtualenv (#197, #230)
|
||||||
|
|
||||||
|
#### 1.1.0
|
||||||
|
|
||||||
|
* fish: use "set -gx" instead of "setenv" (#215, #216, #217, #218)
|
||||||
|
|
||||||
#### 1.0.0
|
#### 1.0.0
|
||||||
|
|
||||||
* Use similar versioning scheme as pyenv; YYYYMMDD -> X.Y.Z
|
* Use similar versioning scheme as pyenv; YYYYMMDD -> X.Y.Z
|
||||||
@@ -33,7 +61,7 @@
|
|||||||
* Improved interoperability with Anaconda/Miniconda (#103, #106, #107, #108)
|
* Improved interoperability with Anaconda/Miniconda (#103, #106, #107, #108)
|
||||||
* Create `virtualenv` inside `envs` directory of source version, like Anaconda/Miniconda (#103, #107)
|
* 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)
|
* 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)
|
* Improve the `pyenv activate` behaviour on multiple versions (#105, #111)
|
||||||
* Reject creating a virtualenv named `system` (yyuu/pyenv#475)
|
* Reject creating a virtualenv named `system` (yyuu/pyenv#475)
|
||||||
* Add `--skip-aliases` to `pyenv virtualenvs` (#120)
|
* Add `--skip-aliases` to `pyenv virtualenvs` (#120)
|
||||||
* Stop showing `version not installed` warning messages in precmd (#49)
|
* Stop showing `version not installed` warning messages in precmd (#49)
|
||||||
|
|||||||
40
README.md
40
README.md
@@ -2,14 +2,14 @@
|
|||||||
|
|
||||||
[](https://gitter.im/yyuu/pyenv-virtualenv?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
[](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
|
pyenv-virtualenv is a [pyenv](https://github.com/pyenv/pyenv) plugin
|
||||||
that provides features to manage virtualenvs and conda environments
|
that provides features to manage virtualenvs and conda environments
|
||||||
for Python on UNIX-like systems.
|
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/yyuu/pyenv-virtualenvwrapper) may help you
|
and you love it, [pyenv-virtualenvwrapper](https://github.com/pyenv/pyenv-virtualenvwrapper) may help you
|
||||||
(additionally) to manage your virtualenvs.)
|
(additionally) to manage your virtualenvs.)
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
@@ -17,7 +17,7 @@ and you love it, [pyenv-virtualenvwrapper](https://github.com/yyuu/pyenv-virtual
|
|||||||
### Installing as a pyenv plugin
|
### Installing as a pyenv plugin
|
||||||
|
|
||||||
This will install the latest development version of pyenv-virtualenv into
|
This will install the latest development version of pyenv-virtualenv into
|
||||||
the `~/.pyenv/plugins/pyenv-virtualenv` directory.
|
the `$(pyenv root)/plugins/pyenv-virtualenv` directory.
|
||||||
|
|
||||||
**Important note:** If you installed pyenv into a non-standard directory, make
|
**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
|
sure that you clone this repo into the 'plugins' directory of wherever you
|
||||||
@@ -31,7 +31,7 @@ From inside that directory you can:
|
|||||||
1. **Check out pyenv-virtualenv into plugin directory**
|
1. **Check out pyenv-virtualenv into plugin directory**
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
$ git clone https://github.com/yyuu/pyenv-virtualenv.git ~/.pyenv/plugins/pyenv-virtualenv
|
$ 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.
|
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.
|
||||||
@@ -40,7 +40,15 @@ From inside that directory you can:
|
|||||||
$ echo 'eval "$(pyenv virtualenv-init -)"' >> ~/.bash_profile
|
$ echo 'eval "$(pyenv virtualenv-init -)"' >> ~/.bash_profile
|
||||||
```
|
```
|
||||||
|
|
||||||
|
**Fish shell note**: Add this to your `~/.config/fish/config.fish`
|
||||||
|
|
||||||
|
```sh
|
||||||
|
status --is-interactive; and pyenv init - | source
|
||||||
|
status --is-interactive; and pyenv virtualenv-init - | source
|
||||||
|
```
|
||||||
|
|
||||||
**Zsh note**: Modify your `~/.zshenv` file instead of `~/.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.
|
**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**
|
3. **Restart your shell to enable pyenv-virtualenv**
|
||||||
@@ -50,10 +58,10 @@ From inside that directory you can:
|
|||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
### Installing with Homebrew (for OS X users)
|
### Installing with Homebrew (for macOS users)
|
||||||
|
|
||||||
Mac OS X users can install pyenv-virtualenv with the
|
macOS users can install pyenv-virtualenv with the
|
||||||
[Homebrew](http://brew.sh) package manager.
|
[Homebrew](https://brew.sh) package manager.
|
||||||
This will give you access to the `pyenv-virtualenv` command. If you have pyenv
|
This 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.
|
||||||
|
|
||||||
@@ -90,7 +98,7 @@ of the virtualenv directory. For example,
|
|||||||
$ pyenv virtualenv 2.7.10 my-virtual-env-2.7.10
|
$ pyenv virtualenv 2.7.10 my-virtual-env-2.7.10
|
||||||
```
|
```
|
||||||
|
|
||||||
will create a virtualenv based on Python 2.7.10 under `~/.pyenv/versions` in a
|
will create a virtualenv based on Python 2.7.10 under `$(pyenv root)/versions` in a
|
||||||
folder called `my-virtual-env-2.7.10`.
|
folder called `my-virtual-env-2.7.10`.
|
||||||
|
|
||||||
|
|
||||||
@@ -129,7 +137,7 @@ There are two entries for each virtualenv, and the shorter one is just a symlink
|
|||||||
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 and `conda` environments.
|
require you to `activate` the virtualenv and `conda` environments.
|
||||||
|
|
||||||
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 lists a valid virtual environment. `.python-version` files denote local Python versions and can be created and deleted with the [`pyenv local`](https://github.com/yyuu/pyenv/blob/master/COMMANDS.md#pyenv-local) command.
|
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.
|
||||||
|
|
||||||
You can also activate and deactivate a pyenv virtualenv manually:
|
You can also activate and deactivate a pyenv virtualenv manually:
|
||||||
|
|
||||||
@@ -141,12 +149,18 @@ pyenv deactivate
|
|||||||
|
|
||||||
### Delete existing virtualenv
|
### Delete existing virtualenv
|
||||||
|
|
||||||
Removing the directories in `~/.pyenv/versions` and `~/.pyenv/versions/{version}/envs` will delete the virtualenv, or you can run:
|
Removing the directories in `$(pyenv root)/versions` and `$(pyenv root)/versions/{version}/envs` will delete the virtualenv, or you can run:
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
pyenv uninstall my-virtual-env
|
pyenv uninstall my-virtual-env
|
||||||
```
|
```
|
||||||
|
|
||||||
|
You can also delete existing virtualenvs by using `virtualenv-delete` command, e.g. you can run:
|
||||||
|
```sh
|
||||||
|
pyenv virtualenv-delete my-virtual-env
|
||||||
|
```
|
||||||
|
This will delete virtualenv called `my-virtual-env`.
|
||||||
|
|
||||||
|
|
||||||
### virtualenv and venv
|
### virtualenv and venv
|
||||||
|
|
||||||
@@ -221,7 +235,7 @@ You can set certain environment variables to control pyenv-virtualenv.
|
|||||||
`virtualenv`, download `get_pip.py` from the specified URL.
|
`virtualenv`, download `get_pip.py` from the specified URL.
|
||||||
* `PIP_VERSION`, if set and `venv` is preferred
|
* `PIP_VERSION`, if set and `venv` is preferred
|
||||||
over `virtualenv`, install the specified version of pip.
|
over `virtualenv`, install the specified version of pip.
|
||||||
|
* `PYENV_VIRTUALENV_VERBOSE_ACTIVATE`, if set, shows some verbose outputs on activation and deactivation
|
||||||
|
|
||||||
## Version History
|
## Version History
|
||||||
|
|
||||||
@@ -230,7 +244,7 @@ See [CHANGELOG.md](CHANGELOG.md).
|
|||||||
|
|
||||||
### License
|
### License
|
||||||
|
|
||||||
(The MIT License)
|
[(The MIT License)](LICENSE)
|
||||||
|
|
||||||
* Copyright (c) 2015 Yamashita, Yuu
|
* Copyright (c) 2015 Yamashita, Yuu
|
||||||
|
|
||||||
|
|||||||
@@ -146,8 +146,8 @@ if [ -z "$no_shell" ]; then
|
|||||||
case "$shell" in
|
case "$shell" in
|
||||||
fish )
|
fish )
|
||||||
cat <<EOS
|
cat <<EOS
|
||||||
setenv PYENV_VERSION "${versions[*]}";
|
set -gx PYENV_VERSION "${versions[*]}";
|
||||||
setenv PYENV_ACTIVATE_SHELL 1;
|
set -gx PYENV_ACTIVATE_SHELL 1;
|
||||||
EOS
|
EOS
|
||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
@@ -164,8 +164,8 @@ fi
|
|||||||
case "${shell}" in
|
case "${shell}" in
|
||||||
fish )
|
fish )
|
||||||
cat <<EOS
|
cat <<EOS
|
||||||
setenv PYENV_VIRTUAL_ENV "${prefix}";
|
set -gx PYENV_VIRTUAL_ENV "${prefix}";
|
||||||
setenv VIRTUAL_ENV "${prefix}";
|
set -gx VIRTUAL_ENV "${prefix}";
|
||||||
EOS
|
EOS
|
||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
@@ -177,7 +177,8 @@ EOS
|
|||||||
esac
|
esac
|
||||||
|
|
||||||
# anaconda/miniconda
|
# anaconda/miniconda
|
||||||
if [ -x "${prefix}/bin/conda" ]; then
|
if [ -d "${prefix}/conda-meta" ] ||
|
||||||
|
[ -x "${prefix}/bin/conda" ]; then
|
||||||
if [[ "${prefix}" != "${prefix%/envs/*}" ]]; then
|
if [[ "${prefix}" != "${prefix%/envs/*}" ]]; then
|
||||||
CONDA_DEFAULT_ENV="${venv##*/envs/}"
|
CONDA_DEFAULT_ENV="${venv##*/envs/}"
|
||||||
else
|
else
|
||||||
@@ -185,7 +186,7 @@ if [ -x "${prefix}/bin/conda" ]; then
|
|||||||
fi
|
fi
|
||||||
case "${shell}" in
|
case "${shell}" in
|
||||||
fish )
|
fish )
|
||||||
echo "setenv CONDA_DEFAULT_ENV \"${CONDA_DEFAULT_ENV}\";"
|
echo "set -gx CONDA_DEFAULT_ENV \"${CONDA_DEFAULT_ENV}\";"
|
||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
echo "export CONDA_DEFAULT_ENV=\"${CONDA_DEFAULT_ENV}\";"
|
echo "export CONDA_DEFAULT_ENV=\"${CONDA_DEFAULT_ENV}\";"
|
||||||
@@ -197,7 +198,7 @@ if [ -n "${PYTHONHOME}" ]; then
|
|||||||
case "${shell}" in
|
case "${shell}" in
|
||||||
fish )
|
fish )
|
||||||
cat <<EOS
|
cat <<EOS
|
||||||
setenv _OLD_VIRTUAL_PYTHONHOME "${PYTHONHOME}";
|
set -gx _OLD_VIRTUAL_PYTHONHOME "${PYTHONHOME}";
|
||||||
set -e PYTHONHOME;
|
set -e PYTHONHOME;
|
||||||
EOS
|
EOS
|
||||||
;;
|
;;
|
||||||
@@ -233,16 +234,26 @@ EOS
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# conda package anaconda/miniconda scripts (#173)
|
# conda package anaconda/miniconda scripts (#173)
|
||||||
if [ -x "${prefix}/bin/conda" ]; then
|
if [ -d "${prefix}/conda-meta" ] ||
|
||||||
|
[ -x "${prefix}/bin/conda" ]; then
|
||||||
shopt -s nullglob
|
shopt -s nullglob
|
||||||
case "${shell}" in
|
case "${shell}" in
|
||||||
fish )
|
fish )
|
||||||
: # conda doesn't support fish
|
# conda 4.4 and above
|
||||||
|
for script in "${prefix}/etc/fish/conf.d"/*.fish; do
|
||||||
|
echo "source \"${script}\";"
|
||||||
|
done
|
||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
|
CONDA_PREFIX="$prefix"
|
||||||
|
echo "export CONDA_PREFIX=\"${CONDA_PREFIX}\";"
|
||||||
for script in "${prefix}/etc/conda/activate.d"/*.sh; do
|
for script in "${prefix}/etc/conda/activate.d"/*.sh; do
|
||||||
echo ". \"${script}\";"
|
echo ". \"${script}\";"
|
||||||
done
|
done
|
||||||
|
# conda 4.4 and above
|
||||||
|
for script in "${prefix}/etc/profile.d"/*.sh; do
|
||||||
|
echo ". \"${script}\";"
|
||||||
|
done
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
shopt -u nullglob
|
shopt -u nullglob
|
||||||
|
|||||||
@@ -59,7 +59,8 @@ if [ -n "$PYENV_VIRTUALENV_VERBOSE_ACTIVATE" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# conda package anaconda/miniconda scripts (#173)
|
# conda package anaconda/miniconda scripts (#173)
|
||||||
if [ -x "${prefix}/bin/conda" ]; then
|
if [ -d "${prefix}/conda-meta" ] ||
|
||||||
|
[ -x "${prefix}/bin/conda" ]; then
|
||||||
shopt -s nullglob
|
shopt -s nullglob
|
||||||
case "${shell}" in
|
case "${shell}" in
|
||||||
fish )
|
fish )
|
||||||
@@ -69,6 +70,7 @@ if [ -x "${prefix}/bin/conda" ]; then
|
|||||||
for script in "${prefix}/etc/conda/deactivate.d"/*.sh; do
|
for script in "${prefix}/etc/conda/deactivate.d"/*.sh; do
|
||||||
echo ". \"${script}\";"
|
echo ". \"${script}\";"
|
||||||
done
|
done
|
||||||
|
echo "unset CONDA_PREFIX"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
shopt -u nullglob
|
shopt -u nullglob
|
||||||
@@ -125,7 +127,7 @@ case "${shell}" in
|
|||||||
fish )
|
fish )
|
||||||
cat <<EOS
|
cat <<EOS
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
||||||
setenv PATH "\$_OLD_VIRTUAL_PATH";
|
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
set -e _OLD_VIRTUAL_PATH;
|
||||||
end;
|
end;
|
||||||
EOS
|
EOS
|
||||||
@@ -144,7 +146,7 @@ case "${shell}" in
|
|||||||
fish )
|
fish )
|
||||||
cat <<EOS
|
cat <<EOS
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
||||||
setenv PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
set -e _OLD_VIRTUAL_PYTHONHOME;
|
||||||
end;
|
end;
|
||||||
EOS
|
EOS
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
# -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.0.0"
|
PYENV_VIRTUALENV_VERSION="1.1.5"
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
[ -n "$PYENV_DEBUG" ] && set -x
|
[ -n "$PYENV_DEBUG" ] && set -x
|
||||||
@@ -101,6 +101,10 @@ http_get_wget() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
version() {
|
version() {
|
||||||
|
if [[ -z "${PYENV_VERSION:-}" ]]; then
|
||||||
|
# `PYENV_VERSION` might not be declared if this was invoked via `--version`
|
||||||
|
export PYENV_VERSION="$(pyenv-version-name)"
|
||||||
|
fi
|
||||||
detect_venv
|
detect_venv
|
||||||
local version
|
local version
|
||||||
if [ -n "${USE_CONDA}" ]; then
|
if [ -n "${USE_CONDA}" ]; then
|
||||||
@@ -108,7 +112,7 @@ version() {
|
|||||||
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (conda ${version:-unknown})"
|
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (conda ${version:-unknown})"
|
||||||
else
|
else
|
||||||
if [ -n "$USE_M_VENV" ]; then
|
if [ -n "$USE_M_VENV" ]; then
|
||||||
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (python -m venv)"
|
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (${M_VENV_PYTHON_BIN:-python} -m venv)"
|
||||||
else
|
else
|
||||||
version="$(pyenv-exec virtualenv --version 2>/dev/null || true)"
|
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})"
|
||||||
@@ -123,7 +127,7 @@ usage() {
|
|||||||
pyenv-exec conda create --help 2>/dev/null || true
|
pyenv-exec conda create --help 2>/dev/null || true
|
||||||
else
|
else
|
||||||
if [ -n "${USE_M_VENV}" ]; then
|
if [ -n "${USE_M_VENV}" ]; then
|
||||||
pyenv-exec python -m venv --help 2>/dev/null || true
|
pyenv-exec "${M_VENV_PYTHON_BIN:-python}" -m venv --help 2>/dev/null || true
|
||||||
else
|
else
|
||||||
pyenv-exec virtualenv --help 2>/dev/null || true
|
pyenv-exec virtualenv --help 2>/dev/null || true
|
||||||
fi
|
fi
|
||||||
@@ -141,9 +145,15 @@ detect_venv() {
|
|||||||
if [ -x "${prefix}/bin/virtualenv" ]; then
|
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
|
# Prefer `python3.x` executable if avaialble (#206, #282)
|
||||||
HAS_M_VENV=1
|
local python
|
||||||
fi
|
for python in "python${PYENV_VERSION%.*}" "python${PYENV_VERSION%%.*}" "python"; do
|
||||||
|
if pyenv-exec "${python}" -m venv --help 1>/dev/null 2>&1; then
|
||||||
|
HAS_M_VENV=1
|
||||||
|
M_VENV_PYTHON_BIN="${python}"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
fi
|
fi
|
||||||
# Use `python -m venv` only if there is venv available, virtualenv is not installed, and `-p` not given
|
# Use `python -m venv` only if there is venv available, virtualenv is not installed, and `-p` not given
|
||||||
if [ -n "${HAS_CONDA}" ]; then
|
if [ -n "${HAS_CONDA}" ]; then
|
||||||
@@ -162,7 +172,7 @@ build_package_ez_setup() {
|
|||||||
echo "Installing setuptools from ${EZ_SETUP}..." 1>&2
|
echo "Installing setuptools from ${EZ_SETUP}..." 1>&2
|
||||||
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}" ]
|
||||||
echo "Installing setuptools from ${EZ_SETUP_URL}..." 1>&2
|
echo "Installing setuptools from ${EZ_SETUP_URL}..." 1>&2
|
||||||
http get "${EZ_SETUP_URL}"
|
http get "${EZ_SETUP_URL}"
|
||||||
fi
|
fi
|
||||||
@@ -180,7 +190,7 @@ build_package_get_pip() {
|
|||||||
echo "Installing pip from ${GET_PIP}..." 1>&2
|
echo "Installing pip from ${GET_PIP}..." 1>&2
|
||||||
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}" ]
|
||||||
echo "Installing pip from ${GET_PIP_URL}..." 1>&2
|
echo "Installing pip from ${GET_PIP_URL}..." 1>&2
|
||||||
http get "${GET_PIP_URL}"
|
http get "${GET_PIP_URL}"
|
||||||
fi
|
fi
|
||||||
@@ -349,9 +359,11 @@ if [[ "${VIRTUALENV_PATH/*/envs/*}" != "${PYENV_ROOT}/versions" ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -n "${COMPAT_VIRTUALENV_PATH}" ]; then
|
if [ -n "${COMPAT_VIRTUALENV_PATH}" ]; then
|
||||||
if [ -e "${COMPAT_VIRTUALENV_PATH}" ] || [ -L "${COMPAT_VIRTUALENV_PATH}" ]; then
|
if [ -z ${FORCE} ]; then
|
||||||
echo "pyenv-virtualenv: \`${COMPAT_VIRTUALENV_PATH}' already exists." 1>&2
|
if [ -e "${COMPAT_VIRTUALENV_PATH}" ] || [ -L "${COMPAT_VIRTUALENV_PATH}" ]; then
|
||||||
exit 1
|
echo "pyenv-virtualenv: \`${COMPAT_VIRTUALENV_PATH}' already exists." 1>&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -375,7 +387,7 @@ if [ -n "$UPGRADE" ]; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -z "${VIRTUALEN_VERSION}" ]; then
|
if [ -z "${VIRTUALENV_VERSION}" ]; then
|
||||||
case "${PYENV_VERSION}" in
|
case "${PYENV_VERSION}" in
|
||||||
"3.0"* )
|
"3.0"* )
|
||||||
NO_ENSUREPIP=1
|
NO_ENSUREPIP=1
|
||||||
@@ -447,11 +459,39 @@ unset VIRTUALENV_VERSION
|
|||||||
|
|
||||||
|
|
||||||
# Download specified version of ez_setup.py/get-pip.py.
|
# Download specified version of ez_setup.py/get-pip.py.
|
||||||
if [ -n "${SETUPTOOLS_VERSION}" ]; then
|
if [ -z "${EZ_SETUP_URL}" ]; then
|
||||||
EZ_SETUP_URL="https://bitbucket.org/pypa/setuptools/raw/${SETUPTOOLS_VERSION}/ez_setup.py"
|
if [ -n "${SETUPTOOLS_VERSION}" ]; then
|
||||||
|
EZ_SETUP_URL="https://bitbucket.org/pypa/setuptools/raw/${SETUPTOOLS_VERSION}/ez_setup.py"
|
||||||
|
unset SETUPTOOLS_VERSION
|
||||||
|
else
|
||||||
|
EZ_SETUP_URL="https://bootstrap.pypa.io/ez_setup.py"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
if [ -n "${PIP_VERSION}" ]; then
|
if [ -z "${GET_PIP_URL}" ]; then
|
||||||
GET_PIP_URL="https://raw.githubusercontent.com/pypa/pip/${PIP_VERSION}/contrib/get-pip.py"
|
if [ -n "${PIP_VERSION}" ]; then
|
||||||
|
{ colorize 1 "WARNING"
|
||||||
|
echo ": Setting PIP_VERSION=${PIP_VERSION} is no longer supported and may cause failures during the install process."
|
||||||
|
} 1>&2
|
||||||
|
GET_PIP_URL="https://raw.githubusercontent.com/pypa/pip/${PIP_VERSION}/contrib/get-pip.py"
|
||||||
|
# Unset `PIP_VERSION` from environment before invoking `get-pip.py` to deal with "ValueError: invalid truth value" (pypa/pip#4528)
|
||||||
|
unset PIP_VERSION
|
||||||
|
else
|
||||||
|
# Use custom get-pip URL based on the target version (#1127)
|
||||||
|
case "${PYENV_VERSION}" in
|
||||||
|
2.6 | 2.6.* )
|
||||||
|
GET_PIP_URL="https://bootstrap.pypa.io/2.6/get-pip.py"
|
||||||
|
;;
|
||||||
|
3.2 | 3.2.* )
|
||||||
|
GET_PIP_URL="https://bootstrap.pypa.io/3.2/get-pip.py"
|
||||||
|
;;
|
||||||
|
3.3 | 3.3.* )
|
||||||
|
GET_PIP_URL="https://bootstrap.pypa.io/3.3/get-pip.py"
|
||||||
|
;;
|
||||||
|
* )
|
||||||
|
GET_PIP_URL="https://bootstrap.pypa.io/get-pip.py"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
@@ -507,10 +547,11 @@ for hook in "${before_hooks[@]}"; do eval "$hook"; done
|
|||||||
|
|
||||||
# Plan cleanup on unsuccessful installation.
|
# Plan cleanup on unsuccessful installation.
|
||||||
cleanup() {
|
cleanup() {
|
||||||
|
[[ -L "${COMPAT_VIRTUALENV_PATH}" ]] && rm "${COMPAT_VIRTUALENV_PATH}"
|
||||||
[ -z "${PREFIX_EXISTS}" ] && rm -rf "$VIRTUALENV_PATH"
|
[ -z "${PREFIX_EXISTS}" ] && rm -rf "$VIRTUALENV_PATH"
|
||||||
}
|
}
|
||||||
|
|
||||||
trap cleanup SIGINT
|
trap cleanup SIGINT ERR
|
||||||
|
|
||||||
# Invoke virtualenv and record exit status in $STATUS.
|
# Invoke virtualenv and record exit status in $STATUS.
|
||||||
STATUS=0
|
STATUS=0
|
||||||
@@ -522,7 +563,7 @@ if [ -n "${USE_CONDA}" ]; then
|
|||||||
pyenv-exec conda create $QUIET $VERBOSE --name "${VIRTUALENV_PATH##*/}" --yes "${VIRTUALENV_OPTIONS[@]}" python || STATUS="$?"
|
pyenv-exec conda create $QUIET $VERBOSE --name "${VIRTUALENV_PATH##*/}" --yes "${VIRTUALENV_OPTIONS[@]}" python || STATUS="$?"
|
||||||
else
|
else
|
||||||
if [ -n "${USE_M_VENV}" ]; then
|
if [ -n "${USE_M_VENV}" ]; then
|
||||||
pyenv-exec python -m venv $QUIET $VERBOSE "${VIRTUALENV_OPTIONS[@]}" "${VIRTUALENV_PATH}" || STATUS="$?"
|
pyenv-exec "${M_VENV_PYTHON_BIN:-python}" -m venv $QUIET $VERBOSE "${VIRTUALENV_OPTIONS[@]}" "${VIRTUALENV_PATH}" || STATUS="$?"
|
||||||
else
|
else
|
||||||
pyenv-exec virtualenv $QUIET $VERBOSE "${VIRTUALENV_OPTIONS[@]}" "${VIRTUALENV_PATH}" || STATUS="$?"
|
pyenv-exec virtualenv $QUIET $VERBOSE "${VIRTUALENV_OPTIONS[@]}" "${VIRTUALENV_PATH}" || STATUS="$?"
|
||||||
fi
|
fi
|
||||||
@@ -533,6 +574,17 @@ if [ -d "${VIRTUALENV_PATH}" ] && [ -n "${COMPAT_VIRTUALENV_PATH}" ]; then
|
|||||||
ln -fs "${VIRTUALENV_PATH}" "${COMPAT_VIRTUALENV_PATH}"
|
ln -fs "${VIRTUALENV_PATH}" "${COMPAT_VIRTUALENV_PATH}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ ! -e "${VIRTUALENV_PATH}/bin/pydoc" ]; then
|
||||||
|
mkdir -p "${VIRTUALENV_PATH}/bin"
|
||||||
|
cat <<EOS > "${VIRTUALENV_PATH}/bin/pydoc"
|
||||||
|
#!${VIRTUALENV_PATH}/bin/python
|
||||||
|
import pydoc
|
||||||
|
if __name__ == '__main__':
|
||||||
|
pydoc.cli()
|
||||||
|
EOS
|
||||||
|
chmod +x "${VIRTUALENV_PATH}/bin/pydoc"
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -z "${NO_ENSUREPIP}" ]; then
|
if [ -z "${NO_ENSUREPIP}" ]; then
|
||||||
## Install setuptools and pip.
|
## Install setuptools and pip.
|
||||||
PYENV_VERSION="${VIRTUALENV_NAME}" build_package_ensurepip
|
PYENV_VERSION="${VIRTUALENV_NAME}" build_package_ensurepip
|
||||||
|
|||||||
@@ -86,8 +86,8 @@ fi
|
|||||||
case "$shell" in
|
case "$shell" in
|
||||||
fish )
|
fish )
|
||||||
cat <<EOS
|
cat <<EOS
|
||||||
setenv PATH '${PYENV_VIRTUALENV_ROOT:-${PYENV_VIRTUALENV_INSTALL_PREFIX}}/shims' \$PATH;
|
set -gx PATH '${PYENV_VIRTUALENV_ROOT:-${PYENV_VIRTUALENV_INSTALL_PREFIX}}/shims' \$PATH;
|
||||||
setenv PYENV_VIRTUALENV_INIT 1;
|
set -gx PYENV_VIRTUALENV_INIT 1;
|
||||||
EOS
|
EOS
|
||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
|
|||||||
@@ -6,6 +6,7 @@
|
|||||||
|
|
||||||
set -e
|
set -e
|
||||||
[ -n "$PYENV_DEBUG" ] && set -x
|
[ -n "$PYENV_DEBUG" ] && set -x
|
||||||
|
. "${BASH_SOURCE%/*}"/../libexec/pyenv-virtualenv-realpath
|
||||||
|
|
||||||
if [ -z "$PYENV_ROOT" ]; then
|
if [ -z "$PYENV_ROOT" ]; then
|
||||||
PYENV_ROOT="${HOME}/.pyenv"
|
PYENV_ROOT="${HOME}/.pyenv"
|
||||||
@@ -19,6 +20,15 @@ else
|
|||||||
IFS=: versions=($(pyenv-version-name))
|
IFS=: versions=($(pyenv-version-name))
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
append_virtualenv_prefix() {
|
||||||
|
if [ -d "${VIRTUALENV_PREFIX_PATH}" ]; then
|
||||||
|
VIRTUALENV_PREFIX_PATHS=("${VIRTUALENV_PREFIX_PATHS[@]}" "${VIRTUALENV_PREFIX_PATH:-${PYENV_PREFIX_PATH}}")
|
||||||
|
else
|
||||||
|
echo "pyenv-virtualenv: version \`${version}' is not a virtualenv" 1>&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
VIRTUALENV_PREFIX_PATHS=()
|
VIRTUALENV_PREFIX_PATHS=()
|
||||||
for version in "${versions[@]}"; do
|
for version in "${versions[@]}"; do
|
||||||
if [ "$version" = "system" ]; then
|
if [ "$version" = "system" ]; then
|
||||||
@@ -55,12 +65,11 @@ for version in "${versions[@]}"; do
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
if [ -d "${VIRTUALENV_PREFIX_PATH}" ]; then
|
append_virtualenv_prefix
|
||||||
VIRTUALENV_PREFIX_PATHS=("${VIRTUALENV_PREFIX_PATHS[@]}" "${VIRTUALENV_PREFIX_PATH:-${PYENV_PREFIX_PATH}}")
|
elif [ -d "${PYENV_PREFIX_PATH}/conda-meta" ]; then
|
||||||
else
|
# conda
|
||||||
echo "pyenv-virtualenv: version \`${version}' is not a virtualenv" 1>&2
|
VIRTUALENV_PREFIX_PATH="$(realpath "${PYENV_PREFIX_PATH}"/../..)"
|
||||||
exit 1
|
append_virtualenv_prefix
|
||||||
fi
|
|
||||||
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
|
||||||
|
|||||||
@@ -7,6 +7,7 @@
|
|||||||
|
|
||||||
set -e
|
set -e
|
||||||
[ -n "$PYENV_DEBUG" ] && set -x
|
[ -n "$PYENV_DEBUG" ] && set -x
|
||||||
|
. "${BASH_SOURCE%/*}"/../libexec/pyenv-virtualenv-realpath
|
||||||
|
|
||||||
if [ -z "$PYENV_ROOT" ]; then
|
if [ -z "$PYENV_ROOT" ]; then
|
||||||
PYENV_ROOT="${HOME}/.pyenv"
|
PYENV_ROOT="${HOME}/.pyenv"
|
||||||
@@ -32,38 +33,6 @@ done
|
|||||||
|
|
||||||
versions_dir="${PYENV_ROOT}/versions"
|
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
|
if [ -d "$versions_dir" ]; then
|
||||||
versions_dir="$(realpath "$versions_dir")"
|
versions_dir="$(realpath "$versions_dir")"
|
||||||
fi
|
fi
|
||||||
|
|||||||
11
etc/pyenv.d/which/conda.bash
Normal file
11
etc/pyenv.d/which/conda.bash
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
# newer versions of conda share programs from the real prefix
|
||||||
|
# this hook tries to find the executable there
|
||||||
|
|
||||||
|
if [ ! -x "${PYENV_COMMAND_PATH}" ] && [[ "${PYENV_COMMAND_PATH##*/}" == "conda" ]]; then
|
||||||
|
if [ -d "${PYENV_ROOT}/versions/${version}/conda-meta" ]; then
|
||||||
|
conda_command_path="$(pyenv-virtualenv-prefix "$version")"/bin/"${PYENV_COMMAND_PATH##*/}"
|
||||||
|
if [ -x "${conda_command_path}" ]; then
|
||||||
|
PYENV_COMMAND_PATH="${conda_command_path}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
@@ -12,7 +12,7 @@ if [ ! -x "${PYENV_COMMAND_PATH}" ] && [[ "${PYENV_COMMAND_PATH##*/}" == "python
|
|||||||
if [ -f "${PYENV_ROOT}/versions/${version}/bin/conda" ]; then
|
if [ -f "${PYENV_ROOT}/versions/${version}/bin/conda" ]; then
|
||||||
: # do nothing for conda's environments
|
: # do nothing for conda's environments
|
||||||
else
|
else
|
||||||
if [ -f "${PYENV_ROOT}/versions/${version}/bin/pyvenv.cfg" ]; then
|
if [ -f "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" ]; then
|
||||||
# venv
|
# venv
|
||||||
virtualenv_binpath="$(cut -b 1-1024 "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" | sed -n '/^ *home *= */s///p' || true)"
|
virtualenv_binpath="$(cut -b 1-1024 "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" | sed -n '/^ *home *= */s///p' || true)"
|
||||||
virtualenv_prefix="${virtualenv_binpath%/bin}"
|
virtualenv_prefix="${virtualenv_binpath%/bin}"
|
||||||
|
|||||||
@@ -12,14 +12,17 @@ if [ -z "${PREFIX}" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
BIN_PATH="${PREFIX}/bin"
|
BIN_PATH="${PREFIX}/bin"
|
||||||
|
LIBEXEC_PATH="${PREFIX}/libexec"
|
||||||
SHIMS_PATH="${PREFIX}/shims"
|
SHIMS_PATH="${PREFIX}/shims"
|
||||||
HOOKS_PATH="${PREFIX}/etc/pyenv.d"
|
HOOKS_PATH="${PREFIX}/etc/pyenv.d"
|
||||||
|
|
||||||
mkdir -p "$BIN_PATH"
|
mkdir -p "$BIN_PATH"
|
||||||
|
mkdir -p "$LIBEXEC_PATH"
|
||||||
mkdir -p "$SHIMS_PATH"
|
mkdir -p "$SHIMS_PATH"
|
||||||
mkdir -p "$HOOKS_PATH"
|
mkdir -p "$HOOKS_PATH"
|
||||||
|
|
||||||
install -p bin/* "$BIN_PATH"
|
install -p bin/* "$BIN_PATH"
|
||||||
|
install -p libexec/* "$LIBEXEC_PATH"
|
||||||
install -p shims/* "$SHIMS_PATH"
|
install -p shims/* "$SHIMS_PATH"
|
||||||
for hook in etc/pyenv.d/*; do
|
for hook in etc/pyenv.d/*; do
|
||||||
if [ -d "$hook" ]; then
|
if [ -d "$hook" ]; then
|
||||||
|
|||||||
50
libexec/pyenv-virtualenv-realpath
Normal file
50
libexec/pyenv-virtualenv-realpath
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Summary: Substitute realpath if unavailable as a builtin or file
|
||||||
|
# Usage: . pyenv-virtualenv-realpath
|
||||||
|
|
||||||
|
if ! {
|
||||||
|
enable -f "${BASH_SOURCE%/*}"/../libexec/pyenv-realpath.dylib realpath ||
|
||||||
|
type realpath
|
||||||
|
} >/dev/null 2>&1; 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 f="$*" \
|
||||||
|
name dir
|
||||||
|
[[ $f ]] || {
|
||||||
|
>&2 echo ${FUNCNAME[0]}: missing operand
|
||||||
|
return
|
||||||
|
}
|
||||||
|
while [[ -L $f ]]; do
|
||||||
|
f="$(resolve_link "$f")"
|
||||||
|
done
|
||||||
|
if [[ ! -d $f ]]; then
|
||||||
|
name="/${f##*/}"
|
||||||
|
# parent?
|
||||||
|
dir="${f%/*}"
|
||||||
|
if [[ $dir == $f ]]; then
|
||||||
|
#lacks /: parent is current directory
|
||||||
|
f="$PWD"
|
||||||
|
else
|
||||||
|
f="$dir"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
#absolute directory
|
||||||
|
dir="$(cd "$f"
|
||||||
|
pwd)"
|
||||||
|
echo "$dir$name"
|
||||||
|
}
|
||||||
|
fi
|
||||||
@@ -138,8 +138,8 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
set -gx PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
||||||
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
set -gx VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
||||||
pyenv-virtualenv: prompt changing not working for fish.
|
pyenv-virtualenv: prompt changing not working for fish.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
@@ -162,10 +162,10 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
setenv PYENV_VERSION "venv";
|
set -gx PYENV_VERSION "venv";
|
||||||
setenv PYENV_ACTIVATE_SHELL 1;
|
set -gx PYENV_ACTIVATE_SHELL 1;
|
||||||
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
set -gx PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
||||||
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
set -gx VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
||||||
pyenv-virtualenv: prompt changing not working for fish.
|
pyenv-virtualenv: prompt changing not working for fish.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
@@ -239,10 +239,10 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
setenv PYENV_VERSION "venv27";
|
set -gx PYENV_VERSION "venv27";
|
||||||
setenv PYENV_ACTIVATE_SHELL 1;
|
set -gx PYENV_ACTIVATE_SHELL 1;
|
||||||
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
set -gx PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
||||||
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
set -gx VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
||||||
pyenv-virtualenv: prompt changing not working for fish.
|
pyenv-virtualenv: prompt changing not working for fish.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
@@ -263,10 +263,10 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
setenv PYENV_VERSION "venv27";
|
set -gx PYENV_VERSION "venv27";
|
||||||
setenv PYENV_ACTIVATE_SHELL 1;
|
set -gx PYENV_ACTIVATE_SHELL 1;
|
||||||
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
set -gx PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
||||||
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
set -gx VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
||||||
pyenv-virtualenv: prompt changing not working for fish.
|
pyenv-virtualenv: prompt changing not working for fish.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
@@ -381,7 +381,7 @@ EOS
|
|||||||
stub pyenv-virtualenv-prefix "2.7.10 : false"
|
stub pyenv-virtualenv-prefix "2.7.10 : false"
|
||||||
stub pyenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
stub pyenv-prefix "venv27 : echo \"${PYENV_ROOT}/versions/venv27\""
|
||||||
|
|
||||||
run pyenv-sh-activate "venv27" "2.7.10"
|
PYENV_SHELL="bash" run pyenv-sh-activate "venv27" "2.7.10"
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
|
|||||||
@@ -39,6 +39,7 @@ 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.
|
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 _OLD_VIRTUAL_PS1="\${PS1}";
|
||||||
export PS1="(anaconda-2.3.0) \${PS1}";
|
export PS1="(anaconda-2.3.0) \${PS1}";
|
||||||
|
export CONDA_PREFIX="${TMP}/pyenv/versions/anaconda-2.3.0";
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
@@ -62,9 +63,9 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
setenv PYENV_VIRTUAL_ENV "${TMP}/pyenv/versions/anaconda-2.3.0";
|
set -gx PYENV_VIRTUAL_ENV "${TMP}/pyenv/versions/anaconda-2.3.0";
|
||||||
setenv VIRTUAL_ENV "${TMP}/pyenv/versions/anaconda-2.3.0";
|
set -gx VIRTUAL_ENV "${TMP}/pyenv/versions/anaconda-2.3.0";
|
||||||
setenv CONDA_DEFAULT_ENV "root";
|
set -gx CONDA_DEFAULT_ENV "root";
|
||||||
pyenv-virtualenv: prompt changing not working for fish.
|
pyenv-virtualenv: prompt changing not working for fish.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
@@ -97,6 +98,7 @@ 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.
|
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 _OLD_VIRTUAL_PS1="\${PS1}";
|
||||||
export PS1="(miniconda-3.9.1) \${PS1}";
|
export PS1="(miniconda-3.9.1) \${PS1}";
|
||||||
|
export CONDA_PREFIX="${TMP}/pyenv/versions/miniconda-3.9.1";
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
@@ -126,6 +128,7 @@ 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.
|
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 _OLD_VIRTUAL_PS1="\${PS1}";
|
||||||
export PS1="(anaconda-2.3.0/envs/foo) \${PS1}";
|
export PS1="(anaconda-2.3.0/envs/foo) \${PS1}";
|
||||||
|
export CONDA_PREFIX="${TMP}/pyenv/versions/anaconda-2.3.0/envs/foo";
|
||||||
. "${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo/etc/conda/activate.d/activate.sh";
|
. "${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo/etc/conda/activate.d/activate.sh";
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
@@ -158,6 +161,7 @@ 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.
|
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 _OLD_VIRTUAL_PS1="\${PS1}";
|
||||||
export PS1="(miniconda-3.9.1/envs/bar) \${PS1}";
|
export PS1="(miniconda-3.9.1/envs/bar) \${PS1}";
|
||||||
|
export CONDA_PREFIX="${TMP}/pyenv/versions/miniconda-3.9.1/envs/bar";
|
||||||
. "${PYENV_ROOT}/versions/miniconda-3.9.1/envs/bar/etc/conda/activate.d/activate.sh";
|
. "${PYENV_ROOT}/versions/miniconda-3.9.1/envs/bar/etc/conda/activate.d/activate.sh";
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
|
|||||||
@@ -30,6 +30,7 @@ setup() {
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
|
unset CONDA_PREFIX
|
||||||
unset PYENV_VIRTUAL_ENV;
|
unset PYENV_VIRTUAL_ENV;
|
||||||
unset VIRTUAL_ENV;
|
unset VIRTUAL_ENV;
|
||||||
unset CONDA_DEFAULT_ENV;
|
unset CONDA_DEFAULT_ENV;
|
||||||
@@ -69,11 +70,11 @@ set -e PYENV_VIRTUAL_ENV;
|
|||||||
set -e VIRTUAL_ENV;
|
set -e VIRTUAL_ENV;
|
||||||
set -e CONDA_DEFAULT_ENV;
|
set -e CONDA_DEFAULT_ENV;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
||||||
setenv PATH "\$_OLD_VIRTUAL_PATH";
|
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
set -e _OLD_VIRTUAL_PATH;
|
||||||
end;
|
end;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
||||||
setenv PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
set -e _OLD_VIRTUAL_PYTHONHOME;
|
||||||
end;
|
end;
|
||||||
if functions -q deactivate;
|
if functions -q deactivate;
|
||||||
@@ -97,6 +98,7 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
. "${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo/etc/conda/deactivate.d/deactivate.sh";
|
. "${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo/etc/conda/deactivate.d/deactivate.sh";
|
||||||
|
unset CONDA_PREFIX
|
||||||
unset PYENV_VIRTUAL_ENV;
|
unset PYENV_VIRTUAL_ENV;
|
||||||
unset VIRTUAL_ENV;
|
unset VIRTUAL_ENV;
|
||||||
unset CONDA_DEFAULT_ENV;
|
unset CONDA_DEFAULT_ENV;
|
||||||
|
|||||||
@@ -247,11 +247,11 @@ EOS
|
|||||||
set -e PYENV_VIRTUAL_ENV;
|
set -e PYENV_VIRTUAL_ENV;
|
||||||
set -e VIRTUAL_ENV;
|
set -e VIRTUAL_ENV;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
||||||
setenv PATH "\$_OLD_VIRTUAL_PATH";
|
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
set -e _OLD_VIRTUAL_PATH;
|
||||||
end;
|
end;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
||||||
setenv PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
set -e _OLD_VIRTUAL_PYTHONHOME;
|
||||||
end;
|
end;
|
||||||
if functions -q deactivate;
|
if functions -q deactivate;
|
||||||
@@ -273,11 +273,11 @@ EOS
|
|||||||
set -e PYENV_VIRTUAL_ENV;
|
set -e PYENV_VIRTUAL_ENV;
|
||||||
set -e VIRTUAL_ENV;
|
set -e VIRTUAL_ENV;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
||||||
setenv PATH "\$_OLD_VIRTUAL_PATH";
|
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
set -e _OLD_VIRTUAL_PATH;
|
||||||
end;
|
end;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
||||||
setenv PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
set -e _OLD_VIRTUAL_PYTHONHOME;
|
||||||
end;
|
end;
|
||||||
if functions -q deactivate;
|
if functions -q deactivate;
|
||||||
@@ -301,11 +301,11 @@ set -e PYENV_ACTIVATE_SHELL;
|
|||||||
set -e PYENV_VIRTUAL_ENV;
|
set -e PYENV_VIRTUAL_ENV;
|
||||||
set -e VIRTUAL_ENV;
|
set -e VIRTUAL_ENV;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
||||||
setenv PATH "\$_OLD_VIRTUAL_PATH";
|
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
set -e _OLD_VIRTUAL_PATH;
|
||||||
end;
|
end;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
||||||
setenv PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
set -e _OLD_VIRTUAL_PYTHONHOME;
|
||||||
end;
|
end;
|
||||||
if functions -q deactivate;
|
if functions -q deactivate;
|
||||||
@@ -329,11 +329,11 @@ set -e PYENV_ACTIVATE_SHELL;
|
|||||||
set -e PYENV_VIRTUAL_ENV;
|
set -e PYENV_VIRTUAL_ENV;
|
||||||
set -e VIRTUAL_ENV;
|
set -e VIRTUAL_ENV;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
||||||
setenv PATH "\$_OLD_VIRTUAL_PATH";
|
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
set -e _OLD_VIRTUAL_PATH;
|
||||||
end;
|
end;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
||||||
setenv PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
set -e _OLD_VIRTUAL_PYTHONHOME;
|
||||||
end;
|
end;
|
||||||
if functions -q deactivate;
|
if functions -q deactivate;
|
||||||
@@ -355,11 +355,11 @@ EOS
|
|||||||
set -e PYENV_VIRTUAL_ENV;
|
set -e PYENV_VIRTUAL_ENV;
|
||||||
set -e VIRTUAL_ENV;
|
set -e VIRTUAL_ENV;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
if [ -n "\$_OLD_VIRTUAL_PATH" ];
|
||||||
setenv PATH "\$_OLD_VIRTUAL_PATH";
|
set -gx PATH "\$_OLD_VIRTUAL_PATH";
|
||||||
set -e _OLD_VIRTUAL_PATH;
|
set -e _OLD_VIRTUAL_PATH;
|
||||||
end;
|
end;
|
||||||
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
if [ -n "\$_OLD_VIRTUAL_PYTHONHOME" ];
|
||||||
setenv PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
set -gx PYTHONHOME "\$_OLD_VIRTUAL_PYTHONHOME";
|
||||||
set -e _OLD_VIRTUAL_PYTHONHOME;
|
set -e _OLD_VIRTUAL_PYTHONHOME;
|
||||||
end;
|
end;
|
||||||
if functions -q deactivate;
|
if functions -q deactivate;
|
||||||
|
|||||||
@@ -25,15 +25,15 @@ unstub_pyenv() {
|
|||||||
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-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
stub pyenv-exec "python3.5 -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 "python3.5 -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"
|
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
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.5.1 python -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
PYENV_VERSION=3.5.1 python3.5 -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
PYENV_VERSION=3.5.1/envs/venv python -s -m ensurepip
|
PYENV_VERSION=3.5.1/envs/venv python -s -m ensurepip
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ OUT
|
|||||||
create_executable "3.5.1" "virtualenv"
|
create_executable "3.5.1" "virtualenv"
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.5.1'"
|
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.5.1'"
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.5.1'"
|
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.5.1'"
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
stub pyenv-exec "python3.5 -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=3.5.1 \"\$@\""
|
||||||
stub pyenv-exec "echo PYENV_VERSION=3.5.1 \"\$@\""
|
stub pyenv-exec "echo PYENV_VERSION=3.5.1 \"\$@\""
|
||||||
|
|||||||
@@ -72,8 +72,8 @@ EOS
|
|||||||
run pyenv-virtualenv-init - fish
|
run pyenv-virtualenv-init - fish
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
setenv PATH '${TMP}/pyenv/plugins/pyenv-virtualenv/shims' \$PATH;
|
set -gx PATH '${TMP}/pyenv/plugins/pyenv-virtualenv/shims' \$PATH;
|
||||||
setenv PYENV_VIRTUALENV_INIT 1;
|
set -gx PYENV_VIRTUALENV_INIT 1;
|
||||||
function _pyenv_virtualenv_hook --on-event fish_prompt;
|
function _pyenv_virtualenv_hook --on-event fish_prompt;
|
||||||
set -l ret \$status
|
set -l ret \$status
|
||||||
if [ -n "\$VIRTUAL_ENV" ]
|
if [ -n "\$VIRTUAL_ENV" ]
|
||||||
|
|||||||
@@ -26,15 +26,15 @@ unstub_pyenv() {
|
|||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
stub pyenv-exec "python3.5 -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 "python3.5 -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"
|
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
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.5.1 python -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
PYENV_VERSION=3.5.1 python3.5 -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
PYENV_VERSION=3.5.1/envs/venv python -s -m ensurepip
|
PYENV_VERSION=3.5.1/envs/venv python -s -m ensurepip
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
@@ -52,8 +52,8 @@ OUT
|
|||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
stub pyenv-exec "python3.3 -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 "python3.3 -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 -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 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
|
stub curl true
|
||||||
@@ -62,8 +62,8 @@ OUT
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.3.6 python -m venv ${PYENV_ROOT}/versions/3.3.6/envs/venv
|
PYENV_VERSION=3.3.6 python3.3 -m venv ${PYENV_ROOT}/versions/3.3.6/envs/venv
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
Installing pip from https://bootstrap.pypa.io/3.3/get-pip.py...
|
||||||
PYENV_VERSION=3.3.6/envs/venv python -s ${TMP}/pyenv/cache/get-pip.py
|
PYENV_VERSION=3.3.6/envs/venv python -s ${TMP}/pyenv/cache/get-pip.py
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
|||||||
@@ -31,6 +31,8 @@ teardown() {
|
|||||||
create_executable "2.7.8" "python2.7"
|
create_executable "2.7.8" "python2.7"
|
||||||
remove_executable "2.7.9" "python2.7"
|
remove_executable "2.7.9" "python2.7"
|
||||||
|
|
||||||
|
stub pyenv-exec "python2.7 -m venv --help : false"
|
||||||
|
stub pyenv-exec "python2 -m venv --help : false"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
stub pyenv-exec "python -m venv --help : false"
|
||||||
stub pyenv-exec "virtualenv --verbose * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv --verbose * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
stub pyenv-exec "python -s -m ensurepip : true"
|
||||||
@@ -56,6 +58,8 @@ OUT
|
|||||||
remove_executable "2.7.8" "python2.7"
|
remove_executable "2.7.8" "python2.7"
|
||||||
create_executable "2.7.9" "python2.7"
|
create_executable "2.7.9" "python2.7"
|
||||||
|
|
||||||
|
stub pyenv-exec "python2.7 -m venv --help : false"
|
||||||
|
stub pyenv-exec "python2 -m venv --help : false"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
stub pyenv-exec "python -m venv --help : false"
|
||||||
stub pyenv-exec "virtualenv --verbose * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv --verbose * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
stub pyenv-exec "python -s -m ensurepip : true"
|
||||||
|
|||||||
@@ -26,17 +26,18 @@ unstub_pyenv() {
|
|||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
stub pyenv-exec "python3.5 -m venv --help : true"
|
||||||
stub pyenv-exec "python -m venv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "python3.5 -m venv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
stub pyenv-exec "python -s -m ensurepip : true"
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.5.1 python -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
PYENV_VERSION=3.5.1 python3.5 -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/3.5.1/envs/venv/bin/pydoc" ]
|
||||||
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
@@ -51,17 +52,18 @@ OUT
|
|||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
stub pyenv-exec "python3.5 -m venv --help : true"
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
stub pyenv-exec "python -s -m ensurepip : true"
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.5.1 virtualenv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
PYENV_VERSION=3.5.1 virtualenv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/3.5.1/envs/venv/bin/pydoc" ]
|
||||||
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
@@ -69,24 +71,27 @@ OUT
|
|||||||
teardown_m_venv "3.5.1"
|
teardown_m_venv "3.5.1"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "install virtualenv if venv is not avaialble" {
|
@test "install virtualenv if venv is not available" {
|
||||||
export PYENV_VERSION="3.2.1"
|
export PYENV_VERSION="3.2.1"
|
||||||
setup_version "3.2.1"
|
setup_version "3.2.1"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
|
stub pyenv-exec "python3.2 -m venv --help : false"
|
||||||
|
stub pyenv-exec "python3 -m venv --help : false"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
stub pyenv-exec "python -m venv --help : false"
|
||||||
stub pyenv-exec "pip install virtualenv* : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "pip install virtualenv* : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.2.1 pip install virtualenv==13.1.2
|
PYENV_VERSION=3.2.1 pip install virtualenv==13.1.2
|
||||||
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/3.2.1/envs/venv
|
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/3.2.1/envs/venv
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/3.2.1/envs/venv/bin/pydoc" ]
|
||||||
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
@@ -100,7 +105,7 @@ OUT
|
|||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
stub pyenv-exec "python3.5 -m venv --help : true"
|
||||||
stub pyenv-exec "pip install virtualenv : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "pip install virtualenv : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
stub pyenv-exec "python -s -m ensurepip : true"
|
||||||
@@ -112,6 +117,7 @@ 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
|
PYENV_VERSION=3.5.1 virtualenv --python=${TMP}/python3 ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/3.5.1/envs/venv/bin/pydoc" ]
|
||||||
assert_success
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
@@ -126,7 +132,7 @@ OUT
|
|||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
stub pyenv-exec "python3.5 -m venv --help : true"
|
||||||
stub pyenv-exec "pip install virtualenv : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "pip install virtualenv : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : true"
|
stub pyenv-exec "python -s -m ensurepip : true"
|
||||||
@@ -138,6 +144,7 @@ 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
|
PYENV_VERSION=3.5.1 virtualenv --python=${TMP}/python3 ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/3.5.1/envs/venv/bin/pydoc" ]
|
||||||
assert_success
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
@@ -152,18 +159,21 @@ OUT
|
|||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
stub pyenv-prefix " : echo '${PYENV_ROOT}/versions/${PYENV_VERSION}'"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
|
stub pyenv-exec "python3.2 -m venv --help : false"
|
||||||
|
stub pyenv-exec "python3 -m venv --help : false"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
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 "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} \"\$@\""
|
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
|
||||||
|
|
||||||
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==13.1.2
|
||||||
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/3.2.1/envs/venv
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/3.2.1/envs/venv/bin/pydoc" ]
|
||||||
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
|
|||||||
@@ -9,6 +9,9 @@ setup() {
|
|||||||
@test "display virtualenv version" {
|
@test "display virtualenv version" {
|
||||||
setup_virtualenv "2.7.7"
|
setup_virtualenv "2.7.7"
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/2.7.7'"
|
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/2.7.7'"
|
||||||
|
stub pyenv-version-name "echo 2.7.7"
|
||||||
|
stub pyenv-exec "python2.7 -m venv --help : false"
|
||||||
|
stub pyenv-exec "python2 -m venv --help : false"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
stub pyenv-exec "python -m venv --help : false"
|
||||||
stub pyenv-exec "virtualenv --version : echo \"1.11\""
|
stub pyenv-exec "virtualenv --version : echo \"1.11\""
|
||||||
|
|
||||||
@@ -24,13 +27,14 @@ setup() {
|
|||||||
|
|
||||||
@test "display venv version" {
|
@test "display venv version" {
|
||||||
setup_m_venv "3.4.1"
|
setup_m_venv "3.4.1"
|
||||||
|
stub pyenv-version-name "echo 3.4.1"
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.4.1'"
|
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.4.1'"
|
||||||
stub pyenv-exec "python -m venv --help : true"
|
stub pyenv-exec "python3.4 -m venv --help : true"
|
||||||
|
|
||||||
run pyenv-virtualenv --version
|
run pyenv-virtualenv --version
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
[[ "$output" == "pyenv-virtualenv "?.?.?" (python -m venv)" ]]
|
[[ "$output" == "pyenv-virtualenv "?.?.?" (python3.4 -m venv)" ]]
|
||||||
|
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
teardown_m_venv "3.4.1"
|
teardown_m_venv "3.4.1"
|
||||||
|
|||||||
@@ -26,6 +26,8 @@ unstub_pyenv() {
|
|||||||
export PYENV_VERSION="2.7.11"
|
export PYENV_VERSION="2.7.11"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
|
stub pyenv-exec "python2.7 -m venv --help : false"
|
||||||
|
stub pyenv-exec "python2 -m venv --help : false"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
stub pyenv-exec "python -m venv --help : false"
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
stub pyenv-exec "python -s -m ensurepip : false"
|
||||||
@@ -34,12 +36,13 @@ unstub_pyenv() {
|
|||||||
|
|
||||||
run pyenv-virtualenv "2.7.11" "venv"
|
run pyenv-virtualenv "2.7.11" "venv"
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=2.7.11 virtualenv ${PYENV_ROOT}/versions/2.7.11/envs/venv
|
PYENV_VERSION=2.7.11 virtualenv ${PYENV_ROOT}/versions/2.7.11/envs/venv
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/2.7.11/envs/venv/bin/pydoc" ]
|
||||||
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
@@ -52,6 +55,8 @@ OUT
|
|||||||
stub_pyenv "${PYENV_VERSION}"
|
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-virtualenv-prefix " : false"
|
||||||
|
stub pyenv-exec "python2.7 -m venv --help : false"
|
||||||
|
stub pyenv-exec "python2 -m venv --help : false"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
stub pyenv-exec "python -m venv --help : false"
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
stub pyenv-exec "python -s -m ensurepip : false"
|
||||||
@@ -60,12 +65,13 @@ OUT
|
|||||||
|
|
||||||
run pyenv-virtualenv venv
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=2.7.11 virtualenv ${PYENV_ROOT}/versions/2.7.11/envs/venv
|
PYENV_VERSION=2.7.11 virtualenv ${PYENV_ROOT}/versions/2.7.11/envs/venv
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/2.7.11/envs/venv/bin/pydoc" ]
|
||||||
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
@@ -79,6 +85,8 @@ OUT
|
|||||||
stub_pyenv "${PYENV_VERSION}"
|
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-virtualenv-prefix " : false"
|
||||||
|
stub pyenv-exec "python2.7 -m venv --help : false"
|
||||||
|
stub pyenv-exec "python2 -m venv --help : false"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
stub pyenv-exec "python -m venv --help : false"
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
stub pyenv-exec "python -s -m ensurepip : false"
|
||||||
@@ -92,6 +100,7 @@ PYENV_VERSION=2.7.11 virtualenv --verbose --python=${TMP}/python ${PYENV_ROOT}/v
|
|||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/2.7.11/envs/venv/bin/pydoc" ]
|
||||||
assert_success
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
@@ -106,6 +115,8 @@ OUT
|
|||||||
stub_pyenv "${PYENV_VERSION}"
|
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-virtualenv-prefix " : false"
|
||||||
|
stub pyenv-exec "python2.7 -m venv --help : false"
|
||||||
|
stub pyenv-exec "python2 -m venv --help : false"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
stub pyenv-exec "python -m venv --help : false"
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
stub pyenv-exec "python -s -m ensurepip : false"
|
||||||
@@ -119,6 +130,7 @@ PYENV_VERSION=2.7.11 virtualenv --verbose --python=${TMP}/python ${PYENV_ROOT}/v
|
|||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/2.7.11/envs/venv/bin/pydoc" ]
|
||||||
assert_success
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
@@ -168,6 +180,8 @@ OUT
|
|||||||
export PYENV_VERSION="2.7.11"
|
export PYENV_VERSION="2.7.11"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
stub pyenv-virtualenv-prefix " : false"
|
stub pyenv-virtualenv-prefix " : false"
|
||||||
|
stub pyenv-exec "python2.7 -m venv --help : false"
|
||||||
|
stub pyenv-exec "python2 -m venv --help : false"
|
||||||
stub pyenv-exec "python -m venv --help : false"
|
stub pyenv-exec "python -m venv --help : false"
|
||||||
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "virtualenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
stub pyenv-exec "python -s -m ensurepip : false"
|
||||||
@@ -176,12 +190,13 @@ OUT
|
|||||||
|
|
||||||
run pyenv-virtualenv "2.7.11" "2.7.11/envs/foo"
|
run pyenv-virtualenv "2.7.11" "2.7.11/envs/foo"
|
||||||
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=2.7.11 virtualenv ${PYENV_ROOT}/versions/2.7.11/envs/foo
|
PYENV_VERSION=2.7.11 virtualenv ${PYENV_ROOT}/versions/2.7.11/envs/foo
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
assert [ -x "${PYENV_ROOT}/versions/2.7.11/envs/foo/bin/pydoc" ]
|
||||||
|
assert_success
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
|
|||||||
Reference in New Issue
Block a user