feat: add support for isolated environment testing
In order to properly test the rehashing after `pip install` and `python -m pip install`, we need to add support for creating an isolated environment.
This commit is contained in:
parent
b154f3a7d8
commit
9e2f5082ae
@ -18,21 +18,47 @@ if [ -z "$PYENV_TEST_DIR" ]; then
|
|||||||
export PYENV_ROOT="${PYENV_TEST_DIR}/root"
|
export PYENV_ROOT="${PYENV_TEST_DIR}/root"
|
||||||
export HOME="${PYENV_TEST_DIR}/home"
|
export HOME="${PYENV_TEST_DIR}/home"
|
||||||
export PYENV_HOOK_PATH="${PYENV_ROOT}/pyenv.d"
|
export PYENV_HOOK_PATH="${PYENV_ROOT}/pyenv.d"
|
||||||
|
PYENV_LIBEXEC="${BATS_TEST_DIRNAME%/*}/libexec"
|
||||||
|
|
||||||
|
if [ -n "$ISOLATED_ENVIRONMENT" ]; then
|
||||||
|
mkdir -p "$PYENV_ROOT" "$HOME" "$PYENV_HOOK_PATH" \
|
||||||
|
"$PYENV_TEST_DIR"/bin "$PYENV_TEST_DIR"/plugins/python-build
|
||||||
|
|
||||||
|
cp -r "$PYENV_LIBEXEC" "$PYENV_TEST_DIR"
|
||||||
|
cp -r "${BATS_TEST_DIRNAME%/*}/plugins/python-build" "$PYENV_TEST_DIR"/plugins/
|
||||||
|
ln -s "$PYENV_TEST_DIR/libexec/pyenv" "$PYENV_TEST_DIR/bin/pyenv"
|
||||||
|
# cp -rL "${BATS_TEST_DIRNAME%/*}/bin" "$PYENV_TEST_DIR"
|
||||||
|
cp -r "${BATS_TEST_DIRNAME%/*}/completions" "$PYENV_TEST_DIR"
|
||||||
|
cp -r "${BATS_TEST_DIRNAME%/*}/pyenv.d" "$PYENV_TEST_DIR"
|
||||||
|
PATH="${PYENV_TEST_DIR}/bin:/usr/bin"
|
||||||
|
export PATH
|
||||||
|
|
||||||
|
else
|
||||||
PATH=/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin
|
PATH=/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin
|
||||||
PATH="${PYENV_TEST_DIR}/bin:$PATH"
|
PATH="${PYENV_TEST_DIR}/bin:$PATH"
|
||||||
PATH="${BATS_TEST_DIRNAME%/*}/libexec:$PATH"
|
PATH="$PYENV_LIBEXEC:$PATH"
|
||||||
PATH="${BATS_TEST_DIRNAME}/libexec:$PATH"
|
PATH="${BATS_TEST_DIRNAME}/libexec:$PATH"
|
||||||
PATH="${PYENV_ROOT}/shims:$PATH"
|
PATH="${PYENV_ROOT}/shims:$PATH"
|
||||||
export PATH
|
export PATH
|
||||||
|
fi
|
||||||
|
|
||||||
for xdg_var in `env 2>/dev/null | grep ^XDG_ | cut -d= -f1`; do unset "$xdg_var"; done
|
for xdg_var in `env 2>/dev/null | grep ^XDG_ | cut -d= -f1`; do unset "$xdg_var"; done
|
||||||
unset xdg_var
|
unset xdg_var
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# We don't want to remove the test directory between
|
||||||
|
# tests if we are running in an isolated environment.
|
||||||
|
# We want to set up the isolated environment once and
|
||||||
|
# delete it at after all tests are run.
|
||||||
|
if [ -n "$ISOLATED_ENVIRONMENT" ]; then
|
||||||
|
teardown_file() {
|
||||||
|
rm -rf "$PYENV_TEST_DIR"
|
||||||
|
}
|
||||||
|
else
|
||||||
teardown() {
|
teardown() {
|
||||||
rm -rf "$PYENV_TEST_DIR"
|
rm -rf "$PYENV_TEST_DIR"
|
||||||
}
|
}
|
||||||
|
fi
|
||||||
|
|
||||||
flunk() {
|
flunk() {
|
||||||
{ if [ "$#" -eq 0 ]; then cat -
|
{ if [ "$#" -eq 0 ]; then cat -
|
||||||
|
Loading…
x
Reference in New Issue
Block a user