Add pyenv versions' option to skip envs for pyenv-latest'

This commit is contained in:
Ivan Pozdeev 2023-02-02 17:41:53 +03:00
parent 9248255f70
commit 9fe80f28e5
2 changed files with 36 additions and 13 deletions

View file

@ -1,23 +1,24 @@
#!/usr/bin/env bash #!/usr/bin/env bash
# Summary: List all Python versions available to pyenv # Summary: List all Python versions available to pyenv
# Usage: pyenv versions [--bare] [--skip-aliases] # Usage: pyenv versions [--bare] [--skip-aliases] [--skip-envs]
# #
# Lists all Python versions found in `$PYENV_ROOT/versions/*'. # Lists all Python versions found in `$PYENV_ROOT/versions/*'.
set -e set -e
[ -n "$PYENV_DEBUG" ] && set -x [ -n "$PYENV_DEBUG" ] && set -x
unset bare unset bare skip_aliases skip_envs
unset skip_aliases
# Provide pyenv completions # Provide pyenv completions
for arg; do for arg; do
case "$arg" in case "$arg" in
--complete ) --complete )
echo --bare echo --bare
echo --skip-aliases echo --skip-aliases
echo --skip-envs
exit ;; exit ;;
--bare ) bare=1 ;; --bare ) bare=1 ;;
--skip-aliases ) skip_aliases=1 ;; --skip-aliases ) skip_aliases=1 ;;
--skip-envs ) skip_envs=1 ;;
* ) * )
pyenv-help --usage versions >&2 pyenv-help --usage versions >&2
exit 1 exit 1
@ -109,7 +110,7 @@ print_version() {
if [[ -z "$bare" && -L "$path" ]]; then if [[ -z "$bare" && -L "$path" ]]; then
# Only resolve the link itself for printing, do not resolve further. # Only resolve the link itself for printing, do not resolve further.
# Doing otherwise would misinform the user of what the link contains. # Doing otherwise would misinform the user of what the link contains.
version_repr="$version --> $(resolve_link "$version")" version_repr="$version --> $(resolve_link "$path")"
else else
version_repr="$version" version_repr="$version"
fi fi
@ -152,12 +153,14 @@ for path in "${versions_dir_entries[@]}"; do
[ "${target%/*/envs/*}" == "$versions_dir" ] && continue [ "${target%/*/envs/*}" == "$versions_dir" ] && continue
fi fi
print_version "${path##*/}" "$path" print_version "${path##*/}" "$path"
# virtual environments created by anaconda/miniconda # virtual environments created by anaconda/miniconda/pyenv-virtualenv
for env_path in "${path}/envs/"*; do if [[ -z $skip_envs ]]; then
if [ -d "${env_path}" ]; then for env_path in "${path}/envs/"*; do
print_version "${env_path#${PYENV_ROOT}/versions/}" "${env_path}" if [ -d "${env_path}" ]; then
fi print_version "${env_path#${PYENV_ROOT}/versions/}" "${env_path}"
done fi
done
fi
fi fi
done done
shopt -u dotglob nullglob shopt -u dotglob nullglob

View file

@ -66,18 +66,38 @@ OUT
assert_success "3.3" assert_success "3.3"
} }
@test "multiple versions" { @test "multiple versions and envs" {
stub_system_python stub_system_python
create_version "2.7.6" create_version "2.7.6"
create_version "3.3.3"
create_version "3.4.0" create_version "3.4.0"
create_version "3.4.0/envs/foo"
create_version "3.4.0/envs/bar"
create_version "3.5.2"
run pyenv-versions run pyenv-versions
assert_success assert_success
assert_output <<OUT assert_output <<OUT
* system (set by ${PYENV_ROOT}/version) * system (set by ${PYENV_ROOT}/version)
2.7.6 2.7.6
3.4.0
3.4.0/envs/bar
3.4.0/envs/foo
3.5.2
OUT
}
@test "skips envs with --skip-envs" {
create_version "3.3.3"
create_version "3.4.0"
create_version "3.4.0/envs/foo"
create_version "3.4.0/envs/bar"
create_version "3.5.0"
run pyenv-versions --skip-envs
assert_success <<OUT
* system (set by ${PYENV_ROOT}/version)
3.3.3 3.3.3
3.4.0 3.4.0
3.5.0
OUT OUT
} }
@ -216,7 +236,7 @@ SH
OUT OUT
} }
@test "non-bare output resolves links" { @test "non-bare output shows symlink contents" {
create_version "1.9.0" create_version "1.9.0"
create_alias "link" "foo/bar" create_alias "link" "foo/bar"