diff --git a/libexec/rbenv b/libexec/rbenv index e893220b..4880df38 100755 --- a/libexec/rbenv +++ b/libexec/rbenv @@ -106,7 +106,13 @@ case "$command" in ;; * ) command_path="$(command -v "rbenv-$command" || true)" - [ -n "$command_path" ] || abort "no such command \`$command'" + if [ -z "$command_path" ]; then + if [ "$command" == "shell" ]; then + abort "shell integration not enabled. Run \`rbenv init' for instructions." + else + abort "no such command \`$command'" + fi + fi shift 1 if [ "$1" = --help ]; then diff --git a/test/shell.bats b/test/shell.bats index 9d6ae14b..bbb146e1 100644 --- a/test/shell.bats +++ b/test/shell.bats @@ -2,6 +2,17 @@ load test_helper +@test "shell integration disabled" { + run rbenv shell + assert_failure "rbenv: shell integration not enabled. Run \`rbenv init' for instructions." +} + +@test "shell integration enabled" { + eval "$(rbenv init -)" + run rbenv shell + assert_success "rbenv: no shell-specific version configured" +} + @test "no shell version" { mkdir -p "${RBENV_TEST_DIR}/myproject" cd "${RBENV_TEST_DIR}/myproject"