From e1e94812425a487069bf33f781bec987e9e49874 Mon Sep 17 00:00:00 2001 From: Martin Polden Date: Fri, 3 Feb 2023 15:20:23 +0100 Subject: Re-organize Go code --- client/go/internal/admin/prog/valgrind_test.go | 92 ++++++++++++++++++++++++++ 1 file changed, 92 insertions(+) create mode 100644 client/go/internal/admin/prog/valgrind_test.go (limited to 'client/go/internal/admin/prog/valgrind_test.go') diff --git a/client/go/internal/admin/prog/valgrind_test.go b/client/go/internal/admin/prog/valgrind_test.go new file mode 100644 index 00000000000..6ec622277c6 --- /dev/null +++ b/client/go/internal/admin/prog/valgrind_test.go @@ -0,0 +1,92 @@ +// Copyright Yahoo. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root. +package prog + +import ( + "fmt" + "os" + "runtime" + "strings" + "testing" + + "github.com/stretchr/testify/assert" + "github.com/vespa-engine/vespa/client/go/internal/admin/trace" + "github.com/vespa-engine/vespa/client/go/internal/util" +) + +var tmpBin string +var mockBinParent string + +func useMock(prog, target string) { + mock := fmt.Sprintf("%s/mockbin/%s", mockBinParent, prog) + symlink := fmt.Sprintf("%s/%s", tmpBin, target) + os.Remove(symlink) + err := os.Symlink(mock, symlink) + if err != nil { + util.JustExitWith(err) + } +} + +func setupValgrind(t *testing.T, testFileName string) { + trace.AdjustVerbosity(1) + t.Setenv("VESPA_HOME", mockBinParent+"/mock_vespahome") + mockBinParent = strings.TrimSuffix(testFileName, "/valgrind_test.go") + tmpBin = t.TempDir() + "/mock.bin.valgrind_test" + err := os.MkdirAll(tmpBin, 0755) + assert.Nil(t, err) + t.Setenv("PATH", fmt.Sprintf("%s:%s", tmpBin, os.Getenv("PATH"))) +} + +func TestValgrindDetection(t *testing.T) { + if runtime.GOOS == "windows" { + return + } + _, tfn, _, _ := runtime.Caller(0) + setupValgrind(t, tfn) + spec := NewSpec([]string{"/opt/vespa/bin/foobar"}) + var argv []string + + useMock("has-valgrind", VALGRIND_PROG) + + t.Setenv("VESPA_USE_VALGRIND", "") + spec.ConfigureValgrind() + assert.Equal(t, false, spec.shouldUseValgrind) + assert.Equal(t, false, spec.shouldUseCallgrind) + + t.Setenv("VESPA_USE_VALGRIND", "foo bar") + spec.ConfigureValgrind() + assert.Equal(t, false, spec.shouldUseValgrind) + assert.Equal(t, false, spec.shouldUseCallgrind) + + t.Setenv("VESPA_USE_VALGRIND", "foobar") + spec.ConfigureValgrind() + assert.Equal(t, true, spec.shouldUseValgrind) + assert.Equal(t, false, spec.shouldUseCallgrind) + + argv = spec.prependValgrind([]string{"/bin/myprog", "-c", "cfgid"}) + trace.Trace("argv:", argv) + assert.Equal(t, 11, len(argv)) + assert.Equal(t, "valgrind", argv[0]) + assert.Equal(t, "/bin/myprog", argv[8]) + + t.Setenv("VESPA_USE_VALGRIND", "another foobar yetmore") + spec.ConfigureValgrind() + assert.Equal(t, true, spec.shouldUseValgrind) + assert.Equal(t, false, spec.shouldUseCallgrind) + + t.Setenv("VESPA_VALGRIND_OPT", "--tool=callgrind") + spec.ConfigureValgrind() + assert.Equal(t, true, spec.shouldUseValgrind) + assert.Equal(t, true, spec.shouldUseCallgrind) + + argv = spec.prependValgrind([]string{"/bin/myprog", "-c", "cfgid"}) + trace.Trace("argv:", argv) + assert.Equal(t, 6, len(argv)) + assert.Equal(t, "valgrind", argv[0]) + assert.Equal(t, "--tool=callgrind", argv[1]) + assert.Equal(t, "/bin/myprog", argv[3]) + + useMock("no-valgrind", "valgrind") + spec.ConfigureValgrind() + assert.Equal(t, false, spec.shouldUseValgrind) + assert.Equal(t, false, spec.shouldUseCallgrind) +} -- cgit v1.2.3