mirror of
https://github.com/asdf-vm/asdf.git
synced 2024-12-26 13:24:59 -07:00
476 lines
14 KiB
Bash
476 lines
14 KiB
Bash
#!/usr/bin/env bats
|
|
# shellcheck disable=SC2030,SC2031,SC2164
|
|
|
|
load test_helpers
|
|
|
|
setup() {
|
|
setup_asdf_dir
|
|
install_dummy_plugin
|
|
install_dummy_version "0.1.0"
|
|
install_dummy_version "0.2.0"
|
|
|
|
PROJECT_DIR="$HOME/project"
|
|
mkdir -p "$PROJECT_DIR"
|
|
|
|
cd "$HOME"
|
|
}
|
|
|
|
teardown() {
|
|
clean_asdf_dir
|
|
}
|
|
|
|
@test "get_install_path should output version path when version is provided" {
|
|
run get_install_path foo version "1.0.0"
|
|
[ "$status" -eq 0 ]
|
|
install_path=${output#"$HOME/"}
|
|
[ "$install_path" = ".asdf/installs/foo/1.0.0" ]
|
|
}
|
|
|
|
@test "get_install_path should output custom path when custom install type is provided" {
|
|
run get_install_path foo custom "1.0.0"
|
|
[ "$status" -eq 0 ]
|
|
install_path=${output#"$HOME/"}
|
|
[ "$install_path" = ".asdf/installs/foo/custom-1.0.0" ]
|
|
}
|
|
|
|
@test "get_install_path should output path when path version is provided" {
|
|
run get_install_path foo path "/some/path"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "/some/path" ]
|
|
}
|
|
|
|
@test "get_download_path should output version path when version is provided" {
|
|
run get_download_path foo version "1.0.0"
|
|
[ "$status" -eq 0 ]
|
|
download_path=${output#"$HOME/"}
|
|
[ "$download_path" = ".asdf/downloads/foo/1.0.0" ]
|
|
}
|
|
|
|
@test "get_download_path should output custom path when custom download type is provided" {
|
|
run get_download_path foo custom "1.0.0"
|
|
[ "$status" -eq 0 ]
|
|
download_path=${output#"$HOME/"}
|
|
[ "$download_path" = ".asdf/downloads/foo/custom-1.0.0" ]
|
|
}
|
|
|
|
@test "get_download_path should output nothing when path version is provided" {
|
|
run get_download_path foo path "/some/path"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "" ]
|
|
}
|
|
|
|
@test "check_if_version_exists should exit with 1 if plugin does not exist" {
|
|
run check_if_version_exists "inexistent" "1.0.0"
|
|
[ "$status" -eq 1 ]
|
|
[ "$output" = "No such plugin: inexistent" ]
|
|
}
|
|
|
|
@test "check_if_version_exists should exit with 1 if version does not exist" {
|
|
run check_if_version_exists "dummy" "1.0.0"
|
|
[ "$status" -eq 1 ]
|
|
}
|
|
|
|
@test "version_not_installed_text is correct" {
|
|
run version_not_installed_text "dummy" "1.0.0"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "version 1.0.0 is not installed for dummy" ]
|
|
}
|
|
|
|
@test "check_if_version_exists should be noop if version exists" {
|
|
run check_if_version_exists "dummy" "0.1.0"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "" ]
|
|
}
|
|
|
|
@test "check_if_version_exists should be noop if version is system" {
|
|
mkdir -p "$ASDF_DIR/plugins/foo"
|
|
run check_if_version_exists "foo" "system"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "" ]
|
|
}
|
|
|
|
@test "check_if_version_exists should be ok for ref:version install" {
|
|
mkdir -p "$ASDF_DIR/plugins/foo"
|
|
mkdir -p "$ASDF_DIR/installs/foo/ref-master"
|
|
run check_if_version_exists "foo" "ref:master"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "" ]
|
|
}
|
|
|
|
@test "check_if_plugin_exists should exit with 1 when plugin is empty string" {
|
|
run check_if_plugin_exists
|
|
[ "$status" -eq 1 ]
|
|
[ "$output" = "No plugin given" ]
|
|
}
|
|
|
|
@test "check_if_plugin_exists should be noop if plugin exists" {
|
|
run check_if_plugin_exists "dummy"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "" ]
|
|
}
|
|
|
|
@test "parse_asdf_version_file should output version" {
|
|
echo "dummy 0.1.0" >"$PROJECT_DIR/.tool-versions"
|
|
run parse_asdf_version_file "$PROJECT_DIR/.tool-versions" dummy
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "0.1.0" ]
|
|
}
|
|
|
|
@test "parse_asdf_version_file should output path on project with spaces" {
|
|
PROJECT_DIR="$PROJECT_DIR/outer space"
|
|
mkdir -p "$PROJECT_DIR"
|
|
|
|
echo "dummy 0.1.0" >"$PROJECT_DIR/.tool-versions"
|
|
run parse_asdf_version_file "$PROJECT_DIR/.tool-versions" dummy
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "0.1.0" ]
|
|
}
|
|
|
|
@test "parse_asdf_version_file should output path version with spaces" {
|
|
echo "dummy path:/some/dummy path" >"$PROJECT_DIR/.tool-versions"
|
|
run parse_asdf_version_file "$PROJECT_DIR/.tool-versions" dummy
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "path:/some/dummy path" ]
|
|
}
|
|
|
|
@test "parse_asdf_version_file should output path version with tilda" {
|
|
echo "dummy path:~/some/dummy path" >"$PROJECT_DIR/.tool-versions"
|
|
run parse_asdf_version_file "$PROJECT_DIR/.tool-versions" dummy
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "path:$HOME/some/dummy path" ]
|
|
}
|
|
|
|
@test "find_versions should return .tool-versions if legacy is disabled" {
|
|
echo "dummy 0.1.0" >"$PROJECT_DIR/.tool-versions"
|
|
echo "0.2.0" >"$PROJECT_DIR/.dummy-version"
|
|
|
|
run find_versions "dummy" "$PROJECT_DIR"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "0.1.0|$PROJECT_DIR/.tool-versions" ]
|
|
}
|
|
|
|
@test "find_versions should return the legacy file if supported" {
|
|
echo "legacy_version_file = yes" >"$HOME/.asdfrc"
|
|
echo "dummy 0.1.0" >"$HOME/.tool-versions"
|
|
echo "0.2.0" >"$PROJECT_DIR/.dummy-version"
|
|
|
|
run find_versions "dummy" "$PROJECT_DIR"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "0.2.0|$PROJECT_DIR/.dummy-version" ]
|
|
}
|
|
|
|
@test "find_versions skips .tool-version file that don't list the plugin" {
|
|
echo "dummy 0.1.0" >"$HOME/.tool-versions"
|
|
echo "another_plugin 0.3.0" >"$PROJECT_DIR/.tool-versions"
|
|
|
|
run find_versions "dummy" "$PROJECT_DIR"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "0.1.0|$HOME/.tool-versions" ]
|
|
}
|
|
|
|
@test "find_versions should return .tool-versions if unsupported" {
|
|
echo "dummy 0.1.0" >"$HOME/.tool-versions"
|
|
echo "0.2.0" >"$PROJECT_DIR/.dummy-version"
|
|
echo "legacy_version_file = yes" >"$HOME/.asdfrc"
|
|
rm "$ASDF_DIR/plugins/dummy/bin/list-legacy-filenames"
|
|
|
|
run find_versions "dummy" "$PROJECT_DIR"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "0.1.0|$HOME/.tool-versions" ]
|
|
}
|
|
|
|
@test "find_versions should return the version set by environment variable" {
|
|
export ASDF_DUMMY_VERSION=0.2.0
|
|
|
|
run find_versions "dummy" "$PROJECT_DIR"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "0.2.0|ASDF_DUMMY_VERSION environment variable" ]
|
|
}
|
|
|
|
@test "asdf_data_dir should return user dir if configured" {
|
|
ASDF_DATA_DIR="/tmp/wadus"
|
|
|
|
run asdf_data_dir
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$ASDF_DATA_DIR" ]
|
|
}
|
|
|
|
@test "asdf_data_dir should return ~/.asdf when ASDF_DATA_DIR is not set" {
|
|
unset ASDF_DATA_DIR
|
|
|
|
run asdf_data_dir
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$HOME/.asdf" ]
|
|
}
|
|
|
|
@test "check_if_plugin_exists should work with a custom data directory" {
|
|
ASDF_DATA_DIR=$HOME/asdf-data
|
|
|
|
mkdir -p "$ASDF_DATA_DIR/plugins"
|
|
mkdir -p "$ASDF_DATA_DIR/installs"
|
|
|
|
install_mock_plugin "dummy2" "$ASDF_DATA_DIR"
|
|
install_mock_plugin_version "dummy2" "0.1.0" "$ASDF_DATA_DIR"
|
|
|
|
run check_if_plugin_exists "dummy2"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "" ]
|
|
}
|
|
|
|
@test "find_versions should return \$ASDF_DEFAULT_TOOL_VERSIONS_FILENAME if set" {
|
|
ASDF_DEFAULT_TOOL_VERSIONS_FILENAME="$PROJECT_DIR/global-tool-versions"
|
|
echo "dummy 0.1.0" >"$ASDF_DEFAULT_TOOL_VERSIONS_FILENAME"
|
|
|
|
run find_versions "dummy" "$PROJECT_DIR"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "0.1.0|$ASDF_DEFAULT_TOOL_VERSIONS_FILENAME" ]
|
|
}
|
|
|
|
@test "find_versions should check \$HOME legacy files before \$ASDF_DEFAULT_TOOL_VERSIONS_FILENAME" {
|
|
ASDF_DEFAULT_TOOL_VERSIONS_FILENAME="$PROJECT_DIR/global-tool-versions"
|
|
echo "dummy 0.2.0" >"$ASDF_DEFAULT_TOOL_VERSIONS_FILENAME"
|
|
echo "dummy 0.1.0" >"$HOME/.dummy-version"
|
|
echo "legacy_version_file = yes" >"$HOME/.asdfrc"
|
|
|
|
run find_versions "dummy" "$PROJECT_DIR"
|
|
[ "$status" -eq 0 ]
|
|
[[ "$output" == *"0.1.0|$HOME/.dummy-version"* ]]
|
|
}
|
|
|
|
@test "get_preset_version_for returns the current version" {
|
|
cd "$PROJECT_DIR"
|
|
echo "dummy 0.2.0" >.tool-versions
|
|
run get_preset_version_for "dummy"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "0.2.0" ]
|
|
}
|
|
|
|
@test "get_preset_version_for returns the global version from home when project is outside of home" {
|
|
echo "dummy 0.1.0" >"$HOME/.tool-versions"
|
|
PROJECT_DIR=$BASE_DIR/project
|
|
mkdir -p "$PROJECT_DIR"
|
|
run get_preset_version_for "dummy"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "0.1.0" ]
|
|
}
|
|
|
|
@test "get_preset_version_for returns the tool version from env if ASDF_{TOOL}_VERSION is defined" {
|
|
cd "$PROJECT_DIR"
|
|
echo "dummy 0.2.0" >.tool-versions
|
|
ASDF_DUMMY_VERSION=3.0.0 run get_preset_version_for "dummy"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "3.0.0" ]
|
|
}
|
|
|
|
@test "get_preset_version_for should return branch reference version" {
|
|
cd "$PROJECT_DIR"
|
|
echo "dummy ref:master" >"$PROJECT_DIR/.tool-versions"
|
|
run get_preset_version_for "dummy"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "ref:master" ]
|
|
}
|
|
|
|
@test "get_preset_version_for should return path version" {
|
|
cd "$PROJECT_DIR"
|
|
echo "dummy path:/some/place with spaces" >"$PROJECT_DIR/.tool-versions"
|
|
run get_preset_version_for "dummy"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "path:/some/place with spaces" ]
|
|
}
|
|
|
|
@test "get_preset_version_for should return path version with tilda" {
|
|
cd "$PROJECT_DIR"
|
|
echo "dummy path:~/some/place with spaces" >"$PROJECT_DIR/.tool-versions"
|
|
run get_preset_version_for "dummy"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "path:$HOME/some/place with spaces" ]
|
|
}
|
|
|
|
@test "get_executable_path for system version should return system path" {
|
|
mkdir -p "$ASDF_DIR/plugins/foo"
|
|
run get_executable_path "foo" "system" "ls"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$(which ls)" ]
|
|
}
|
|
|
|
@test "get_executable_path for system version should not use asdf shims" {
|
|
mkdir -p "$ASDF_DIR/plugins/foo"
|
|
touch "$ASDF_DIR/shims/dummy_executable"
|
|
chmod +x "$ASDF_DIR/shims/dummy_executable"
|
|
|
|
run which dummy_executable
|
|
[ "$status" -eq 0 ]
|
|
|
|
run get_executable_path "foo" "system" "dummy_executable"
|
|
[ "$status" -eq 1 ]
|
|
}
|
|
|
|
@test "get_executable_path for non system version should return relative path from plugin" {
|
|
mkdir -p "$ASDF_DIR/plugins/foo"
|
|
mkdir -p "$ASDF_DIR/installs/foo/1.0.0/bin"
|
|
executable_path="$ASDF_DIR/installs/foo/1.0.0/bin/dummy"
|
|
touch "$executable_path"
|
|
chmod +x "$executable_path"
|
|
|
|
run get_executable_path "foo" "1.0.0" "bin/dummy"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$executable_path" ]
|
|
}
|
|
|
|
@test "get_executable_path for ref:version installed version should resolve to ref-version" {
|
|
mkdir -p "$ASDF_DIR/plugins/foo"
|
|
mkdir -p "$ASDF_DIR/installs/foo/ref-master/bin"
|
|
executable_path="$ASDF_DIR/installs/foo/ref-master/bin/dummy"
|
|
touch "$executable_path"
|
|
chmod +x "$executable_path"
|
|
|
|
run get_executable_path "foo" "ref:master" "bin/dummy"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$executable_path" ]
|
|
}
|
|
|
|
@test "find_tool_versions will find a .tool-versions path if it exists in current directory" {
|
|
echo "dummy 0.1.0" >"$PROJECT_DIR/.tool-versions"
|
|
cd "$PROJECT_DIR"
|
|
|
|
run find_tool_versions
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$PROJECT_DIR/.tool-versions" ]
|
|
}
|
|
|
|
@test "find_tool_versions will find a .tool-versions path if it exists in parent directory" {
|
|
echo "dummy 0.1.0" >"$PROJECT_DIR/.tool-versions"
|
|
mkdir -p "$PROJECT_DIR/child"
|
|
cd "$PROJECT_DIR"/child
|
|
|
|
run find_tool_versions
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$PROJECT_DIR/.tool-versions" ]
|
|
}
|
|
|
|
@test "get_version_from_env returns the version set in the environment variable" {
|
|
export ASDF_DUMMY_VERSION=0.1.0
|
|
run get_version_from_env 'dummy'
|
|
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = '0.1.0' ]
|
|
}
|
|
|
|
@test "get_version_from_env returns nothing when environment variable is not set" {
|
|
run get_version_from_env 'dummy'
|
|
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = '' ]
|
|
}
|
|
|
|
@test "resolve_symlink converts the symlink path to the real file path" {
|
|
touch foo
|
|
ln -s "$PWD/foo" bar
|
|
|
|
run resolve_symlink bar
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$PWD/foo" ]
|
|
rm -f foo bar
|
|
}
|
|
|
|
@test "resolve_symlink converts relative symlink directory path to the real file path" {
|
|
mkdir baz
|
|
ln -s ../foo baz/bar
|
|
|
|
run resolve_symlink baz/bar
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$PWD/baz/../foo" ]
|
|
rm -f foo bar
|
|
}
|
|
|
|
@test "resolve_symlink converts relative symlink path to the real file path" {
|
|
touch foo
|
|
ln -s foo bar
|
|
|
|
run resolve_symlink bar
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$PWD/foo" ]
|
|
rm -f foo bar
|
|
}
|
|
|
|
@test "strip_tool_version_comments removes lines that only contain comments" {
|
|
cat <<EOF >test_file
|
|
# comment line
|
|
ruby 2.0.0
|
|
EOF
|
|
run strip_tool_version_comments test_file
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "ruby 2.0.0" ]
|
|
}
|
|
@test "strip_tool_version_comments removes lines that only contain comments even with missing newline" {
|
|
echo -n "# comment line" >test_file
|
|
run strip_tool_version_comments test_file
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "" ]
|
|
}
|
|
|
|
@test "strip_tool_version_comments removes trailing comments on lines containing version information" {
|
|
cat <<EOF >test_file
|
|
ruby 2.0.0 # inline comment
|
|
EOF
|
|
run strip_tool_version_comments test_file
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "ruby 2.0.0" ]
|
|
}
|
|
|
|
@test "strip_tool_version_comments removes trailing comments on lines containing version information even with missing newline" {
|
|
echo -n "ruby 2.0.0 # inline comment" >test_file
|
|
run strip_tool_version_comments test_file
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "ruby 2.0.0" ]
|
|
}
|
|
|
|
@test "strip_tool_version_comments removes all comments from the version file" {
|
|
cat <<EOF >test_file
|
|
ruby 2.0.0 # inline comment
|
|
# comment line
|
|
erlang 18.2.1 # inline comment
|
|
EOF
|
|
expected="$(
|
|
cat <<EOF
|
|
ruby 2.0.0
|
|
erlang 18.2.1
|
|
EOF
|
|
)"
|
|
run strip_tool_version_comments test_file
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$expected" ]
|
|
}
|
|
|
|
@test "with_shim_executable doesn't crash when executable names contain dashes" {
|
|
cd "$PROJECT_DIR"
|
|
echo "dummy 0.1.0" >"$PROJECT_DIR/.tool-versions"
|
|
mkdir -p "$ASDF_DIR/installs/dummy/0.1.0/bin"
|
|
touch "$ASDF_DIR/installs/dummy/0.1.0/bin/test-dash"
|
|
chmod +x "$ASDF_DIR/installs/dummy/0.1.0/bin/test-dash"
|
|
run asdf reshim dummy 0.1.0
|
|
|
|
message="callback invoked"
|
|
|
|
callback() {
|
|
echo "$message"
|
|
}
|
|
|
|
run with_shim_executable test-dash callback
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "$message" ]
|
|
}
|
|
|
|
@test "prints warning if .tool-versions file has carriage returns" {
|
|
ASDF_CONFIG_FILE="$BATS_TEST_TMPDIR/asdfrc"
|
|
cat >"$ASDF_CONFIG_FILE" <<<$'key2 = value2\r'
|
|
|
|
[[ "$(get_asdf_config_value "key1" 2>&1)" = *"contains carriage returns"* ]]
|
|
}
|
|
|
|
@test "prints if asdfrc config file has carriage returns" {
|
|
cat >".tool-versions" <<<$'nodejs 19.6.0\r'
|
|
|
|
[[ "$(find_tool_versions 2>&1)" = *"contains carriage returns"* ]]
|
|
}
|