undo assert_output_lines in tests

It was a dumb idea and it wasn't even implemented perfectly.
This commit is contained in:
Mislav Marohnić 2013-04-06 14:10:44 +02:00
parent 969af1567a
commit 7fc5f46bbb
8 changed files with 67 additions and 58 deletions

View file

@ -38,7 +38,9 @@ else
exit 1
fi"
run rbenv-completions hello happy world
assert_success "\
assert_success
assert_output <<OUT
happy
world"
world
OUT
}

View file

@ -27,9 +27,11 @@ create_executable() {
rbenv-rehash
run rbenv-completions exec
assert_success "\
assert_success
assert_output <<OUT
rake
ruby"
ruby
OUT
}
@test "supports hook path with spaces" {
@ -54,15 +56,16 @@ for arg; do
done
SH
run rbenv-exec ruby -w -e "puts 'hello world'" -- extra args
assert_success "\
run rbenv-exec ruby -w "/path to/ruby script.rb" -- extra args
assert_success
assert_output <<OUT
${RBENV_ROOT}/versions/2.0/bin/ruby
-w
-e
puts 'hello world'
/path to/ruby script.rb
--
extra
args"
args
OUT
}
@test "supports ruby -S <cmd>" {
@ -85,9 +88,10 @@ else
fi
SH
create_executable "rake" "\
create_executable "rake" <<SH
#!/usr/bin/env ruby
echo hello rake"
echo hello rake
SH
rbenv-rehash
run ruby -S rake

View file

@ -22,10 +22,12 @@ create_hook() {
create_hook "$path2" exec "bueno.bash"
RBENV_HOOK_PATH="$path1:$path2" run rbenv-hooks exec
assert_success "\
assert_success
assert_output <<OUT
${RBENV_TEST_DIR}/rbenv.d/exec/ahoy.bash
${RBENV_TEST_DIR}/rbenv.d/exec/hello.bash
${RBENV_TEST_DIR}/etc/rbenv_hooks/exec/bueno.bash"
${RBENV_TEST_DIR}/etc/rbenv_hooks/exec/bueno.bash
OUT
}
@test "supports hook paths with spaces" {
@ -35,9 +37,11 @@ create_hook() {
create_hook "$path2" exec "ahoy.bash"
RBENV_HOOK_PATH="$path1:$path2" run rbenv-hooks exec
assert_success "\
assert_success
assert_output <<OUT
${RBENV_TEST_DIR}/my hooks/rbenv.d/exec/hello.bash
${RBENV_TEST_DIR}/etc/rbenv hooks/exec/ahoy.bash"
${RBENV_TEST_DIR}/etc/rbenv hooks/exec/ahoy.bash
OUT
}
@test "resolves relative paths" {

View file

@ -45,8 +45,10 @@ create_executable() {
assert_success ""
run ls "${RBENV_ROOT}/shims"
assert_success "\
assert_success
assert_output <<OUT
rake
rspec
ruby"
ruby
OUT
}

View file

@ -22,9 +22,11 @@ load test_helper
@test "shell change invalid version" {
run rbenv-sh-shell 1.2.3
assert_failure "\
assert_failure
assert_output <<SH
rbenv: version \`1.2.3' not installed
return 1"
return 1
SH
}
@test "shell change version" {

View file

@ -26,7 +26,7 @@ assert_success() {
if [ "$status" -ne 0 ]; then
flunk "command failed with exit status $status"
elif [ "$#" -gt 0 ]; then
assert_output_lines "$1"
assert_output "$1"
fi
}
@ -34,7 +34,7 @@ assert_failure() {
if [ "$status" -eq 0 ]; then
flunk "expected failed exit status"
elif [ "$#" -gt 0 ]; then
assert_output_lines "$1"
assert_output "$1"
fi
}
@ -47,21 +47,11 @@ assert_equal() {
}
assert_output() {
assert_equal "$1" "$output"
}
# compares lines with leading whitespace trimmed
assert_output_lines() {
local -a expected
IFS=$'\n' expected=($1)
for (( i=0; i < ${#expected[@]}; i++ )); do
local wants="${expected[$i]}"
local got="${lines[$i]}"
assert_equal \
"${wants#"${wants%%[![:space:]]*}"}" \
"${got#"${got%%[![:space:]]*}"}"
done
assert_equal "${expected[$i]}" "${lines[$i]}"
local expected
if [ $# -eq 0 ]; then expected="$(cat -)"
else expected="$1"
fi
assert_equal "$expected" "$output"
}
assert_line() {

View file

@ -16,9 +16,11 @@ create_executable() {
create_executable "2.0" "rspec"
run rbenv-whence ruby
assert_success "\
assert_success
assert_output <<OUT
1.8
2.0"
2.0
OUT
run rbenv-whence rake
assert_success "1.8"

View file

@ -49,9 +49,12 @@ create_executable() {
create_executable "2.0" "rspec"
RBENV_VERSION=1.8 run rbenv-which rspec
assert_failure "\
assert_failure
assert_output <<OUT
rbenv: rspec: command not found
The \`rspec' command exists in these Ruby versions:
1.9
2.0"
2.0
OUT
}