From f26e8f5915530431794cb5d5d881c0a616bb0241 Mon Sep 17 00:00:00 2001 From: Andrei Fedotov Date: Tue, 23 Jul 2024 19:08:47 +0300 Subject: [PATCH] Add TestKprobeMatchBinariesPrefixLargePath Adding test that has Prefix operator in matchBinaries selector. The file path of test binary (direct-write-tester) being executed is larger than 256 bytes. Signed-off-by: Andrei Fedotov --- pkg/sensors/tracing/kprobe_test.go | 45 ++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) diff --git a/pkg/sensors/tracing/kprobe_test.go b/pkg/sensors/tracing/kprobe_test.go index 5ecc0d2902b..3bde63d896d 100644 --- a/pkg/sensors/tracing/kprobe_test.go +++ b/pkg/sensors/tracing/kprobe_test.go @@ -3886,6 +3886,51 @@ func TestKprobeMatchBinaries(t *testing.T) { }) } +func TestKprobeMatchBinariesPrefixLargePath(t *testing.T) { + // Test executable path length greater than 256 + if !kernels.EnableLargeProgs() { + t.Skip(skipMatchBinariesPrefix) + } + repoBinPath := testutils.RepoRootPath("contrib/tester-progs/direct-write-tester") + tmpDir, err := os.MkdirTemp("/tmp", "tetragon-matchbinlarge-*") + assert.NoError(t, err) + defer os.RemoveAll(tmpDir) + + tmpDirLarge := tmpDir + "/" + strings.Repeat("a", 250) + err = os.Mkdir(tmpDirLarge, 0755) + assert.NoError(t, err) + + tmpBinaryPath := tmpDirLarge + "/direct-write-tester" + + err = exec.Command("cp", repoBinPath, tmpBinaryPath).Run() + assert.NoError(t, err) + + var doneWG, readyWG sync.WaitGroup + defer doneWG.Wait() + + ctx, cancel := context.WithTimeout(context.Background(), tus.Conf().CmdWaitTime) + defer cancel() + + createCrdFile(t, getMatchBinariesCrd("Prefix", []string{tmpDir})) + + obs, err := observertesthelper.GetDefaultObserverWithFile(t, ctx, testConfigFile, tus.Conf().TetragonLib, observertesthelper.WithMyPid()) + if err != nil { + t.Fatalf("GetDefaultObserverWithFile error: %s", err) + } + observertesthelper.LoopEvents(ctx, t, &doneWG, &readyWG, obs) + readyWG.Wait() + + if err := exec.Command(tmpBinaryPath, tmpDirLarge+"/test").Run(); err != nil { + t.Fatalf("failed to run direct-write-tester: %s", err) + } + + checker := ec.NewUnorderedEventChecker(ec.NewProcessKprobeChecker(""). + WithProcess(ec.NewProcessChecker().WithBinary(sm.Full(tmpBinaryPath))). + WithFunctionName(sm.Full("fd_install"))) + err = jsonchecker.JsonTestCheck(t, checker) + assert.NoError(t, err) +} + // matchBinariesPerfringTest checks that the matchBinaries do correctly // filter the events i.e. it checks that no other events appear. func matchBinariesPerfringTest(t *testing.T, operator string, values []string) {