mirror of
https://github.com/pyenv/pyenv-virtualenv.git
synced 2025-11-08 11:33:55 -05:00
Compare commits
36 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0fd8a161e6 | ||
|
|
704f08f866 | ||
|
|
8c7dd01954 | ||
|
|
99a90ab774 | ||
|
|
187156d600 | ||
|
|
7dc9f78589 | ||
|
|
24b494a858 | ||
|
|
1488c3ed65 | ||
|
|
5c2d7dc291 | ||
|
|
f58bdb5cd5 | ||
|
|
d9391b4fb9 | ||
|
|
d6bc583753 | ||
|
|
98bb240843 | ||
|
|
1cb6bb06ef | ||
|
|
08cfea259c | ||
|
|
c64aebef08 | ||
|
|
b952f573ba | ||
|
|
62e32f9cb3 | ||
|
|
8ab4463d80 | ||
|
|
34dc769a5d | ||
|
|
16597f0bb8 | ||
|
|
fa0876685e | ||
|
|
ab5b5b9221 | ||
|
|
f627609419 | ||
|
|
23f7027ce4 | ||
|
|
55f7e3e1e1 | ||
|
|
d26852e274 | ||
|
|
7938c89aff | ||
|
|
1ce2e2d730 | ||
|
|
d3d6504e01 | ||
|
|
15981986e5 | ||
|
|
ddda0d7200 | ||
|
|
4f39ac4623 | ||
|
|
dbbbc33206 | ||
|
|
17ee6e72b6 | ||
|
|
1f761275cd |
16
CHANGELOG.md
16
CHANGELOG.md
@@ -1,5 +1,21 @@
|
|||||||
## Version History
|
## Version History
|
||||||
|
|
||||||
|
#### 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
|
#### 20160112
|
||||||
|
|
||||||
* Fix problem with `virtualenv` to look up executables from source version with `--system-site-packages` (#62)
|
* Fix problem with `virtualenv` to look up executables from source version with `--system-site-packages` (#62)
|
||||||
|
|||||||
22
README.md
22
README.md
@@ -111,14 +111,18 @@ $ pyenv virtualenv venv34
|
|||||||
`pyenv virtualenvs` shows you the list of existing virtualenvs and `conda` environments.
|
`pyenv virtualenvs` shows you the list of existing virtualenvs and `conda` environments.
|
||||||
|
|
||||||
```sh
|
```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)
|
miniconda3-3.9.1 (created from /home/yyuu/.pyenv/versions/miniconda3-3.9.1)
|
||||||
miniconda3-3.9.1/envs/myenv (created from /home/yyuu/.pyenv/versions/miniconda3-3.9.1)
|
miniconda3-3.9.1/envs/myenv (created from /home/yyuu/.pyenv/versions/miniconda3-3.9.1)
|
||||||
* venv27 (created from /home/yyuu/.pyenv/versions/2.7.10)
|
2.7.10/envs/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)
|
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
|
||||||
|
|
||||||
@@ -144,14 +148,14 @@ pyenv uninstall my-virtual-env
|
|||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
### virtualenv and pyvenv
|
### virtualenv and venv
|
||||||
|
|
||||||
There is a [venv](http://docs.python.org/3/library/venv.html) module available
|
There is a [venv](http://docs.python.org/3/library/venv.html) module available
|
||||||
for CPython 3.3 and newer.
|
for CPython 3.3 and newer.
|
||||||
It provides a command-line tool `pyvenv` which is the successor of `virtualenv`
|
It provides an executable module `venv` which is the successor of `virtualenv`
|
||||||
and distributed by default.
|
and distributed by default.
|
||||||
|
|
||||||
`pyenv-virtualenv` uses `pyvenv` if it is available and the `virtualenv`
|
`pyenv-virtualenv` uses `python -m venv` if it is available and the `virtualenv`
|
||||||
command is not available.
|
command is not available.
|
||||||
|
|
||||||
|
|
||||||
@@ -211,11 +215,11 @@ You can set certain environment variables to control pyenv-virtualenv.
|
|||||||
* `VIRTUALENV_VERSION`, if set, forces pyenv-virtualenv to install the desired
|
* `VIRTUALENV_VERSION`, if set, forces pyenv-virtualenv to install the desired
|
||||||
version of virtualenv. If `virtualenv` has not been installed,
|
version of virtualenv. If `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 `pyvenv` is preferred over `virtualenv`,
|
* `GET_PIP`, if set and `venv` is preferred over `virtualenv`,
|
||||||
use `get_pip.py` from the specified location.
|
use `get_pip.py` from the specified location.
|
||||||
* `GET_PIP_URL`, if set and `pyvenv` is preferred over
|
* `GET_PIP_URL`, if set and `venv` is preferred over
|
||||||
`virtualenv`, download `get_pip.py` from the specified URL.
|
`virtualenv`, download `get_pip.py` from the specified URL.
|
||||||
* `PIP_VERSION`, if set and `pyvenv` 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.
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -24,7 +24,6 @@ resolve_link() {
|
|||||||
|
|
||||||
unset FORCE
|
unset FORCE
|
||||||
unset QUIET
|
unset QUIET
|
||||||
unset VERBOSE
|
|
||||||
|
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
@@ -36,10 +35,6 @@ while [ $# -gt 0 ]; do
|
|||||||
"-f" | "--force" )
|
"-f" | "--force" )
|
||||||
FORCE=1
|
FORCE=1
|
||||||
;;
|
;;
|
||||||
"--no-error" )
|
|
||||||
# for backward compatibility with v20151103 and earlier
|
|
||||||
QUIET=1
|
|
||||||
;;
|
|
||||||
"-q" | "--quiet" )
|
"-q" | "--quiet" )
|
||||||
QUIET=1
|
QUIET=1
|
||||||
;;
|
;;
|
||||||
@@ -47,7 +42,8 @@ while [ $# -gt 0 ]; do
|
|||||||
exec pyenv-sh-deactivate
|
exec pyenv-sh-deactivate
|
||||||
;;
|
;;
|
||||||
"-v" | "--verbose" )
|
"-v" | "--verbose" )
|
||||||
VERBOSE=1
|
unset QUIET
|
||||||
|
PYENV_VIRTUALENV_VERBOSE_ACTIVATE=1
|
||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
break
|
break
|
||||||
@@ -136,9 +132,11 @@ if [[ "${VIRTUAL_ENV}" == "${prefix}" ]]; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
pyenv-sh-deactivate --force --quiet ${VERBOSE+--verbose} || true
|
pyenv-sh-deactivate --force --quiet || true
|
||||||
|
|
||||||
echo "pyenv-virtualenv: activate ${venv}" 1>&2
|
if [ -n "$PYENV_VIRTUALENV_VERBOSE_ACTIVATE" ]; then
|
||||||
|
echo "pyenv-virtualenv: activate ${venv}" 1>&2
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -z "$no_shell" ]; then
|
if [ -z "$no_shell" ]; then
|
||||||
# shell version set in pyenv-sh-activate should be unset
|
# shell version set in pyenv-sh-activate should be unset
|
||||||
@@ -162,7 +160,7 @@ EOS
|
|||||||
IFS="$OLDIFS"
|
IFS="$OLDIFS"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# virtualenv/pyvenv
|
# virtualenv/venv
|
||||||
case "${shell}" in
|
case "${shell}" in
|
||||||
fish )
|
fish )
|
||||||
cat <<EOS
|
cat <<EOS
|
||||||
@@ -180,7 +178,7 @@ esac
|
|||||||
|
|
||||||
# anaconda/miniconda
|
# anaconda/miniconda
|
||||||
if [ -x "${prefix}/bin/conda" ]; then
|
if [ -x "${prefix}/bin/conda" ]; then
|
||||||
if [[ "${venv}" != "${venv%/envs/*}" ]]; then
|
if [[ "${prefix}" != "${prefix%/envs/*}" ]]; then
|
||||||
CONDA_DEFAULT_ENV="${venv##*/envs/}"
|
CONDA_DEFAULT_ENV="${venv##*/envs/}"
|
||||||
else
|
else
|
||||||
CONDA_DEFAULT_ENV="root"
|
CONDA_DEFAULT_ENV="root"
|
||||||
@@ -218,10 +216,14 @@ PYENV_VIRTUALENV_DISABLE_PROMPT="${PYENV_VIRTUALENV_DISABLE_PROMPT:-${VIRTUAL_EN
|
|||||||
if [ -z "${PYENV_VIRTUALENV_DISABLE_PROMPT}" ]; then
|
if [ -z "${PYENV_VIRTUALENV_DISABLE_PROMPT}" ]; then
|
||||||
case "${shell}" in
|
case "${shell}" in
|
||||||
fish )
|
fish )
|
||||||
echo "pyenv-virtualenv: prompt changing not work for fish." 1>&2
|
if [ -z "${QUIET}" ]; then
|
||||||
|
echo "pyenv-virtualenv: prompt changing not working for fish." 1>&2
|
||||||
|
fi
|
||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
echo "pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior." 1>&2
|
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
|
cat <<EOS
|
||||||
export _OLD_VIRTUAL_PS1="\${PS1}";
|
export _OLD_VIRTUAL_PS1="\${PS1}";
|
||||||
export PS1="(${venv}) \${PS1}";
|
export PS1="(${venv}) \${PS1}";
|
||||||
@@ -229,3 +231,19 @@ EOS
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
fi
|
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
|
||||||
|
|||||||
@@ -15,22 +15,18 @@ fi
|
|||||||
|
|
||||||
unset FORCE
|
unset FORCE
|
||||||
unset QUIET
|
unset QUIET
|
||||||
unset VERBOSE
|
|
||||||
|
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
"-f" | "--force" )
|
"-f" | "--force" )
|
||||||
FORCE=1
|
FORCE=1
|
||||||
;;
|
;;
|
||||||
"--no-error" )
|
|
||||||
# for backward compatibility with v20151103 and earlier
|
|
||||||
QUIET=1
|
|
||||||
;;
|
|
||||||
"-q" | "--quiet")
|
"-q" | "--quiet")
|
||||||
QUIET=1
|
QUIET=1
|
||||||
;;
|
;;
|
||||||
"-v" | "--verbose" )
|
"-v" | "--verbose" )
|
||||||
VERBOSE=1
|
unset QUIET
|
||||||
|
PYENV_VIRTUALENV_VERBOSE_ACTIVATE=1
|
||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
break
|
break
|
||||||
@@ -58,7 +54,25 @@ else
|
|||||||
venv="${prefix##*/}"
|
venv="${prefix##*/}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "pyenv-virtualenv: deactivate ${venv}" 1>&2
|
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
|
if [ -n "${PYENV_ACTIVATE_SHELL}" ]; then
|
||||||
# shell version set in pyenv-sh-activate should be unset
|
# shell version set in pyenv-sh-activate should be unset
|
||||||
@@ -79,7 +93,7 @@ EOS
|
|||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# virtualenv/pyvenv
|
# virtualenv/venv
|
||||||
case "${shell}" in
|
case "${shell}" in
|
||||||
fish )
|
fish )
|
||||||
cat <<EOS
|
cat <<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="20160112"
|
PYENV_VIRTUALENV_VERSION="20160716"
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
[ -n "$PYENV_DEBUG" ] && set -x
|
[ -n "$PYENV_DEBUG" ] && set -x
|
||||||
@@ -107,11 +107,8 @@ version() {
|
|||||||
version="$(pyenv-exec conda --version 2>/dev/null || true)"
|
version="$(pyenv-exec conda --version 2>/dev/null || true)"
|
||||||
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (conda ${version:-unknown})"
|
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (conda ${version:-unknown})"
|
||||||
else
|
else
|
||||||
if [ -n "$USE_PYVENV" ]; then
|
if [ -n "$USE_M_VENV" ]; then
|
||||||
version="$(pyenv-which pyvenv 2>/dev/null || true)"
|
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (python -m venv)"
|
||||||
version="${version#${PYENV_ROOT}/versions/}"
|
|
||||||
version="${version%/bin/pyvenv}"
|
|
||||||
echo "pyenv-virtualenv ${PYENV_VIRTUALENV_VERSION} (pyvenv ${version:-unknown})"
|
|
||||||
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})"
|
||||||
@@ -125,8 +122,8 @@ usage() {
|
|||||||
if [ -n "${USE_CONDA}" ]; then
|
if [ -n "${USE_CONDA}" ]; then
|
||||||
pyenv-exec conda create --help 2>/dev/null || true
|
pyenv-exec conda create --help 2>/dev/null || true
|
||||||
else
|
else
|
||||||
if [ -n "${USE_PYVENV}" ]; then
|
if [ -n "${USE_M_VENV}" ]; then
|
||||||
pyenv-exec pyvenv --help 2>/dev/null || true
|
pyenv-exec 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
|
||||||
@@ -144,16 +141,16 @@ detect_venv() {
|
|||||||
if [ -x "${prefix}/bin/virtualenv" ]; then
|
if [ -x "${prefix}/bin/virtualenv" ]; then
|
||||||
HAS_VIRTUALENV=1
|
HAS_VIRTUALENV=1
|
||||||
fi
|
fi
|
||||||
if [ -x "${prefix}/bin/pyvenv" ]; then
|
if pyenv-exec python -m venv --help 1>/dev/null 2>&1; then
|
||||||
HAS_PYVENV=1
|
HAS_M_VENV=1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
# Use pyvenv only if there is pyvenv, 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
|
||||||
USE_CONDA=1
|
USE_CONDA=1
|
||||||
else
|
else
|
||||||
if [ -n "${HAS_PYVENV}" ] && [ -z "${HAS_VIRTUALENV}" ] && [ -z "${VIRTUALENV_PYTHON}" ]; then
|
if [ -n "${HAS_M_VENV}" ] && [ -z "${HAS_VIRTUALENV}" ] && [ -z "${VIRTUALENV_PYTHON}" ]; then
|
||||||
USE_PYVENV=1
|
USE_M_VENV=1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@@ -359,9 +356,9 @@ if [ -n "${COMPAT_VIRTUALENV_PATH}" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
unset HAS_VIRTUALENV
|
unset HAS_VIRTUALENV
|
||||||
unset HAS_PYVENV
|
unset HAS_M_VENV
|
||||||
unset USE_CONDA
|
unset USE_CONDA
|
||||||
unset USE_PYVENV
|
unset USE_M_VENV
|
||||||
detect_venv
|
detect_venv
|
||||||
|
|
||||||
SEED="$(date "+%Y%m%d%H%M%S").$$"
|
SEED="$(date "+%Y%m%d%H%M%S").$$"
|
||||||
@@ -371,13 +368,30 @@ REQUIREMENTS="${TMP}/requirements.${SEED}.txt"
|
|||||||
# Upgrade existing virtualenv
|
# Upgrade existing virtualenv
|
||||||
if [ -n "$UPGRADE" ]; then
|
if [ -n "$UPGRADE" ]; then
|
||||||
FORCE=1
|
FORCE=1
|
||||||
# pyvenv has `--upgrade` by default
|
# `python -m venv` has `--upgrade` by default
|
||||||
if [ -n "${USE_PYVENV}" ]; then
|
if [ -n "${USE_M_VENV}" ]; then
|
||||||
unset UPGRADE
|
unset UPGRADE
|
||||||
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--upgrade"
|
VIRTUALENV_OPTIONS[${#VIRTUALENV_OPTIONS[*]}]="--upgrade"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ -z "${VIRTUALEN_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
|
if [ -n "${USE_CONDA}" ]; then
|
||||||
# e.g. `conda create -n py35 python=3.5 anaconda`
|
# e.g. `conda create -n py35 python=3.5 anaconda`
|
||||||
if [ -n "${VIRTUALENV_PYTHON}" ]; then
|
if [ -n "${VIRTUALENV_PYTHON}" ]; then
|
||||||
@@ -388,12 +402,12 @@ if [ -n "${USE_CONDA}" ]; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
if [ -n "${USE_PYVENV}" ]; then
|
if [ -n "${USE_M_VENV}" ]; then
|
||||||
# Unset some arguments not supported by pyvenv
|
# Unset some arguments not supported by `python -m venv`
|
||||||
unset QUIET
|
unset QUIET
|
||||||
unset VERBOSE
|
unset VERBOSE
|
||||||
if [ -n "${VIRTUALENV_PYTHON}" ]; then
|
if [ -n "${VIRTUALENV_PYTHON}" ]; then
|
||||||
echo "pyenv-virtualenv: \`--python=${VIRTUALENV_PYTHON}' is not supported by pyvenv." 1>&2
|
echo "pyenv-virtualenv: \`--python=${VIRTUALENV_PYTHON}' is not supported by \`python -m venv'." 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
@@ -416,8 +430,12 @@ else
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
if [ -z "${HAS_VIRTUALENV}" ]; then
|
if [ -z "${HAS_VIRTUALENV}" ]; then
|
||||||
VIRTUALENV_VERSION="==${VIRTUALENV_VERSION}"
|
if [ -n "${VIRTUALENV_VERSION}" ]; then
|
||||||
pyenv-exec pip install $QUIET $VERBOSE "virtualenv${VIRTUALENV_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
|
||||||
@@ -503,8 +521,8 @@ cd "${PYENV_VIRTUALENV_CACHE_PATH}"
|
|||||||
if [ -n "${USE_CONDA}" ]; then
|
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_PYVENV}" ]; then
|
if [ -n "${USE_M_VENV}" ]; then
|
||||||
pyenv-exec pyvenv $QUIET $VERBOSE "${VIRTUALENV_OPTIONS[@]}" "${VIRTUALENV_PATH}" || STATUS="$?"
|
pyenv-exec 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
|
||||||
|
|||||||
@@ -71,7 +71,7 @@ if [ -z "$print" ]; then
|
|||||||
echo
|
echo
|
||||||
case "$shell" in
|
case "$shell" in
|
||||||
fish )
|
fish )
|
||||||
echo 'status --is-interactive; and . (pyenv virtualenv-init -|psub)'
|
echo 'status --is-interactive; and source (pyenv virtualenv-init -|psub)'
|
||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
echo 'eval "$(pyenv virtualenv-init -)"'
|
echo 'eval "$(pyenv virtualenv-init -)"'
|
||||||
@@ -92,7 +92,7 @@ EOS
|
|||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
cat <<EOS
|
cat <<EOS
|
||||||
export PATH="${PYENV_VIRTUALENV_ROOT:-${PYENV_VIRTUALENV_INSTALL_PREFIX}}/shims:${PATH}";
|
export PATH="${PYENV_VIRTUALENV_ROOT:-${PYENV_VIRTUALENV_INSTALL_PREFIX}}/shims:\${PATH}";
|
||||||
export PYENV_VIRTUALENV_INIT=1;
|
export PYENV_VIRTUALENV_INIT=1;
|
||||||
EOS
|
EOS
|
||||||
;;
|
;;
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ for version in "${versions[@]}"; do
|
|||||||
VIRTUALENV_PREFIX_PATH="${PYENV_PREFIX_PATH}"
|
VIRTUALENV_PREFIX_PATH="${PYENV_PREFIX_PATH}"
|
||||||
else
|
else
|
||||||
if [ -f "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" ]; then
|
if [ -f "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" ]; then
|
||||||
# pyvenv
|
# 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_PATH="${virtualenv_binpath%/bin}"
|
VIRTUALENV_PREFIX_PATH="${virtualenv_binpath%/bin}"
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ if [ ! -x "${PYENV_COMMAND_PATH}" ] && [[ "${PYENV_COMMAND_PATH##*/}" == "python
|
|||||||
: # 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}/bin/pyvenv.cfg" ]; then
|
||||||
# pyvenv
|
# 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}"
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ if [ ! -x "${PYENV_COMMAND_PATH}" ]; then
|
|||||||
: # do nothing for conda's environments
|
: # do nothing for conda's environments
|
||||||
else
|
else
|
||||||
if [ -f "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" ]; then
|
if [ -f "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" ]; then
|
||||||
# pyvenv
|
# 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}"
|
||||||
if grep -q -i "include-system-site-packages *= *true" "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" 1>/dev/null 2>&1; then
|
if grep -q -i "include-system-site-packages *= *true" "${PYENV_ROOT}/versions/${version}/pyvenv.cfg" 1>/dev/null 2>&1; then
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ setup() {
|
|||||||
unset CONDA_DEFAULT_ENV
|
unset CONDA_DEFAULT_ENV
|
||||||
unset PYTHONHOME
|
unset PYTHONHOME
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME
|
unset _OLD_VIRTUAL_PYTHONHOME
|
||||||
|
unset PYENV_VIRTUALENV_VERBOSE_ACTIVATE
|
||||||
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
||||||
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
||||||
unset VIRTUAL_ENV_DISABLE_PROMPT
|
unset VIRTUAL_ENV_DISABLE_PROMPT
|
||||||
@@ -30,7 +31,6 @@ setup() {
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate venv
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
||||||
export 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.
|
pyenv-virtualenv: prompt changing will be removed from future release. configure \`export PYENV_VIRTUALENV_DISABLE_PROMPT=1' to simulate the behavior.
|
||||||
@@ -44,13 +44,39 @@ EOS
|
|||||||
unstub pyenv-sh-deactivate
|
unstub pyenv-sh-deactivate
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "activate virtualenv from current version (verbose)" {
|
@test "activate virtualenv from current version (quiet)" {
|
||||||
export PYENV_VIRTUALENV_INIT=1
|
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 --verbose : echo deactivated"
|
stub pyenv-sh-deactivate "--force --quiet : echo deactivated"
|
||||||
|
|
||||||
|
PYENV_SHELL="bash" PYENV_VERSION="venv" run pyenv-sh-activate --quiet
|
||||||
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<EOS
|
||||||
|
deactivated
|
||||||
|
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
||||||
|
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
||||||
|
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 (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
|
PYENV_SHELL="bash" PYENV_VERSION="venv" run pyenv-sh-activate --verbose
|
||||||
|
|
||||||
@@ -84,7 +110,6 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate venv
|
|
||||||
export PYENV_VERSION="venv";
|
export PYENV_VERSION="venv";
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
export PYENV_ACTIVATE_SHELL=1;
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv";
|
||||||
@@ -113,10 +138,9 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate venv
|
|
||||||
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
||||||
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
||||||
pyenv-virtualenv: prompt changing not work for fish.
|
pyenv-virtualenv: prompt changing not working for fish.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
@@ -138,12 +162,11 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate venv
|
|
||||||
setenv PYENV_VERSION "venv";
|
setenv PYENV_VERSION "venv";
|
||||||
setenv PYENV_ACTIVATE_SHELL 1;
|
setenv PYENV_ACTIVATE_SHELL 1;
|
||||||
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
||||||
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv";
|
||||||
pyenv-virtualenv: prompt changing not work for fish.
|
pyenv-virtualenv: prompt changing not working for fish.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
@@ -164,7 +187,6 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate venv27
|
|
||||||
export PYENV_VERSION="venv27";
|
export PYENV_VERSION="venv27";
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
export PYENV_ACTIVATE_SHELL=1;
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
||||||
@@ -191,7 +213,6 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate venv27
|
|
||||||
export PYENV_VERSION="venv27";
|
export PYENV_VERSION="venv27";
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
export PYENV_ACTIVATE_SHELL=1;
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
||||||
@@ -218,12 +239,11 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate venv27
|
|
||||||
setenv PYENV_VERSION "venv27";
|
setenv PYENV_VERSION "venv27";
|
||||||
setenv PYENV_ACTIVATE_SHELL 1;
|
setenv PYENV_ACTIVATE_SHELL 1;
|
||||||
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
||||||
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
||||||
pyenv-virtualenv: prompt changing not work for fish.
|
pyenv-virtualenv: prompt changing not working for fish.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
@@ -243,12 +263,11 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate venv27
|
|
||||||
setenv PYENV_VERSION "venv27";
|
setenv PYENV_VERSION "venv27";
|
||||||
setenv PYENV_ACTIVATE_SHELL 1;
|
setenv PYENV_ACTIVATE_SHELL 1;
|
||||||
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
setenv PYENV_VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
||||||
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
setenv VIRTUAL_ENV "${PYENV_ROOT}/versions/venv27";
|
||||||
pyenv-virtualenv: prompt changing not work for fish.
|
pyenv-virtualenv: prompt changing not working for fish.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
@@ -367,7 +386,6 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate venv27
|
|
||||||
export PYENV_VERSION="venv27:2.7.10";
|
export PYENV_VERSION="venv27:2.7.10";
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
export PYENV_ACTIVATE_SHELL=1;
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv27";
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ setup() {
|
|||||||
unset CONDA_DEFAULT_ENV
|
unset CONDA_DEFAULT_ENV
|
||||||
unset PYTHONHOME
|
unset PYTHONHOME
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME
|
unset _OLD_VIRTUAL_PYTHONHOME
|
||||||
|
unset PYENV_VIRTUALENV_VERBOSE_ACTIVATE
|
||||||
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
||||||
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
||||||
unset VIRTUAL_ENV_DISABLE_PROMPT
|
unset VIRTUAL_ENV_DISABLE_PROMPT
|
||||||
@@ -32,7 +33,6 @@ setup() {
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate anaconda-2.3.0
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0";
|
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0";
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0";
|
export VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0";
|
||||||
export CONDA_DEFAULT_ENV="root";
|
export CONDA_DEFAULT_ENV="root";
|
||||||
@@ -62,11 +62,10 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate anaconda-2.3.0
|
|
||||||
setenv PYENV_VIRTUAL_ENV "${TMP}/pyenv/versions/anaconda-2.3.0";
|
setenv PYENV_VIRTUAL_ENV "${TMP}/pyenv/versions/anaconda-2.3.0";
|
||||||
setenv VIRTUAL_ENV "${TMP}/pyenv/versions/anaconda-2.3.0";
|
setenv VIRTUAL_ENV "${TMP}/pyenv/versions/anaconda-2.3.0";
|
||||||
setenv CONDA_DEFAULT_ENV "root";
|
setenv CONDA_DEFAULT_ENV "root";
|
||||||
pyenv-virtualenv: prompt changing not work for fish.
|
pyenv-virtualenv: prompt changing not working for fish.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
@@ -90,7 +89,6 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate miniconda-3.9.1
|
|
||||||
export PYENV_VERSION="miniconda-3.9.1";
|
export PYENV_VERSION="miniconda-3.9.1";
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
export PYENV_ACTIVATE_SHELL=1;
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/miniconda-3.9.1";
|
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/miniconda-3.9.1";
|
||||||
@@ -122,13 +120,13 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate anaconda-2.3.0/envs/foo
|
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo";
|
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 VIRTUAL_ENV="${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo";
|
||||||
export CONDA_DEFAULT_ENV="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.
|
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}";
|
||||||
|
. "${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo/etc/conda/activate.d/activate.sh";
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
@@ -152,7 +150,6 @@ EOS
|
|||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
deactivated
|
deactivated
|
||||||
pyenv-virtualenv: activate miniconda-3.9.1/envs/bar
|
|
||||||
export PYENV_VERSION="miniconda-3.9.1/envs/bar";
|
export PYENV_VERSION="miniconda-3.9.1/envs/bar";
|
||||||
export PYENV_ACTIVATE_SHELL=1;
|
export PYENV_ACTIVATE_SHELL=1;
|
||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/miniconda-3.9.1/envs/bar";
|
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/miniconda-3.9.1/envs/bar";
|
||||||
@@ -161,6 +158,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}";
|
||||||
|
. "${PYENV_ROOT}/versions/miniconda-3.9.1/envs/bar/etc/conda/activate.d/activate.sh";
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ setup() {
|
|||||||
unset CONDA_DEFAULT_ENV
|
unset CONDA_DEFAULT_ENV
|
||||||
unset PYTHONHOME
|
unset PYTHONHOME
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME
|
unset _OLD_VIRTUAL_PYTHONHOME
|
||||||
|
unset PYENV_VIRTUALENV_VERBOSE_ACTIVATE
|
||||||
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
||||||
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
||||||
unset VIRTUAL_ENV_DISABLE_PROMPT
|
unset VIRTUAL_ENV_DISABLE_PROMPT
|
||||||
@@ -29,7 +30,6 @@ setup() {
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate anaconda-2.3.0
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
unset PYENV_VIRTUAL_ENV;
|
||||||
unset VIRTUAL_ENV;
|
unset VIRTUAL_ENV;
|
||||||
unset CONDA_DEFAULT_ENV;
|
unset CONDA_DEFAULT_ENV;
|
||||||
@@ -65,7 +65,6 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate anaconda-2.3.0
|
|
||||||
set -e PYENV_VIRTUAL_ENV;
|
set -e PYENV_VIRTUAL_ENV;
|
||||||
set -e VIRTUAL_ENV;
|
set -e VIRTUAL_ENV;
|
||||||
set -e CONDA_DEFAULT_ENV;
|
set -e CONDA_DEFAULT_ENV;
|
||||||
@@ -97,7 +96,7 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate anaconda-2.3.0/envs/foo
|
. "${PYENV_ROOT}/versions/anaconda-2.3.0/envs/foo/etc/conda/deactivate.d/deactivate.sh";
|
||||||
unset PYENV_VIRTUAL_ENV;
|
unset PYENV_VIRTUAL_ENV;
|
||||||
unset VIRTUAL_ENV;
|
unset VIRTUAL_ENV;
|
||||||
unset CONDA_DEFAULT_ENV;
|
unset CONDA_DEFAULT_ENV;
|
||||||
|
|||||||
@@ -40,7 +40,7 @@ OUT
|
|||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_pyvenv "miniconda3-3.16.0"
|
teardown_m_venv "miniconda3-3.16.0"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "create virtualenv by conda create with -p" {
|
@test "create virtualenv by conda create with -p" {
|
||||||
@@ -63,7 +63,7 @@ OUT
|
|||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_pyvenv "miniconda3-3.16.0"
|
teardown_m_venv "miniconda3-3.16.0"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "create virtualenv by conda create with --python" {
|
@test "create virtualenv by conda create with --python" {
|
||||||
@@ -86,5 +86,5 @@ OUT
|
|||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_pyvenv "miniconda3-3.16.0"
|
teardown_m_venv "miniconda3-3.16.0"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ setup() {
|
|||||||
unset CONDA_DEFAULT_ENV
|
unset CONDA_DEFAULT_ENV
|
||||||
unset PYTHONHOME
|
unset PYTHONHOME
|
||||||
unset _OLD_VIRTUAL_PYTHONHOME
|
unset _OLD_VIRTUAL_PYTHONHOME
|
||||||
|
unset PYENV_VIRTUALENV_VERBOSE_ACTIVATE
|
||||||
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
unset PYENV_VIRTUALENV_DISABLE_PROMPT
|
||||||
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
unset PYENV_VIRTUAL_ENV_DISABLE_PROMPT
|
||||||
unset VIRTUAL_ENV_DISABLE_PROMPT
|
unset VIRTUAL_ENV_DISABLE_PROMPT
|
||||||
@@ -27,7 +28,36 @@ setup() {
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
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 --quit
|
||||||
|
|
||||||
|
assert_success
|
||||||
|
assert_output <<EOS
|
||||||
unset PYENV_VIRTUAL_ENV;
|
unset PYENV_VIRTUAL_ENV;
|
||||||
unset VIRTUAL_ENV;
|
unset VIRTUAL_ENV;
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
||||||
@@ -53,6 +83,7 @@ EOS
|
|||||||
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
export PYENV_VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
||||||
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
export VIRTUAL_ENV="${PYENV_ROOT}/versions/venv"
|
||||||
export PYENV_ACTIVATE_SHELL=
|
export PYENV_ACTIVATE_SHELL=
|
||||||
|
export PYENV_VIRTUALENV_VERBOSE_ACTIVATE=1
|
||||||
|
|
||||||
PYENV_SHELL="bash" run pyenv-sh-deactivate --verbose
|
PYENV_SHELL="bash" run pyenv-sh-deactivate --verbose
|
||||||
|
|
||||||
@@ -89,7 +120,6 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate venv
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
unset PYENV_VIRTUAL_ENV;
|
||||||
unset VIRTUAL_ENV;
|
unset VIRTUAL_ENV;
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
||||||
@@ -120,7 +150,6 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate venv
|
|
||||||
unset PYENV_VERSION;
|
unset PYENV_VERSION;
|
||||||
unset PYENV_ACTIVATE_SHELL;
|
unset PYENV_ACTIVATE_SHELL;
|
||||||
unset PYENV_VIRTUAL_ENV;
|
unset PYENV_VIRTUAL_ENV;
|
||||||
@@ -153,7 +182,6 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate venv
|
|
||||||
unset PYENV_VERSION;
|
unset PYENV_VERSION;
|
||||||
unset PYENV_ACTIVATE_SHELL;
|
unset PYENV_ACTIVATE_SHELL;
|
||||||
unset PYENV_VIRTUAL_ENV;
|
unset PYENV_VIRTUAL_ENV;
|
||||||
@@ -186,7 +214,6 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate venv
|
|
||||||
unset PYENV_VIRTUAL_ENV;
|
unset PYENV_VIRTUAL_ENV;
|
||||||
unset VIRTUAL_ENV;
|
unset VIRTUAL_ENV;
|
||||||
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
if [ -n "\${_OLD_VIRTUAL_PATH}" ]; then
|
||||||
@@ -217,7 +244,6 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate venv
|
|
||||||
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" ];
|
||||||
@@ -244,7 +270,6 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate venv
|
|
||||||
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" ];
|
||||||
@@ -271,7 +296,6 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate venv
|
|
||||||
set -e PYENV_VERSION;
|
set -e PYENV_VERSION;
|
||||||
set -e PYENV_ACTIVATE_SHELL;
|
set -e PYENV_ACTIVATE_SHELL;
|
||||||
set -e PYENV_VIRTUAL_ENV;
|
set -e PYENV_VIRTUAL_ENV;
|
||||||
@@ -300,7 +324,6 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate venv
|
|
||||||
set -e PYENV_VERSION;
|
set -e PYENV_VERSION;
|
||||||
set -e PYENV_ACTIVATE_SHELL;
|
set -e PYENV_ACTIVATE_SHELL;
|
||||||
set -e PYENV_VIRTUAL_ENV;
|
set -e PYENV_VIRTUAL_ENV;
|
||||||
@@ -329,7 +352,6 @@ EOS
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
pyenv-virtualenv: deactivate venv
|
|
||||||
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" ];
|
||||||
|
|||||||
@@ -23,8 +23,8 @@ setup() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "delete virtualenv by symlink" {
|
@test "delete virtualenv by symlink" {
|
||||||
mkdir -p "${PYENV_ROOT}/versions/2.7.10/envs/venv27"
|
mkdir -p "${PYENV_ROOT}/versions/2.7.11/envs/venv27"
|
||||||
ln -fs "${PYENV_ROOT}/versions/2.7.10/envs/venv27" "${PYENV_ROOT}/versions/venv27"
|
ln -fs "${PYENV_ROOT}/versions/2.7.11/envs/venv27" "${PYENV_ROOT}/versions/venv27"
|
||||||
|
|
||||||
stub pyenv-rehash "true"
|
stub pyenv-rehash "true"
|
||||||
|
|
||||||
@@ -34,55 +34,55 @@ setup() {
|
|||||||
|
|
||||||
unstub pyenv-rehash
|
unstub pyenv-rehash
|
||||||
|
|
||||||
[ ! -d "${PYENV_ROOT}/versions/2.7.10/envs/venv27" ]
|
[ ! -d "${PYENV_ROOT}/versions/2.7.11/envs/venv27" ]
|
||||||
[ ! -L "${PYENV_ROOT}/versions/venv27" ]
|
[ ! -L "${PYENV_ROOT}/versions/venv27" ]
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "delete virtualenv with symlink" {
|
@test "delete virtualenv with symlink" {
|
||||||
mkdir -p "${PYENV_ROOT}/versions/2.7.10/envs/venv27"
|
mkdir -p "${PYENV_ROOT}/versions/2.7.11/envs/venv27"
|
||||||
ln -fs "${PYENV_ROOT}/versions/2.7.10/envs/venv27" "${PYENV_ROOT}/versions/venv27"
|
ln -fs "${PYENV_ROOT}/versions/2.7.11/envs/venv27" "${PYENV_ROOT}/versions/venv27"
|
||||||
|
|
||||||
stub pyenv-rehash "true"
|
stub pyenv-rehash "true"
|
||||||
|
|
||||||
run pyenv-virtualenv-delete -f "2.7.10/envs/venv27"
|
run pyenv-virtualenv-delete -f "2.7.11/envs/venv27"
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
|
|
||||||
unstub pyenv-rehash
|
unstub pyenv-rehash
|
||||||
|
|
||||||
[ ! -d "${PYENV_ROOT}/versions/2.7.10/envs/venv27" ]
|
[ ! -d "${PYENV_ROOT}/versions/2.7.11/envs/venv27" ]
|
||||||
[ ! -L "${PYENV_ROOT}/versions/venv27" ]
|
[ ! -L "${PYENV_ROOT}/versions/venv27" ]
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "not delete virtualenv with different symlink" {
|
@test "not delete virtualenv with different symlink" {
|
||||||
mkdir -p "${PYENV_ROOT}/versions/2.7.8/envs/venv27"
|
mkdir -p "${PYENV_ROOT}/versions/2.7.8/envs/venv27"
|
||||||
mkdir -p "${PYENV_ROOT}/versions/2.7.10/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"
|
ln -fs "${PYENV_ROOT}/versions/2.7.8/envs/venv27" "${PYENV_ROOT}/versions/venv27"
|
||||||
|
|
||||||
stub pyenv-rehash "true"
|
stub pyenv-rehash "true"
|
||||||
|
|
||||||
run pyenv-virtualenv-delete -f "2.7.10/envs/venv27"
|
run pyenv-virtualenv-delete -f "2.7.11/envs/venv27"
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
|
|
||||||
unstub pyenv-rehash
|
unstub pyenv-rehash
|
||||||
|
|
||||||
[ ! -d "${PYENV_ROOT}/versions/2.7.10/envs/venv27" ]
|
[ ! -d "${PYENV_ROOT}/versions/2.7.11/envs/venv27" ]
|
||||||
[ -L "${PYENV_ROOT}/versions/venv27" ]
|
[ -L "${PYENV_ROOT}/versions/venv27" ]
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "not delete virtualenv with same name" {
|
@test "not delete virtualenv with same name" {
|
||||||
mkdir -p "${PYENV_ROOT}/versions/2.7.10/envs/venv27"
|
mkdir -p "${PYENV_ROOT}/versions/2.7.11/envs/venv27"
|
||||||
mkdir -p "${PYENV_ROOT}/versions/venv27"
|
mkdir -p "${PYENV_ROOT}/versions/venv27"
|
||||||
|
|
||||||
stub pyenv-rehash "true"
|
stub pyenv-rehash "true"
|
||||||
|
|
||||||
run pyenv-virtualenv-delete -f "2.7.10/envs/venv27"
|
run pyenv-virtualenv-delete -f "2.7.11/envs/venv27"
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
|
|
||||||
unstub pyenv-rehash
|
unstub pyenv-rehash
|
||||||
|
|
||||||
[ ! -d "${PYENV_ROOT}/versions/2.7.10/envs/venv27" ]
|
[ ! -d "${PYENV_ROOT}/versions/2.7.11/envs/venv27" ]
|
||||||
[ -d "${PYENV_ROOT}/versions/venv27" ]
|
[ -d "${PYENV_ROOT}/versions/venv27" ]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,28 +19,29 @@ unstub_pyenv() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "path should be handled properly even if there is 'envs' in PYENV_ROOT" {
|
@test "path should be handled properly even if there is 'envs' in PYENV_ROOT" {
|
||||||
export PYENV_VERSION="3.4.1"
|
export PYENV_VERSION="3.5.1"
|
||||||
setup_pyvenv "3.4.1"
|
setup_m_venv "3.5.1"
|
||||||
stub_pyenv "${PYENV_VERSION}"
|
stub_pyenv "${PYENV_VERSION}"
|
||||||
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 "pyvenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";mkdir -p \${PYENV_ROOT}/versions/3.4.1/envs/venv/bin"
|
stub pyenv-exec "python -m venv --help : true"
|
||||||
stub pyenv-exec "python -s -m ensurepip : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";touch \${PYENV_ROOT}/versions/3.4.1/envs/venv/bin/pip"
|
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
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.4.1 pyvenv ${PYENV_ROOT}/versions/3.4.1/envs/venv
|
PYENV_VERSION=3.5.1 python -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
PYENV_VERSION=3.4.1/envs/venv python -s -m ensurepip
|
PYENV_VERSION=3.5.1/envs/venv python -s -m ensurepip
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
assert [ -e "${PYENV_ROOT}/versions/3.4.1/envs/venv/bin/pip" ]
|
assert [ -e "${PYENV_ROOT}/versions/3.5.1/envs/venv/bin/pip" ]
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_pyvenv "3.4.1"
|
teardown_m_venv "3.5.1"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,22 +13,23 @@ 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.2.1"
|
setup_version "3.5.1"
|
||||||
create_executable "3.2.1" "virtualenv"
|
create_executable "3.5.1" "virtualenv"
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.2.1'"
|
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.5.1'"
|
||||||
stub pyenv-prefix "echo '${PYENV_ROOT}/versions/3.2.1'"
|
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.2.1 \"\$@\""
|
stub pyenv-exec "echo PYENV_VERSION=3.5.1 \"\$@\""
|
||||||
stub pyenv-exec "echo PYENV_VERSION=3.2.1 \"\$@\""
|
stub pyenv-exec "echo PYENV_VERSION=3.5.1 \"\$@\""
|
||||||
stub pyenv-rehash "echo rehashed"
|
stub pyenv-rehash "echo rehashed"
|
||||||
|
|
||||||
run pyenv-virtualenv "3.2.1" venv
|
run pyenv-virtualenv "3.5.1" venv
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<-OUT
|
assert_output <<-OUT
|
||||||
before: ${PYENV_ROOT}/versions/3.2.1/envs/venv
|
before: ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/3.2.1/envs/venv
|
PYENV_VERSION=3.5.1 virtualenv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
PYENV_VERSION=3.2.1 python -s -m ensurepip
|
PYENV_VERSION=3.5.1 python -s -m ensurepip
|
||||||
after: 0
|
after: 0
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
@@ -37,5 +38,5 @@ OUT
|
|||||||
unstub pyenv-hooks
|
unstub pyenv-hooks
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
unstub pyenv-rehash
|
unstub pyenv-rehash
|
||||||
teardown_version "3.2.1"
|
teardown_version "3.5.1"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -42,7 +42,7 @@ load test_helper
|
|||||||
@test "fish instructions" {
|
@test "fish instructions" {
|
||||||
run pyenv-virtualenv-init fish
|
run pyenv-virtualenv-init fish
|
||||||
assert [ "$status" -eq 1 ]
|
assert [ "$status" -eq 1 ]
|
||||||
assert_output_contains 'status --is-interactive; and . (pyenv virtualenv-init -|psub)'
|
assert_output_contains 'status --is-interactive; and source (pyenv virtualenv-init -|psub)'
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "outputs bash-specific syntax" {
|
@test "outputs bash-specific syntax" {
|
||||||
@@ -50,7 +50,7 @@ load test_helper
|
|||||||
run pyenv-virtualenv-init - bash
|
run pyenv-virtualenv-init - bash
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
export PATH="${TMP}/pyenv/plugins/pyenv-virtualenv/shims:${PATH}";
|
export PATH="${TMP}/pyenv/plugins/pyenv-virtualenv/shims:\${PATH}";
|
||||||
export PYENV_VIRTUALENV_INIT=1;
|
export PYENV_VIRTUALENV_INIT=1;
|
||||||
_pyenv_virtualenv_hook() {
|
_pyenv_virtualenv_hook() {
|
||||||
local ret=\$?
|
local ret=\$?
|
||||||
@@ -91,7 +91,7 @@ EOS
|
|||||||
run pyenv-virtualenv-init - zsh
|
run pyenv-virtualenv-init - zsh
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<EOS
|
assert_output <<EOS
|
||||||
export PATH="${TMP}/pyenv/plugins/pyenv-virtualenv/shims:${PATH}";
|
export PATH="${TMP}/pyenv/plugins/pyenv-virtualenv/shims:\${PATH}";
|
||||||
export PYENV_VIRTUALENV_INIT=1;
|
export PYENV_VIRTUALENV_INIT=1;
|
||||||
_pyenv_virtualenv_hook() {
|
_pyenv_virtualenv_hook() {
|
||||||
local ret=\$?
|
local ret=\$?
|
||||||
|
|||||||
@@ -21,54 +21,56 @@ unstub_pyenv() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "install pip with ensurepip" {
|
@test "install pip with ensurepip" {
|
||||||
export PYENV_VERSION="3.4.1"
|
export PYENV_VERSION="3.5.1"
|
||||||
setup_pyvenv "3.4.1"
|
setup_m_venv "3.5.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 "pyvenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";mkdir -p \${PYENV_ROOT}/versions/3.4.1/envs/venv/bin"
|
stub pyenv-exec "python -m venv --help : true"
|
||||||
stub pyenv-exec "python -s -m ensurepip : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";touch \${PYENV_ROOT}/versions/3.4.1/envs/venv/bin/pip"
|
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
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.4.1 pyvenv ${PYENV_ROOT}/versions/3.4.1/envs/venv
|
PYENV_VERSION=3.5.1 python -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
PYENV_VERSION=3.4.1/envs/venv python -s -m ensurepip
|
PYENV_VERSION=3.5.1/envs/venv python -s -m ensurepip
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
assert [ -e "${PYENV_ROOT}/versions/3.4.1/envs/venv/bin/pip" ]
|
assert [ -e "${PYENV_ROOT}/versions/3.5.1/envs/venv/bin/pip" ]
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_pyvenv "3.4.1"
|
teardown_m_venv "3.5.1"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "install pip without using ensurepip" {
|
@test "install pip without using ensurepip" {
|
||||||
export PYENV_VERSION="3.3.5"
|
export PYENV_VERSION="3.3.6"
|
||||||
setup_pyvenv "3.3.5"
|
setup_m_venv "3.3.6"
|
||||||
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 "pyvenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";mkdir -p \${PYENV_ROOT}/versions/3.3.5/envs/venv/bin"
|
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 -m ensurepip : false"
|
||||||
stub pyenv-exec "python -s */get-pip.py : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\";touch \${PYENV_ROOT}/versions/3.3.5/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
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.3.5 pyvenv ${PYENV_ROOT}/versions/3.3.5/envs/venv
|
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...
|
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
||||||
PYENV_VERSION=3.3.5/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
|
||||||
assert [ -e "${PYENV_ROOT}/versions/3.3.5/envs/venv/bin/pip" ]
|
assert [ -e "${PYENV_ROOT}/versions/3.3.6/envs/venv/bin/pip" ]
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_pyvenv "3.3.5"
|
teardown_m_venv "3.3.6"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -45,14 +45,14 @@ remove_virtualenv() {
|
|||||||
remove_version "${2:-$1}"
|
remove_version "${2:-$1}"
|
||||||
}
|
}
|
||||||
|
|
||||||
create_pyvenv() {
|
create_m_venv() {
|
||||||
create_version "$1"
|
create_version "$1"
|
||||||
create_version "${2:-$1}"
|
create_version "${2:-$1}"
|
||||||
echo "home = ${PYENV_ROOT}/versions/${2:-$1}/bin" > "${PYENV_ROOT}/versions/$1/pyvenv.cfg"
|
echo "home = ${PYENV_ROOT}/versions/${2:-$1}/bin" > "${PYENV_ROOT}/versions/$1/pyvenv.cfg"
|
||||||
touch "${PYENV_ROOT}/versions/$1/bin/activate"
|
touch "${PYENV_ROOT}/versions/$1/bin/activate"
|
||||||
}
|
}
|
||||||
|
|
||||||
remove_pyvenv() {
|
remove_m_venv() {
|
||||||
remove_version "${2:-$1}"
|
remove_version "${2:-$1}"
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -73,18 +73,18 @@ remove_conda() {
|
|||||||
@test "display prefix of virtualenv created by virtualenv" {
|
@test "display prefix of virtualenv created by virtualenv" {
|
||||||
stub pyenv-version-name "echo foo"
|
stub pyenv-version-name "echo foo"
|
||||||
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\""
|
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\""
|
||||||
create_virtualenv "foo" "2.7.6"
|
create_virtualenv "foo" "2.7.11"
|
||||||
|
|
||||||
PYENV_VERSION="foo" run pyenv-virtualenv-prefix
|
PYENV_VERSION="foo" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
${PYENV_ROOT}/versions/2.7.6
|
${PYENV_ROOT}/versions/2.7.11
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
remove_virtualenv "foo" "2.7.6"
|
remove_virtualenv "foo" "2.7.11"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "display prefix of virtualenv created by virtualenv (pypy)" {
|
@test "display prefix of virtualenv created by virtualenv (pypy)" {
|
||||||
@@ -125,57 +125,57 @@ OUT
|
|||||||
stub pyenv-version-name "echo foo:bar"
|
stub pyenv-version-name "echo foo:bar"
|
||||||
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\"" \
|
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\"" \
|
||||||
"bar : echo \"${PYENV_ROOT}/versions/bar\""
|
"bar : echo \"${PYENV_ROOT}/versions/bar\""
|
||||||
create_virtualenv "foo" "2.7.6"
|
create_virtualenv "foo" "2.7.11"
|
||||||
create_virtualenv "bar" "3.2.1"
|
create_virtualenv "bar" "3.5.1"
|
||||||
|
|
||||||
PYENV_VERSION="foo:bar" run pyenv-virtualenv-prefix
|
PYENV_VERSION="foo:bar" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
${PYENV_ROOT}/versions/2.7.6:${PYENV_ROOT}/versions/3.2.1
|
${PYENV_ROOT}/versions/2.7.11:${PYENV_ROOT}/versions/3.5.1
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
remove_virtualenv "foo" "2.7.6"
|
remove_virtualenv "foo" "2.7.11"
|
||||||
remove_virtualenv "bar" "3.2.1"
|
remove_virtualenv "bar" "3.5.1"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "display prefix of virtualenv created by pyvenv" {
|
@test "display prefix of virtualenv created by venv" {
|
||||||
stub pyenv-version-name "echo foo"
|
stub pyenv-version-name "echo foo"
|
||||||
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\""
|
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\""
|
||||||
create_pyvenv "foo" "3.3.3"
|
create_m_venv "foo" "3.3.6"
|
||||||
|
|
||||||
PYENV_VERSION="foo" run pyenv-virtualenv-prefix
|
PYENV_VERSION="foo" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
${PYENV_ROOT}/versions/3.3.3
|
${PYENV_ROOT}/versions/3.3.6
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
remove_pyvenv "foo" "3.3.3"
|
remove_m_venv "foo" "3.3.6"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "display prefixes of virtualenv created by pyvenv" {
|
@test "display prefixes of virtualenv created by venv" {
|
||||||
stub pyenv-version-name "echo foo:bar"
|
stub pyenv-version-name "echo foo:bar"
|
||||||
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\"" \
|
stub pyenv-prefix "foo : echo \"${PYENV_ROOT}/versions/foo\"" \
|
||||||
"bar : echo \"${PYENV_ROOT}/versions/bar\""
|
"bar : echo \"${PYENV_ROOT}/versions/bar\""
|
||||||
create_pyvenv "foo" "3.3.3"
|
create_m_venv "foo" "3.3.6"
|
||||||
create_pyvenv "bar" "3.4.0"
|
create_m_venv "bar" "3.4.4"
|
||||||
|
|
||||||
PYENV_VERSION="foo:bar" run pyenv-virtualenv-prefix
|
PYENV_VERSION="foo:bar" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
${PYENV_ROOT}/versions/3.3.3:${PYENV_ROOT}/versions/3.4.0
|
${PYENV_ROOT}/versions/3.3.6:${PYENV_ROOT}/versions/3.4.4
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
remove_pyvenv "foo" "3.3.3"
|
remove_m_venv "foo" "3.3.6"
|
||||||
remove_pyvenv "bar" "3.4.0"
|
remove_m_venv "bar" "3.4.4"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "display prefix of virtualenv created by conda" {
|
@test "display prefix of virtualenv created by conda" {
|
||||||
@@ -209,38 +209,38 @@ OUT
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "should fail if the version is not a virtualenv" {
|
@test "should fail if the version is not a virtualenv" {
|
||||||
stub pyenv-version-name "echo 3.4.0"
|
stub pyenv-version-name "echo 3.4.4"
|
||||||
stub pyenv-prefix "3.4.0 : echo \"${PYENV_ROOT}/versions/3.4.0\""
|
stub pyenv-prefix "3.4.4 : echo \"${PYENV_ROOT}/versions/3.4.4\""
|
||||||
create_version "3.4.0"
|
create_version "3.4.4"
|
||||||
|
|
||||||
PYENV_VERSION="3.4.0" run pyenv-virtualenv-prefix
|
PYENV_VERSION="3.4.4" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
assert_failure
|
assert_failure
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
pyenv-virtualenv: version \`3.4.0' is not a virtualenv
|
pyenv-virtualenv: version \`3.4.4' is not a virtualenv
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
remove_version "3.4.0"
|
remove_version "3.4.4"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "should fail if one of the versions is not a virtualenv" {
|
@test "should fail if one of the versions is not a virtualenv" {
|
||||||
stub pyenv-version-name "echo venv33:3.4.0"
|
stub pyenv-version-name "echo venv33:3.4.4"
|
||||||
stub pyenv-prefix "venv33 : echo \"${PYENV_ROOT}/versions/venv33\"" \
|
stub pyenv-prefix "venv33 : echo \"${PYENV_ROOT}/versions/venv33\"" \
|
||||||
"3.4.0 : echo \"${PYENV_ROOT}/versions/3.4.0\""
|
"3.4.4 : echo \"${PYENV_ROOT}/versions/3.4.4\""
|
||||||
create_virtualenv "venv33" "3.3.3"
|
create_virtualenv "venv33" "3.3.6"
|
||||||
create_version "3.4.0"
|
create_version "3.4.4"
|
||||||
|
|
||||||
PYENV_VERSION="venv33:3.4.0" run pyenv-virtualenv-prefix
|
PYENV_VERSION="venv33:3.4.4" run pyenv-virtualenv-prefix
|
||||||
|
|
||||||
assert_failure
|
assert_failure
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
pyenv-virtualenv: version \`3.4.0' is not a virtualenv
|
pyenv-virtualenv: version \`3.4.4' is not a virtualenv
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub pyenv-version-name
|
unstub pyenv-version-name
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
remove_virtualenv "venv33" "3.3.3"
|
remove_virtualenv "venv33" "3.3.6"
|
||||||
remove_version "3.4.0"
|
remove_version "3.4.4"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,6 +31,7 @@ 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 "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"
|
||||||
stub pyenv-which "python2.7 : echo ${PYENV_ROOT}/versions/2.7.8/bin/python2.7"
|
stub pyenv-which "python2.7 : echo ${PYENV_ROOT}/versions/2.7.8/bin/python2.7"
|
||||||
@@ -55,6 +56,7 @@ 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 "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"
|
||||||
stub pyenv-which "python2.7 : false"
|
stub pyenv-which "python2.7 : false"
|
||||||
|
|||||||
@@ -20,36 +20,38 @@ unstub_pyenv() {
|
|||||||
unstub pyenv-rehash
|
unstub pyenv-rehash
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "use pyvenv if virtualenv is not available" {
|
@test "use venv if virtualenv is not available" {
|
||||||
export PYENV_VERSION="3.4.1"
|
export PYENV_VERSION="3.5.1"
|
||||||
setup_pyvenv "3.4.1"
|
setup_m_venv "3.5.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 "pyvenv * : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
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"
|
stub pyenv-exec "python -s -m ensurepip : true"
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.4.1 pyvenv ${PYENV_ROOT}/versions/3.4.1/envs/venv
|
PYENV_VERSION=3.5.1 python -m venv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_pyvenv "3.4.1"
|
teardown_m_venv "3.5.1"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "not use pyvenv if virtualenv is available" {
|
@test "not use venv if virtualenv is available" {
|
||||||
export PYENV_VERSION="3.4.1"
|
export PYENV_VERSION="3.5.1"
|
||||||
setup_pyvenv "3.4.1"
|
setup_m_venv "3.5.1"
|
||||||
create_executable "3.4.1" "virtualenv"
|
create_executable "3.5.1" "virtualenv"
|
||||||
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 "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"
|
||||||
|
|
||||||
@@ -57,51 +59,48 @@ OUT
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.4.1 virtualenv ${PYENV_ROOT}/versions/3.4.1/envs/venv
|
PYENV_VERSION=3.5.1 virtualenv ${PYENV_ROOT}/versions/3.5.1/envs/venv
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_pyvenv "3.4.1"
|
teardown_m_venv "3.5.1"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "install virtualenv if pyvenv is not avaialble" {
|
@test "install virtualenv if venv is not avaialble" {
|
||||||
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 "pip install virtualenv : echo PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
stub pyenv-exec "python -m venv --help : false"
|
||||||
|
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 : false"
|
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
|
||||||
stub curl true
|
|
||||||
|
|
||||||
run pyenv-virtualenv venv
|
run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.2.1 pip install virtualenv
|
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
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
unstub curl
|
|
||||||
teardown_version "3.2.1"
|
teardown_version "3.2.1"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "install virtualenv if -p has given" {
|
@test "install virtualenv if -p has given" {
|
||||||
export PYENV_VERSION="3.4.1"
|
export PYENV_VERSION="3.5.1"
|
||||||
setup_pyvenv "3.4.1"
|
setup_m_venv "3.5.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 "python -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"
|
||||||
@@ -109,8 +108,8 @@ OUT
|
|||||||
run pyenv-virtualenv -p ${TMP}/python3 venv
|
run pyenv-virtualenv -p ${TMP}/python3 venv
|
||||||
|
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.4.1 pip install virtualenv
|
PYENV_VERSION=3.5.1 pip install virtualenv
|
||||||
PYENV_VERSION=3.4.1 virtualenv --python=${TMP}/python3 ${PYENV_ROOT}/versions/3.4.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_success
|
assert_success
|
||||||
@@ -118,15 +117,16 @@ OUT
|
|||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_pyvenv "3.4.1"
|
teardown_m_venv "3.5.1"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "install virtualenv if --python has given" {
|
@test "install virtualenv if --python has given" {
|
||||||
export PYENV_VERSION="3.4.1"
|
export PYENV_VERSION="3.5.1"
|
||||||
setup_pyvenv "3.4.1"
|
setup_m_venv "3.5.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 "python -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"
|
||||||
@@ -134,8 +134,8 @@ OUT
|
|||||||
run pyenv-virtualenv --python=${TMP}/python3 venv
|
run pyenv-virtualenv --python=${TMP}/python3 venv
|
||||||
|
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.4.1 pip install virtualenv
|
PYENV_VERSION=3.5.1 pip install virtualenv
|
||||||
PYENV_VERSION=3.4.1 virtualenv --python=${TMP}/python3 ${PYENV_ROOT}/versions/3.4.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_success
|
assert_success
|
||||||
@@ -143,7 +143,7 @@ OUT
|
|||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
teardown_pyvenv "3.4.1"
|
teardown_m_venv "3.5.1"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "install virtualenv with unsetting troublesome pip options" {
|
@test "install virtualenv with unsetting troublesome pip options" {
|
||||||
@@ -152,25 +152,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 "pip install virtualenv : 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} \"\$@\""
|
stub pyenv-exec "virtualenv * : echo PIP_REQUIRE_VENV=\${PIP_REQUIRE_VENV} PYENV_VERSION=\${PYENV_VERSION} \"\$@\""
|
||||||
stub pyenv-exec "python -s -m ensurepip : false"
|
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
|
||||||
stub curl true
|
|
||||||
|
|
||||||
PIP_REQUIRE_VENV="true" run pyenv-virtualenv venv
|
PIP_REQUIRE_VENV="true" run pyenv-virtualenv venv
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PIP_REQUIRE_VENV= PYENV_VERSION=3.2.1 pip install virtualenv
|
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
|
||||||
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
|
|
||||||
unstub_pyenv
|
unstub_pyenv
|
||||||
unstub pyenv-virtualenv-prefix
|
unstub pyenv-virtualenv-prefix
|
||||||
unstub pyenv-exec
|
unstub pyenv-exec
|
||||||
unstub curl
|
|
||||||
teardown_version "3.2.1"
|
teardown_version "3.2.1"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -120,7 +120,6 @@ remove_executable() {
|
|||||||
setup_version() {
|
setup_version() {
|
||||||
create_executable "$1" "python"
|
create_executable "$1" "python"
|
||||||
remove_executable "$1" "activate"
|
remove_executable "$1" "activate"
|
||||||
remove_executable "$1" "pyvenv"
|
|
||||||
remove_executable "$1" "conda"
|
remove_executable "$1" "conda"
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -131,7 +130,6 @@ teardown_version() {
|
|||||||
setup_virtualenv() {
|
setup_virtualenv() {
|
||||||
create_executable "$1" "python"
|
create_executable "$1" "python"
|
||||||
create_executable "$1" "activate"
|
create_executable "$1" "activate"
|
||||||
remove_executable "$1" "pyvenv"
|
|
||||||
remove_executable "$1" "conda"
|
remove_executable "$1" "conda"
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -139,21 +137,19 @@ teardown_virtualenv() {
|
|||||||
rm -fr "${PYENV_ROOT}/versions/$1"
|
rm -fr "${PYENV_ROOT}/versions/$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
setup_pyvenv() {
|
setup_m_venv() {
|
||||||
create_executable "$1" "python"
|
create_executable "$1" "python"
|
||||||
create_executable "$1" "activate"
|
create_executable "$1" "activate"
|
||||||
create_executable "$1" "pyvenv"
|
|
||||||
remove_executable "$1" "conda"
|
remove_executable "$1" "conda"
|
||||||
}
|
}
|
||||||
|
|
||||||
teardown_pyvenv() {
|
teardown_m_venv() {
|
||||||
rm -fr "${PYENV_ROOT}/versions/$1"
|
rm -fr "${PYENV_ROOT}/versions/$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
setup_conda() {
|
setup_conda() {
|
||||||
create_executable "$1" "python"
|
create_executable "$1" "python"
|
||||||
create_executable "$1" "activate"
|
create_executable "$1" "activate"
|
||||||
remove_executable "$1" "pyvenv"
|
|
||||||
create_executable "$1" "conda"
|
create_executable "$1" "conda"
|
||||||
local conda="$1"
|
local conda="$1"
|
||||||
shift 1
|
shift 1
|
||||||
@@ -161,10 +157,12 @@ setup_conda() {
|
|||||||
for env; do
|
for env; do
|
||||||
create_executable "${conda}/envs/${env}" "python"
|
create_executable "${conda}/envs/${env}" "python"
|
||||||
create_executable "${conda}/envs/${env}" "activate"
|
create_executable "${conda}/envs/${env}" "activate"
|
||||||
remove_executable "${conda}/envs/${env}" "pyvenv"
|
|
||||||
create_executable "${conda}/envs/${env}" "conda"
|
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
|
done
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
teardown_conda() {
|
teardown_conda() {
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ 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-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
|
||||||
@@ -21,16 +22,16 @@ setup() {
|
|||||||
teardown_virtualenv "2.7.7"
|
teardown_virtualenv "2.7.7"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "display pyvenv version" {
|
@test "display venv version" {
|
||||||
setup_pyvenv "3.4.1"
|
setup_m_venv "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-which "pyvenv : echo \"${PYENV_ROOT}/versions/3.4.1/bin/pyvenv\""
|
stub pyenv-exec "python -m venv --help : true"
|
||||||
|
|
||||||
run pyenv-virtualenv --version
|
run pyenv-virtualenv --version
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
[[ "$output" == "pyenv-virtualenv 20"*" (pyvenv 3.4.1)" ]]
|
[[ "$output" == "pyenv-virtualenv 20"*" (python -m venv)" ]]
|
||||||
|
|
||||||
unstub pyenv-prefix
|
unstub pyenv-prefix
|
||||||
teardown_pyvenv "3.4.1"
|
teardown_m_venv "3.4.1"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,19 +23,20 @@ unstub_pyenv() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "create virtualenv from given version" {
|
@test "create virtualenv from given version" {
|
||||||
export PYENV_VERSION="3.2.1"
|
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 "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"
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
stub pyenv-exec "python -s */get-pip.py : true"
|
||||||
stub curl true
|
stub curl true
|
||||||
|
|
||||||
run pyenv-virtualenv "3.2.1" "venv"
|
run pyenv-virtualenv "2.7.11" "venv"
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/3.2.1/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
|
||||||
@@ -47,10 +48,11 @@ OUT
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "create virtualenv from current version" {
|
@test "create virtualenv from current version" {
|
||||||
export PYENV_VERSION="3.2.1"
|
export PYENV_VERSION="2.7.11"
|
||||||
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 "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"
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
stub pyenv-exec "python -s */get-pip.py : true"
|
||||||
@@ -60,7 +62,7 @@ OUT
|
|||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/3.2.1/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
|
||||||
@@ -73,10 +75,11 @@ OUT
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "create virtualenv with short options" {
|
@test "create virtualenv with short options" {
|
||||||
export PYENV_VERSION="3.2.1"
|
export PYENV_VERSION="2.7.11"
|
||||||
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 "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"
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
stub pyenv-exec "python -s */get-pip.py : true"
|
||||||
@@ -85,7 +88,7 @@ OUT
|
|||||||
run pyenv-virtualenv -v -p ${TMP}/python venv
|
run pyenv-virtualenv -v -p ${TMP}/python venv
|
||||||
|
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.2.1 virtualenv --verbose --python=${TMP}/python ${PYENV_ROOT}/versions/3.2.1/envs/venv
|
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...
|
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
@@ -99,10 +102,11 @@ OUT
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "create virtualenv with long options" {
|
@test "create virtualenv with long options" {
|
||||||
export PYENV_VERSION="3.2.1"
|
export PYENV_VERSION="2.7.11"
|
||||||
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 "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"
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
stub pyenv-exec "python -s */get-pip.py : true"
|
||||||
@@ -111,7 +115,7 @@ OUT
|
|||||||
run pyenv-virtualenv --verbose --python=${TMP}/python venv
|
run pyenv-virtualenv --verbose --python=${TMP}/python venv
|
||||||
|
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.2.1 virtualenv --verbose --python=${TMP}/python ${PYENV_ROOT}/versions/3.2.1/envs/venv
|
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...
|
Installing pip from https://bootstrap.pypa.io/get-pip.py...
|
||||||
rehashed
|
rehashed
|
||||||
OUT
|
OUT
|
||||||
@@ -125,7 +129,7 @@ OUT
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "no whitespace allowed in virtualenv name" {
|
@test "no whitespace allowed in virtualenv name" {
|
||||||
run pyenv-virtualenv "3.2.1" "foo bar"
|
run pyenv-virtualenv "2.7.11" "foo bar"
|
||||||
|
|
||||||
assert_failure
|
assert_failure
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
@@ -134,7 +138,7 @@ OUT
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "no tab allowed in virtualenv name" {
|
@test "no tab allowed in virtualenv name" {
|
||||||
run pyenv-virtualenv "3.2.1" "foo bar baz"
|
run pyenv-virtualenv "2.7.11" "foo bar baz"
|
||||||
|
|
||||||
assert_failure
|
assert_failure
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
@@ -143,7 +147,7 @@ OUT
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "system not allowed as virtualenv name" {
|
@test "system not allowed as virtualenv name" {
|
||||||
run pyenv-virtualenv "3.2.1" "system"
|
run pyenv-virtualenv "2.7.11" "system"
|
||||||
|
|
||||||
assert_failure
|
assert_failure
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
@@ -152,7 +156,7 @@ OUT
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "no slash allowed in virtualenv name" {
|
@test "no slash allowed in virtualenv name" {
|
||||||
run pyenv-virtualenv "3.2.1" "foo/bar"
|
run pyenv-virtualenv "2.7.11" "foo/bar"
|
||||||
|
|
||||||
assert_failure
|
assert_failure
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
@@ -161,19 +165,20 @@ OUT
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "slash allowed if it is the long name of the virtualenv" {
|
@test "slash allowed if it is the long name of the virtualenv" {
|
||||||
export PYENV_VERSION="3.2.1"
|
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 "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"
|
||||||
stub pyenv-exec "python -s */get-pip.py : true"
|
stub pyenv-exec "python -s */get-pip.py : true"
|
||||||
stub curl true
|
stub curl true
|
||||||
|
|
||||||
run pyenv-virtualenv "3.2.1" "3.2.1/envs/foo"
|
run pyenv-virtualenv "2.7.11" "2.7.11/envs/foo"
|
||||||
|
|
||||||
assert_success
|
assert_success
|
||||||
assert_output <<OUT
|
assert_output <<OUT
|
||||||
PYENV_VERSION=3.2.1 virtualenv ${PYENV_ROOT}/versions/3.2.1/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
|
||||||
|
|||||||
Reference in New Issue
Block a user