diff --git a/pkg/sensors/tracing/kprobe_test.go b/pkg/sensors/tracing/kprobe_test.go index 5ecc0d2902b..6f283fc57b6 100644 --- a/pkg/sensors/tracing/kprobe_test.go +++ b/pkg/sensors/tracing/kprobe_test.go @@ -3886,6 +3886,50 @@ func TestKprobeMatchBinaries(t *testing.T) { }) } +func TestKprobeMatchBinariesPrefixLargePath(t *testing.T) { + if !kernels.EnableLargeProgs() { + t.Skip() + } + 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) {