summaryrefslogtreecommitdiffstats
path: root/client/go/internal/admin/vespa-wrapper/startcbinary/numactl_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'client/go/internal/admin/vespa-wrapper/startcbinary/numactl_test.go')
-rw-r--r--client/go/internal/admin/vespa-wrapper/startcbinary/numactl_test.go89
1 files changed, 89 insertions, 0 deletions
diff --git a/client/go/internal/admin/vespa-wrapper/startcbinary/numactl_test.go b/client/go/internal/admin/vespa-wrapper/startcbinary/numactl_test.go
new file mode 100644
index 00000000000..65f52be988e
--- /dev/null
+++ b/client/go/internal/admin/vespa-wrapper/startcbinary/numactl_test.go
@@ -0,0 +1,89 @@
+// Copyright Yahoo. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
+package startcbinary
+
+import (
+ "fmt"
+ "os"
+ "runtime"
+ "strings"
+ "testing"
+
+ "github.com/stretchr/testify/assert"
+ "github.com/vespa-engine/vespa/client/go/internal/admin/trace"
+)
+
+func setup(t *testing.T, testFileName string) {
+ trace.AdjustVerbosity(1)
+ mockBinParent = strings.TrimSuffix(testFileName, "/numactl_test.go")
+ tmpBin = t.TempDir() + "/mock.bin.numactl_test"
+ err := os.MkdirAll(tmpBin, 0755)
+ assert.Nil(t, err)
+ t.Setenv("PATH", fmt.Sprintf("%s:%s", tmpBin, os.Getenv("PATH")))
+}
+
+func TestNumaCtlDetection(t *testing.T) {
+ if runtime.GOOS == "windows" {
+ return
+ }
+ _, tfn, _, _ := runtime.Caller(0)
+ setup(t, tfn)
+ orig := []string{"/bin/myprog", "-c", "cfgid"}
+ spec := NewProgSpec(orig)
+
+ useMock("no-numactl", "numactl")
+ spec.configureNumaCtl()
+ assert.Equal(t, false, spec.shouldUseNumaCtl)
+
+ useMock("bad-numactl", "numactl")
+ spec.configureNumaCtl()
+ assert.Equal(t, false, spec.shouldUseNumaCtl)
+
+ t.Setenv("VESPA_AFFINITY_CPU_SOCKET", "")
+ useMock("good-numactl", "numactl")
+ spec.configureNumaCtl()
+ assert.Equal(t, true, spec.shouldUseNumaCtl)
+ assert.Equal(t, -1, spec.numaSocket)
+ argv := spec.prependNumaCtl(orig)
+ trace.Trace("argv:", argv)
+ assert.Equal(t, 6, len(argv))
+ assert.Equal(t, "numactl", argv[0])
+ assert.Equal(t, "--interleave", argv[1])
+ assert.Equal(t, "all", argv[2])
+ assert.Equal(t, "/bin/myprog-bin", argv[3])
+ assert.Equal(t, "-c", argv[4])
+ assert.Equal(t, "cfgid", argv[5])
+
+ t.Setenv("VESPA_AFFINITY_CPU_SOCKET", "0")
+ spec.configureNumaCtl()
+ assert.Equal(t, true, spec.shouldUseNumaCtl)
+ assert.Equal(t, 0, spec.numaSocket)
+ argv = spec.prependNumaCtl(orig)
+ trace.Trace("argv:", argv)
+ assert.Equal(t, 6, len(argv))
+ assert.Equal(t, "numactl", argv[0])
+ assert.Equal(t, "--cpunodebind=0", argv[1])
+ assert.Equal(t, "--membind=0", argv[2])
+ assert.Equal(t, "/bin/myprog-bin", argv[3])
+ assert.Equal(t, "-c", argv[4])
+ assert.Equal(t, "cfgid", argv[5])
+
+ t.Setenv("VESPA_AFFINITY_CPU_SOCKET", "1")
+ spec.configureNumaCtl()
+ assert.Equal(t, true, spec.shouldUseNumaCtl)
+ assert.Equal(t, 1, spec.numaSocket)
+ argv = spec.prependNumaCtl(orig)
+ trace.Trace("argv:", argv)
+ assert.Equal(t, 6, len(argv))
+ assert.Equal(t, "numactl", argv[0])
+ assert.Equal(t, "--cpunodebind=1", argv[1])
+ assert.Equal(t, "--membind=1", argv[2])
+ assert.Equal(t, "/bin/myprog-bin", argv[3])
+ assert.Equal(t, "-c", argv[4])
+ assert.Equal(t, "cfgid", argv[5])
+
+ t.Setenv("VESPA_AFFINITY_CPU_SOCKET", "2")
+ spec.configureNumaCtl()
+ assert.Equal(t, true, spec.shouldUseNumaCtl)
+ assert.Equal(t, 0, spec.numaSocket)
+
+}