asdf/test/utils.bats

464 lines
13 KiB
Plaintext
Raw Normal View History

#!/usr/bin/env bats
# shellcheck disable=SC2030,SC2031,SC2164
2016-06-28 20:56:33 -07:00
load test_helpers
setup() {
2016-06-28 20:56:33 -07:00
setup_asdf_dir
2016-07-23 17:03:43 -07:00
install_dummy_plugin
install_dummy_version "0.1.0"
install_dummy_version "0.2.0"
PROJECT_DIR="$HOME/project"
mkdir -p "$PROJECT_DIR"
2019-11-27 10:50:00 -07:00
cd "$HOME"
}
teardown() {
2016-06-28 20:56:33 -07:00
clean_asdf_dir
}
2020-03-06 16:54:33 -07:00
@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/"}
2020-03-06 16:54:33 -07:00
[ "$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/"}
2020-03-06 16:54:33 -07:00
[ "$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/"}
echo "$download_path"
2020-03-06 16:54:33 -07:00
[ "$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/"}
2020-03-06 16:54:33 -07:00
[ "$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" {
2016-07-23 17:03:43 -07:00
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" {
2016-07-23 17:03:43 -07:00
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 ]
2016-07-23 17:03:43 -07:00
[ "$output" = "version 1.0.0 is not installed for dummy" ]
}
@test "check_if_version_exists should be noop if version exists" {
2016-07-23 17:03:43 -07:00
run check_if_version_exists "dummy" "0.1.0"
[ "$status" -eq 0 ]
[ "$output" = "" ]
}
2016-07-05 23:32:57 -07:00
@test "check_if_version_exists should be noop if version is system" {
mkdir -p "$ASDF_DIR/plugins/foo"
2016-07-05 23:32:57 -07:00
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 ]
2016-07-05 23:32:57 -07:00
[ "$output" = "No plugin given" ]
}
@test "check_if_plugin_exists should be noop if plugin exists" {
2016-07-23 17:03:43 -07:00
run check_if_plugin_exists "dummy"
[ "$status" -eq 0 ]
[ "$output" = "" ]
}
2016-12-23 10:11:47 -07:00
@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
2016-12-23 10:11:47 -07:00
[ "$status" -eq 0 ]
[ "$output" = "0.1.0" ]
2016-12-23 10:11:47 -07:00
}
@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" ]
}
2016-12-23 10:11:47 -07:00
@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" ]
2016-12-23 10:11:47 -07:00
}
@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" ]
2016-12-23 10:11:47 -07:00
}
2016-07-05 23:32:57 -07:00
@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" ]
}
2016-07-05 23:32:57 -07:00
@test "get_executable_path for system version should return system path" {
mkdir -p "$ASDF_DIR/plugins/foo"
2016-07-05 23:32:57 -07:00
run get_executable_path "foo" "system" "ls"
[ "$status" -eq 0 ]
[ "$output" = "$(which ls)" ]
2016-07-05 23:32:57 -07:00
}
@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"
2016-07-05 23:32:57 -07:00
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"
2016-07-05 23:32:57 -07:00
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" ]
}