mirror of
https://github.com/pyenv/pyenv.git
synced 2024-11-07 20:31:01 -05:00
Revert "rbenv exec: avoid mutating PATH"
It was supposed to fix shelling out to Ruby but it in fact broke another
kind of shelling out to Ruby: invoking the `ruby` binary directly with
the `-S` flag.
Fixes #480
This reverts commit db143bb654
.
This commit is contained in:
parent
f1fdb9bbc8
commit
95a039aaaa
3 changed files with 37 additions and 275 deletions
|
@ -2,59 +2,24 @@
|
||||||
#
|
#
|
||||||
# Summary: Run an executable with the selected Ruby version
|
# Summary: Run an executable with the selected Ruby version
|
||||||
#
|
#
|
||||||
# Usage: rbenv exec <command> [args...]
|
# Usage: rbenv exec <command> [arg1 arg2...]
|
||||||
#
|
#
|
||||||
# Runs an executable contained by the currently selected Ruby's bin
|
# Runs an executable by first preparing PATH so that the selected Ruby
|
||||||
# directory. Rough equivalent of:
|
# version's `bin' directory is at the front.
|
||||||
#
|
#
|
||||||
# exec "$(rbenv prefix)/bin/$command" args...
|
# For example, if the currently selected Ruby version is 1.9.3-p327:
|
||||||
|
# rbenv exec bundle install
|
||||||
|
#
|
||||||
|
# is equivalent to:
|
||||||
|
# PATH="$RBENV_ROOT/versions/1.9.3-p327/bin:$PATH" bundle install
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
[ -n "$RBENV_DEBUG" ] && set -x
|
[ -n "$RBENV_DEBUG" ] && set -x
|
||||||
|
|
||||||
rubypath=""
|
|
||||||
# Provide rbenv completions
|
# Provide rbenv completions
|
||||||
while true; do
|
if [ "$1" = "--complete" ]; then
|
||||||
case "$1" in
|
|
||||||
"--complete" )
|
|
||||||
exec rbenv shims --short
|
exec rbenv shims --short
|
||||||
;;
|
|
||||||
"--rubypath" )
|
|
||||||
rubypath=1
|
|
||||||
shift 1
|
|
||||||
;;
|
|
||||||
* )
|
|
||||||
break
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
# Replace any "RBENV_ROOT/shims" or "RBENV_ROOT/versions/*/bin" paths in the
|
|
||||||
# list with the given path. If no replacements were made, prepend the path onto
|
|
||||||
# the list.
|
|
||||||
replace_shims_path() {
|
|
||||||
local path="$1"
|
|
||||||
local dir="$2"
|
|
||||||
# fake directory that serves as a placeholder for shims location in RUBYPATH:
|
|
||||||
local placeholder="/rbenv_shims_were_here"
|
|
||||||
local found=""
|
|
||||||
local result=""
|
|
||||||
local -a paths
|
|
||||||
IFS=: paths=($path)
|
|
||||||
|
|
||||||
for path in "${paths[@]}"; do
|
|
||||||
if [[ $path = "${RBENV_ROOT}/shims" || $path == "${RBENV_ROOT}/versions/"*/bin || $path = $placeholder ]]; then
|
|
||||||
found=1
|
|
||||||
result="${result}${dir:-$placeholder}:"
|
|
||||||
else
|
|
||||||
result="${result}${path}:"
|
|
||||||
fi
|
fi
|
||||||
done
|
|
||||||
|
|
||||||
# if no rbenv paths were replaced, simply prepend the path
|
|
||||||
[ -n "$found" -o -z "$dir" ] || result="${dir}:${path}"
|
|
||||||
echo "${result%:}"
|
|
||||||
}
|
|
||||||
|
|
||||||
RBENV_VERSION="$(rbenv-version-name)"
|
RBENV_VERSION="$(rbenv-version-name)"
|
||||||
RBENV_COMMAND="$1"
|
RBENV_COMMAND="$1"
|
||||||
|
@ -66,6 +31,7 @@ fi
|
||||||
|
|
||||||
export RBENV_VERSION
|
export RBENV_VERSION
|
||||||
RBENV_COMMAND_PATH="$(rbenv-which "$RBENV_COMMAND")"
|
RBENV_COMMAND_PATH="$(rbenv-which "$RBENV_COMMAND")"
|
||||||
|
RBENV_BIN_PATH="${RBENV_COMMAND_PATH%/*}"
|
||||||
|
|
||||||
OLDIFS="$IFS"
|
OLDIFS="$IFS"
|
||||||
IFS=$'\n' scripts=(`rbenv-hooks exec`)
|
IFS=$'\n' scripts=(`rbenv-hooks exec`)
|
||||||
|
@ -75,9 +41,7 @@ for script in "${scripts[@]}"; do
|
||||||
done
|
done
|
||||||
|
|
||||||
shift 1
|
shift 1
|
||||||
if [ -n "$rubypath" ]; then
|
if [ "$RBENV_VERSION" != "system" ]; then
|
||||||
bindir=""
|
export PATH="${RBENV_BIN_PATH}:${PATH}"
|
||||||
[ "$RBENV_VERSION" != "system" ] && bindir="${RBENV_COMMAND_PATH%/*}"
|
|
||||||
export RUBYPATH="$(replace_shims_path "${RUBYPATH:-$PATH}" "$bindir")"
|
|
||||||
fi
|
fi
|
||||||
exec -a "$RBENV_COMMAND" "$RBENV_COMMAND_PATH" "$@"
|
exec -a "$RBENV_COMMAND" "$RBENV_COMMAND_PATH" "$@"
|
||||||
|
|
|
@ -45,12 +45,10 @@ create_prototype_shim() {
|
||||||
set -e
|
set -e
|
||||||
[ -n "\$RBENV_DEBUG" ] && set -x
|
[ -n "\$RBENV_DEBUG" ] && set -x
|
||||||
|
|
||||||
opt=""
|
|
||||||
program="\${0##*/}"
|
program="\${0##*/}"
|
||||||
if [ "\$program" = "ruby" ]; then
|
if [ "\$program" = "ruby" ]; then
|
||||||
for arg; do
|
for arg; do
|
||||||
case "\$arg" in
|
case "\$arg" in
|
||||||
-S* ) opt=--rubypath ;;
|
|
||||||
-e* | -- ) break ;;
|
-e* | -- ) break ;;
|
||||||
*/* )
|
*/* )
|
||||||
if [ -f "\$arg" ]; then
|
if [ -f "\$arg" ]; then
|
||||||
|
@ -63,7 +61,7 @@ if [ "\$program" = "ruby" ]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export RBENV_ROOT="$RBENV_ROOT"
|
export RBENV_ROOT="$RBENV_ROOT"
|
||||||
exec "$(command -v rbenv)" exec \$opt "\$program" "\$@"
|
exec "$(command -v rbenv)" exec "\$program" "\$@"
|
||||||
SH
|
SH
|
||||||
chmod +x "$PROTOTYPE_SHIM_PATH"
|
chmod +x "$PROTOTYPE_SHIM_PATH"
|
||||||
}
|
}
|
||||||
|
|
244
test/exec.bats
244
test/exec.bats
|
@ -3,37 +3,15 @@
|
||||||
load test_helper
|
load test_helper
|
||||||
|
|
||||||
create_executable() {
|
create_executable() {
|
||||||
local file="${1?}"
|
name="${1?}"
|
||||||
[[ $file == */* ]] || file="${RBENV_ROOT}/versions/${RBENV_VERSION}/bin/$file"
|
|
||||||
shift 1
|
shift 1
|
||||||
mkdir -p "${file%/*}"
|
bin="${RBENV_ROOT}/versions/${RBENV_VERSION}/bin"
|
||||||
|
mkdir -p "$bin"
|
||||||
{ if [ $# -eq 0 ]; then cat -
|
{ if [ $# -eq 0 ]; then cat -
|
||||||
else echo "$@"
|
else echo "$@"
|
||||||
fi
|
fi
|
||||||
} | sed -Ee '1s/^[[:space:]]+//' > "$file"
|
} | sed -Ee '1s/^ +//' > "${bin}/$name"
|
||||||
chmod +x "$file"
|
chmod +x "${bin}/$name"
|
||||||
}
|
|
||||||
|
|
||||||
# Fake ruby executable that emulates `ruby -S <cmd>' behavior by running the
|
|
||||||
# first `cmd' found in RUBYPATH/PATH as bash script.
|
|
||||||
create_ruby_executable() {
|
|
||||||
create_executable "${1:-ruby}" <<SH
|
|
||||||
#!$BASH
|
|
||||||
if [[ \$1 == "-S"* ]]; then
|
|
||||||
cmd="\${1#-S}"
|
|
||||||
[ -n "\$cmd" ] || cmd="\$2"
|
|
||||||
found="\$(PATH="\${RUBYPATH:-\$PATH}" \$(command -v which) \$cmd)"
|
|
||||||
# assert that the found executable has ruby for shebang
|
|
||||||
if head -1 "\$found" | grep ruby >/dev/null; then
|
|
||||||
\$BASH "\$found"
|
|
||||||
else
|
|
||||||
echo "ruby: no Ruby script found in input (LoadError)" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo 'ruby (rbenv test)'
|
|
||||||
fi
|
|
||||||
SH
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "fails with invalid version" {
|
@test "fails with invalid version" {
|
||||||
|
@ -104,56 +82,26 @@ ${RBENV_ROOT}/versions/2.0/bin/ruby
|
||||||
OUT
|
OUT
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "doesn't mutate PATH" {
|
|
||||||
export RBENV_VERSION="2.0"
|
|
||||||
create_executable "ruby" <<SH
|
|
||||||
#!$BASH
|
|
||||||
echo \$PATH
|
|
||||||
SH
|
|
||||||
|
|
||||||
run rbenv-exec ruby
|
|
||||||
assert_success "$PATH"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "doesn't set RUBYPATH" {
|
|
||||||
export RBENV_VERSION="2.0"
|
|
||||||
create_executable "ruby" <<SH
|
|
||||||
#!$BASH
|
|
||||||
echo \$RUBYPATH
|
|
||||||
SH
|
|
||||||
|
|
||||||
RUBYPATH="" run rbenv-exec ruby
|
|
||||||
assert_success
|
|
||||||
assert_output ""
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "allows subprocesses to select a different RBENV_VERSION" {
|
|
||||||
RBENV_VERSION=1.8 create_executable "rake" <<SH
|
|
||||||
#!$BASH
|
|
||||||
echo rake 1.8
|
|
||||||
SH
|
|
||||||
|
|
||||||
export RBENV_VERSION="2.0"
|
|
||||||
create_executable "rake" "#!/bin/sh"
|
|
||||||
create_executable "ruby" <<SH
|
|
||||||
#!$BASH
|
|
||||||
echo ruby 2.0
|
|
||||||
RBENV_VERSION=1.8 exec rake
|
|
||||||
SH
|
|
||||||
|
|
||||||
rbenv rehash
|
|
||||||
run ruby
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
ruby 2.0
|
|
||||||
rake 1.8
|
|
||||||
OUT
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "supports ruby -S <cmd>" {
|
@test "supports ruby -S <cmd>" {
|
||||||
export RBENV_VERSION="2.0"
|
export RBENV_VERSION="2.0"
|
||||||
|
|
||||||
create_ruby_executable
|
# emulate `ruby -S' behavior
|
||||||
|
create_executable "ruby" <<SH
|
||||||
|
#!$BASH
|
||||||
|
if [[ \$1 == "-S"* ]]; then
|
||||||
|
found="\$(PATH="\${RUBYPATH:-\$PATH}" which \$2)"
|
||||||
|
# assert that the found executable has ruby for shebang
|
||||||
|
if head -1 "\$found" | grep ruby >/dev/null; then
|
||||||
|
\$BASH "\$found"
|
||||||
|
else
|
||||||
|
echo "ruby: no Ruby script found in input (LoadError)" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo 'ruby 2.0 (rbenv test)'
|
||||||
|
fi
|
||||||
|
SH
|
||||||
|
|
||||||
create_executable "rake" <<SH
|
create_executable "rake" <<SH
|
||||||
#!/usr/bin/env ruby
|
#!/usr/bin/env ruby
|
||||||
echo hello rake
|
echo hello rake
|
||||||
|
@ -163,151 +111,3 @@ SH
|
||||||
run ruby -S rake
|
run ruby -S rake
|
||||||
assert_success "hello rake"
|
assert_success "hello rake"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "supports ruby -S with system version" {
|
|
||||||
export RBENV_VERSION=2.0
|
|
||||||
create_executable "ruby" "#!/bin/sh"
|
|
||||||
create_executable "rake" "#!/bin/sh"
|
|
||||||
rbenv-rehash
|
|
||||||
|
|
||||||
create_ruby_executable "${RBENV_TEST_DIR}/bin/ruby"
|
|
||||||
create_executable "${RBENV_TEST_DIR}/bin/rake" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo system rake
|
|
||||||
SH
|
|
||||||
|
|
||||||
RBENV_VERSION=system run ruby -S rake
|
|
||||||
assert_success "system rake"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "ruby -S allows commands higher in PATH to have precedence over shims" {
|
|
||||||
export RBENV_VERSION="2.0"
|
|
||||||
|
|
||||||
create_ruby_executable
|
|
||||||
create_executable "rake" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo normal rake
|
|
||||||
SH
|
|
||||||
rbenv-rehash
|
|
||||||
|
|
||||||
create_executable "${HOME}/bin/rake" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo override rake
|
|
||||||
SH
|
|
||||||
|
|
||||||
PATH="${HOME}/bin:$PATH" run ruby -S rake
|
|
||||||
assert_success "override rake"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "ruby -S respects existing RUBYPATH" {
|
|
||||||
export RBENV_VERSION="2.0"
|
|
||||||
|
|
||||||
create_ruby_executable
|
|
||||||
create_executable "rspec" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo normal rspec
|
|
||||||
SH
|
|
||||||
rbenv-rehash
|
|
||||||
|
|
||||||
create_executable "${HOME}/bin/rspec" "#!/bin/sh"
|
|
||||||
create_executable "${HOME}/bin/rake" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo override rake
|
|
||||||
SH
|
|
||||||
|
|
||||||
export RUBYPATH="${HOME}/bin"
|
|
||||||
run ruby -S rspec
|
|
||||||
assert_success "normal rspec"
|
|
||||||
run ruby -S rake
|
|
||||||
assert_success "override rake"
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "supports nested ruby -S invocations to change RBENV_VERSION" {
|
|
||||||
export RBENV_VERSION="1.8"
|
|
||||||
create_ruby_executable
|
|
||||||
create_executable "rspec" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo rspec 1.8
|
|
||||||
SH
|
|
||||||
|
|
||||||
export RBENV_VERSION="2.0"
|
|
||||||
create_ruby_executable
|
|
||||||
create_executable "rspec" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo rspec 2.0
|
|
||||||
SH
|
|
||||||
create_executable "rake" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo rake 2.0
|
|
||||||
RBENV_VERSION=1.8 ruby -S rspec
|
|
||||||
SH
|
|
||||||
|
|
||||||
rbenv-rehash
|
|
||||||
run ruby -S rake
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
rake 2.0
|
|
||||||
rspec 1.8
|
|
||||||
OUT
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "supports system ruby -S invocation to select a different RBENV_VERSION" {
|
|
||||||
export RBENV_VERSION="2.0"
|
|
||||||
create_ruby_executable
|
|
||||||
create_executable "rspec" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo rspec 2.0
|
|
||||||
SH
|
|
||||||
rbenv-rehash
|
|
||||||
|
|
||||||
create_ruby_executable "${RBENV_TEST_DIR}/bin/ruby"
|
|
||||||
create_executable "${RBENV_TEST_DIR}/bin/rspec" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo system rspec
|
|
||||||
SH
|
|
||||||
create_executable "${RBENV_TEST_DIR}/bin/rake" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo system rake
|
|
||||||
RBENV_VERSION=2.0 ruby -S rspec
|
|
||||||
SH
|
|
||||||
|
|
||||||
RBENV_VERSION=system run ruby -S rake
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
system rake
|
|
||||||
rspec 2.0
|
|
||||||
OUT
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "nested ruby -S invocations preserve PATH precedence" {
|
|
||||||
export RBENV_VERSION="2.0"
|
|
||||||
create_ruby_executable
|
|
||||||
create_executable "rspec" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo rspec 2.0
|
|
||||||
SH
|
|
||||||
rbenv-rehash
|
|
||||||
|
|
||||||
create_ruby_executable "${RBENV_TEST_DIR}/bin/ruby"
|
|
||||||
create_executable "${RBENV_TEST_DIR}/bin/rspec" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo system rspec
|
|
||||||
SH
|
|
||||||
create_executable "${RBENV_TEST_DIR}/bin/rake" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo system rake
|
|
||||||
RBENV_VERSION=2.0 ruby -S rspec
|
|
||||||
SH
|
|
||||||
|
|
||||||
create_executable "${HOME}/bin/rspec" <<SH
|
|
||||||
#!/usr/bin/env ruby
|
|
||||||
echo override rspec
|
|
||||||
SH
|
|
||||||
|
|
||||||
PATH="${HOME}/bin:$PATH" RBENV_VERSION=system run ruby -S rake
|
|
||||||
assert_success
|
|
||||||
assert_output <<OUT
|
|
||||||
system rake
|
|
||||||
override rspec
|
|
||||||
OUT
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue