mirror of
https://github.com/status-im/consul.git
synced 2025-01-10 13:55:55 +00:00
efe279f802
* Add a make target to run lint-consul-retry on all the modules * Cleanup sdk/testutil/retry * Fix a bunch of retry.Run* usage to not use the outer testing.T * Fix some more recent retry lint issues and pin to v1.4.0 of lint-consul-retry * Fix codegen copywrite lint issues * Don’t perform cleanup after each retry attempt by default. * Use the common testutil.TestingTB interface in test-integ/tenancy * Fix retry tests * Update otel access logging extension test to perform requests within the retry block
64 lines
1.7 KiB
Go
64 lines
1.7 KiB
Go
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
package testutil
|
|
|
|
import (
|
|
"os"
|
|
"strings"
|
|
"testing"
|
|
)
|
|
|
|
var noCleanup = strings.ToLower(os.Getenv("TEST_NOCLEANUP")) == "true"
|
|
var saveSnapshot = strings.ToLower(os.Getenv("TEST_SAVE_SNAPSHOT")) == "true"
|
|
|
|
// TempDir creates a temporary directory within tmpdir with the name 'testname-name'.
|
|
// If the directory cannot be created t.Fatal is called.
|
|
// The directory will be removed when the test ends. Set TEST_NOCLEANUP env var
|
|
// to prevent the directory from being removed.
|
|
func TempDir(t TestingTB, name string) string {
|
|
if t == nil {
|
|
panic("argument t must be non-nil")
|
|
}
|
|
name = t.Name() + "-" + name
|
|
name = strings.Replace(name, "/", "_", -1)
|
|
d, err := os.MkdirTemp("", name)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
t.Cleanup(func() {
|
|
if noCleanup {
|
|
t.Logf("skipping cleanup because TEST_NOCLEANUP was enabled")
|
|
return
|
|
}
|
|
os.RemoveAll(d)
|
|
})
|
|
return d
|
|
}
|
|
|
|
// TempFile creates a temporary file within tmpdir with the name 'testname-name'.
|
|
// If the file cannot be created t.Fatal is called. If a temporary directory
|
|
// has been created before consider storing the file inside this directory to
|
|
// avoid double cleanup.
|
|
// The file will be removed when the test ends. Set TEST_NOCLEANUP env var
|
|
// to prevent the file from being removed.
|
|
func TempFile(t testing.TB, name string) *os.File {
|
|
if t == nil {
|
|
panic("argument t must be non-nil")
|
|
}
|
|
name = t.Name() + "-" + name
|
|
name = strings.Replace(name, "/", "_", -1)
|
|
f, err := os.CreateTemp("", name)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
t.Cleanup(func() {
|
|
if noCleanup {
|
|
t.Logf("skipping cleanup because TEST_NOCLEANUP was enabled")
|
|
return
|
|
}
|
|
os.Remove(f.Name())
|
|
})
|
|
return f
|
|
}
|