2023-09-11 08:18:43 +00:00
|
|
|
package testutil
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
2024-03-12 14:15:54 +00:00
|
|
|
"path/filepath"
|
2023-09-12 13:28:53 +00:00
|
|
|
"runtime"
|
2023-09-11 08:18:43 +00:00
|
|
|
"strings"
|
2024-03-12 14:15:54 +00:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
2023-09-11 08:18:43 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// CleanupEnvironment sets up a pristine environment containing only $PATH and $HOME.
|
|
|
|
// The original environment is restored upon test completion.
|
|
|
|
// Note: use of this function is incompatible with parallel execution.
|
2024-12-12 14:42:15 +00:00
|
|
|
func CleanupEnvironment(t TestingT) {
|
2023-09-11 08:18:43 +00:00
|
|
|
// Restore environment when test finishes.
|
|
|
|
environ := os.Environ()
|
|
|
|
t.Cleanup(func() {
|
|
|
|
// Restore original environment.
|
|
|
|
for _, kv := range environ {
|
|
|
|
kvs := strings.SplitN(kv, "=", 2)
|
|
|
|
os.Setenv(kvs[0], kvs[1])
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
path := os.Getenv("PATH")
|
|
|
|
pwd := os.Getenv("PWD")
|
|
|
|
os.Clearenv()
|
|
|
|
|
|
|
|
// We use t.Setenv instead of os.Setenv because the former actively
|
|
|
|
// prevents a test being run with t.Parallel. Modifying the environment
|
|
|
|
// within a test is not compatible with running tests in parallel
|
|
|
|
// because of isolation; the environment is scoped to the process.
|
|
|
|
t.Setenv("PATH", path)
|
|
|
|
t.Setenv("HOME", pwd)
|
2023-09-12 13:28:53 +00:00
|
|
|
if runtime.GOOS == "windows" {
|
|
|
|
t.Setenv("USERPROFILE", pwd)
|
|
|
|
}
|
2023-09-11 08:18:43 +00:00
|
|
|
}
|
2023-09-29 08:38:06 +00:00
|
|
|
|
2024-03-12 14:15:54 +00:00
|
|
|
// Changes into specified directory for the duration of the test.
|
|
|
|
// Returns the current working directory.
|
2024-12-12 14:42:15 +00:00
|
|
|
func Chdir(t TestingT, dir string) string {
|
2024-12-09 12:34:27 +00:00
|
|
|
// Prevent parallel execution when changing the working directory.
|
|
|
|
// t.Setenv automatically fails if t.Parallel is set.
|
|
|
|
t.Setenv("DO_NOT_RUN_IN_PARALLEL", "true")
|
|
|
|
|
2024-03-12 14:15:54 +00:00
|
|
|
wd, err := os.Getwd()
|
|
|
|
require.NoError(t, err)
|
2024-12-20 14:40:54 +00:00
|
|
|
if os.Getenv("TESTS_ORIG_WD") == "" {
|
|
|
|
t.Setenv("TESTS_ORIG_WD", wd)
|
|
|
|
}
|
2024-03-12 14:15:54 +00:00
|
|
|
|
|
|
|
abs, err := filepath.Abs(dir)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
err = os.Chdir(abs)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
t.Cleanup(func() {
|
|
|
|
err := os.Chdir(wd)
|
|
|
|
require.NoError(t, err)
|
|
|
|
})
|
|
|
|
|
|
|
|
return wd
|
|
|
|
}
|
2024-12-20 14:40:54 +00:00
|
|
|
|
|
|
|
// Return filename ff testutil.Chdir was not called.
|
|
|
|
// Return absolute path to filename testutil.Chdir() was called.
|
|
|
|
func TestData(filename string) string {
|
|
|
|
// Note, if TESTS_ORIG_WD is not set, Getenv return "" and Join returns filename
|
|
|
|
return filepath.Join(os.Getenv("TESTS_ORIG_WD"), filename)
|
|
|
|
}
|