asdf/main_test.go

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

159 lines
3.8 KiB
Go
Raw Normal View History

package main
import (
"fmt"
"os"
"os/exec"
"strings"
"testing"
)
// Basic integration tests using the legacy BATS test scripts. This ensures the
// new Golang implementation matches the existing Bash implementation.
func TestBatsTests(t *testing.T) {
// Create temp directory
dir, err := os.MkdirTemp("", "golang-bats-tests")
if err != nil {
t.Fatal("Failed to create temp dir")
}
defer os.RemoveAll(dir)
// Build asdf and put in temp directory
build_asdf(t, dir)
// Run tests with the asdf binary in the temp directory
t.Run("current_command", func(t *testing.T) {
run_bats_file(t, dir, "current_command.bats")
})
t.Run("get_asdf_config_value", func(t *testing.T) {
run_bats_file(t, dir, "get_asdf_config_value.bats")
})
t.Run("help_command", func(t *testing.T) {
run_bats_file(t, dir, "help_command.bats")
})
t.Run("info_command", func(t *testing.T) {
run_bats_file(t, dir, "info_command.bats")
})
t.Run("install_command", func(t *testing.T) {
run_bats_file(t, dir, "install_command.bats")
})
t.Run("latest_command", func(t *testing.T) {
run_bats_file(t, dir, "latest_command.bats")
})
t.Run("list_command", func(t *testing.T) {
run_bats_file(t, dir, "list_command.bats")
})
t.Run("plugin_extension_command", func(t *testing.T) {
run_bats_file(t, dir, "plugin_extension_command.bats")
})
t.Run("plugin_list_all_command", func(t *testing.T) {
run_bats_file(t, dir, "plugin_list_all_command.bats")
})
t.Run("plugin_remove_command", func(t *testing.T) {
run_bats_file(t, dir, "plugin_remove_command.bats")
})
t.Run("plugin_test_command", func(t *testing.T) {
run_bats_file(t, dir, "plugin_test_command.bats")
})
t.Run("plugin_update_command", func(t *testing.T) {
run_bats_file(t, dir, "plugin_update_command.bats")
})
t.Run("remove_command", func(t *testing.T) {
run_bats_file(t, dir, "remove_command.bats")
})
t.Run("reshim_command", func(t *testing.T) {
run_bats_file(t, dir, "reshim_command.bats")
})
t.Run("reshim_command", func(t *testing.T) {
run_bats_file(t, dir, "reshim_command.bats")
})
t.Run("shim_env_command", func(t *testing.T) {
run_bats_file(t, dir, "shim_env_command.bats")
})
t.Run("shim_exec", func(t *testing.T) {
run_bats_file(t, dir, "shim_exec.bats")
})
t.Run("shim_versions_command", func(t *testing.T) {
run_bats_file(t, dir, "shim_versions_command.bats")
})
t.Run("shim_versions_command", func(t *testing.T) {
run_bats_file(t, dir, "shim_versions_command.bats")
})
t.Run("uninstall_command", func(t *testing.T) {
run_bats_file(t, dir, "uninstall_command.bats")
})
t.Run("update_command", func(t *testing.T) {
run_bats_file(t, dir, "update_command.bats")
})
t.Run("version_commands", func(t *testing.T) {
run_bats_file(t, dir, "version_commands.bats")
})
t.Run("where_command", func(t *testing.T) {
run_bats_file(t, dir, "where_command.bats")
})
t.Run("which_command", func(t *testing.T) {
run_bats_file(t, dir, "which_command.bats")
})
}
func run_bats_file(t *testing.T, dir, filename string) {
t.Helper()
cmd := exec.Command("bats", "--verbose-run", fmt.Sprintf("test/%s", filename))
// Capture stdout and stderr
var stdout strings.Builder
var stderr strings.Builder
cmd.Stdout = &stdout
cmd.Stderr = &stderr
// Add dir to asdf test variables
asdf_test_home := fmt.Sprintf("HOME=%s/.asdf/", dir)
asdf_bin_path := fmt.Sprintf("ASDF_BIN=%s", dir)
cmd.Env = append(cmd.Environ(), asdf_bin_path, asdf_test_home)
err := cmd.Run()
if err != nil {
// If command fails print both stderr and stdout
fmt.Println("stdout:", stdout.String())
fmt.Println("stderr:", stderr.String())
t.Fatal("bats command failed to run test file successfully")
return
}
}
func build_asdf(t *testing.T, dir string) {
cmd := exec.Command("go", "build", "-o", dir)
err := cmd.Run()
if err != nil {
t.Fatal("Failed to build asdf")
}
}