mirror of
https://github.com/pyenv/pyenv.git
synced 2024-12-04 13:41:47 -05:00
47b0ce77c0
* Fixes #2430 while still preventing CVE-2022-35861 * Adds a skipped version message to stderr Co-authored-by: Ivan Pozdeev <vano@mail.mipt.ru>
118 lines
2.4 KiB
Bash
118 lines
2.4 KiB
Bash
#!/usr/bin/env bats
|
|
|
|
load test_helper
|
|
|
|
setup() {
|
|
mkdir -p "${PYENV_TEST_DIR}/myproject"
|
|
cd "${PYENV_TEST_DIR}/myproject"
|
|
}
|
|
|
|
@test "fails without arguments" {
|
|
run pyenv-version-file-read
|
|
assert_failure ""
|
|
}
|
|
|
|
@test "fails for invalid file" {
|
|
run pyenv-version-file-read "non-existent"
|
|
assert_failure ""
|
|
}
|
|
|
|
@test "fails for blank file" {
|
|
echo > my-version
|
|
run pyenv-version-file-read my-version
|
|
assert_failure ""
|
|
}
|
|
|
|
@test "reads simple version file" {
|
|
cat > my-version <<<"3.3.5"
|
|
run pyenv-version-file-read my-version
|
|
assert_success "3.3.5"
|
|
}
|
|
|
|
@test "ignores leading spaces" {
|
|
cat > my-version <<<" 3.3.5"
|
|
run pyenv-version-file-read my-version
|
|
assert_success "3.3.5"
|
|
}
|
|
|
|
@test "reads only the first word from file" {
|
|
cat > my-version <<<"3.3.5 2.7.6 hi"
|
|
run pyenv-version-file-read my-version
|
|
assert_success "3.3.5"
|
|
}
|
|
|
|
@test "loads *not* only the first line in file" {
|
|
cat > my-version <<IN
|
|
2.7.6 one
|
|
3.3.5 two
|
|
IN
|
|
run pyenv-version-file-read my-version
|
|
assert_success "2.7.6:3.3.5"
|
|
}
|
|
|
|
@test "ignores leading blank lines" {
|
|
cat > my-version <<IN
|
|
|
|
3.3.5
|
|
IN
|
|
run pyenv-version-file-read my-version
|
|
assert_success "3.3.5"
|
|
}
|
|
|
|
@test "handles the file with no trailing newline" {
|
|
echo -n "2.7.6" > my-version
|
|
run pyenv-version-file-read my-version
|
|
assert_success "2.7.6"
|
|
}
|
|
|
|
@test "ignores carriage returns" {
|
|
cat > my-version <<< $'3.3.5\r'
|
|
run pyenv-version-file-read my-version
|
|
assert_success "3.3.5"
|
|
}
|
|
|
|
@test "skips comment lines" {
|
|
cat > my-version <<IN
|
|
3.9.3
|
|
3.8.9
|
|
# 3.4.0
|
|
#3.3.7
|
|
2.7.16
|
|
IN
|
|
run pyenv-version-file-read my-version
|
|
assert_success "3.9.3:3.8.9:2.7.16"
|
|
}
|
|
|
|
@test "skips \`..' relative path traversal" {
|
|
echo '..' > my-version
|
|
run pyenv-version-file-read my-version
|
|
assert_failure "pyenv: invalid version \`..' ignored in \`my-version'"
|
|
}
|
|
|
|
@test "skips glob path traversal" {
|
|
cat > my-version <<IN
|
|
../*
|
|
3.9.3
|
|
IN
|
|
run pyenv-version-file-read my-version
|
|
assert_success <<OUT
|
|
pyenv: invalid version \`../\*' ignored in \`my-version'
|
|
3.9.3
|
|
OUT
|
|
}
|
|
|
|
@test "allows relative paths that exist and stay within versions" {
|
|
venv=3.10.3/envs/../test
|
|
mkdir -p "${PYENV_ROOT}/versions/${venv}"
|
|
echo -n "${venv}" > my-version
|
|
run pyenv-version-file-read my-version
|
|
assert_success "${venv}"
|
|
}
|
|
|
|
@test "skips relative paths that lead outside of versions" {
|
|
venv=../3.10.3/envs/test
|
|
mkdir -p "${PYENV_ROOT}/versions/${venv}"
|
|
echo -n "${venv}" > my-version
|
|
run pyenv-version-file-read my-version
|
|
assert_failure
|
|
}
|