59e0b67c7f
Fixes #6041 Unlike all other Consul operations, boostrapping requires Consul be available. This PR tries Consul 3 times with a backoff to account for the group services being asynchronously registered with Consul.
90 lines
1.9 KiB
Go
90 lines
1.9 KiB
Go
package testutil
|
|
|
|
import (
|
|
"os/exec"
|
|
"runtime"
|
|
"sync"
|
|
"syscall"
|
|
"testing"
|
|
|
|
"github.com/hashicorp/nomad/client/fingerprint"
|
|
)
|
|
|
|
// RequireRoot skips tests unless running on a Unix as root.
|
|
func RequireRoot(t *testing.T) {
|
|
if syscall.Geteuid() != 0 {
|
|
t.Skip("Must run as root on Unix")
|
|
}
|
|
}
|
|
|
|
// RequireConsul skips tests unless a Consul binary is available on $PATH.
|
|
func RequireConsul(t *testing.T) {
|
|
_, err := exec.Command("consul", "version").CombinedOutput()
|
|
if err != nil {
|
|
t.Skipf("Test requires Consul: %v", err)
|
|
}
|
|
}
|
|
|
|
func ExecCompatible(t *testing.T) {
|
|
if runtime.GOOS != "linux" || syscall.Geteuid() != 0 {
|
|
t.Skip("Test only available running as root on linux")
|
|
}
|
|
CgroupCompatible(t)
|
|
}
|
|
|
|
func JavaCompatible(t *testing.T) {
|
|
if runtime.GOOS == "linux" && syscall.Geteuid() != 0 {
|
|
t.Skip("Test only available when running as root on linux")
|
|
}
|
|
}
|
|
|
|
func QemuCompatible(t *testing.T) {
|
|
// Check if qemu exists
|
|
bin := "qemu-system-x86_64"
|
|
if runtime.GOOS == "windows" {
|
|
bin = "qemu-img"
|
|
}
|
|
_, err := exec.Command(bin, "--version").CombinedOutput()
|
|
if err != nil {
|
|
t.Skip("Must have Qemu installed for Qemu specific tests to run")
|
|
}
|
|
}
|
|
|
|
func CgroupCompatible(t *testing.T) {
|
|
mount, err := fingerprint.FindCgroupMountpointDir()
|
|
if err != nil || mount == "" {
|
|
t.Skipf("Failed to find cgroup mount: %v %v", mount, err)
|
|
}
|
|
}
|
|
|
|
var rktExists bool
|
|
var rktOnce sync.Once
|
|
|
|
func RktCompatible(t *testing.T) {
|
|
if runtime.GOOS != "linux" || syscall.Geteuid() != 0 {
|
|
t.Skip("Must be root on Linux to run test")
|
|
}
|
|
|
|
// else see if rkt exists
|
|
rktOnce.Do(func() {
|
|
_, err := exec.Command("rkt", "version").CombinedOutput()
|
|
if err == nil {
|
|
rktExists = true
|
|
}
|
|
})
|
|
|
|
if !rktExists {
|
|
t.Skip("Must have rkt installed for rkt specific tests to run")
|
|
}
|
|
}
|
|
|
|
func MountCompatible(t *testing.T) {
|
|
if runtime.GOOS == "windows" {
|
|
t.Skip("Windows does not support mount")
|
|
}
|
|
|
|
if syscall.Geteuid() != 0 {
|
|
t.Skip("Must be root to run test")
|
|
}
|
|
}
|