From dc69517264471ffb458d325a18f74e694cac0a3a Mon Sep 17 00:00:00 2001 From: Jiri Olsa Date: Mon, 4 Dec 2023 09:44:34 +0000 Subject: [PATCH] tetragon: Move TestKprobeSigkill functionality to testSigkill function Moving TestKprobeSigkill functionality to testSigkill function, so it can be used be following change. Signed-off-by: Jiri Olsa --- pkg/sensors/tracing/kprobe_sigkill_test.go | 45 ++++++++++++---------- 1 file changed, 25 insertions(+), 20 deletions(-) diff --git a/pkg/sensors/tracing/kprobe_sigkill_test.go b/pkg/sensors/tracing/kprobe_sigkill_test.go index 621a6cdcb51..ec5bfa15141 100644 --- a/pkg/sensors/tracing/kprobe_sigkill_test.go +++ b/pkg/sensors/tracing/kprobe_sigkill_test.go @@ -11,6 +11,7 @@ import ( "testing" "github.com/cilium/tetragon/api/v1/tetragon" + "github.com/cilium/tetragon/api/v1/tetragon/codegen/eventchecker" ec "github.com/cilium/tetragon/api/v1/tetragon/codegen/eventchecker" "github.com/cilium/tetragon/pkg/arch" "github.com/cilium/tetragon/pkg/jsonchecker" @@ -25,11 +26,7 @@ import ( _ "github.com/cilium/tetragon/pkg/sensors/exec" ) -func TestKprobeSigkill(t *testing.T) { - if !kernels.MinKernelVersion("5.3.0") { - t.Skip("sigkill requires at least 5.3.0 version") - } - +func testSigkill(t *testing.T, makeSpecFile func(pid string) string, checker *eventchecker.UnorderedEventChecker) { var doneWG, readyWG sync.WaitGroup defer doneWG.Wait() @@ -55,19 +52,6 @@ func TestKprobeSigkill(t *testing.T) { return pidStr } - // makeSpecFile creates a new spec file bsed on the template, and the provided arguments - makeSpecFile := func(pid string) string { - data := map[string]string{ - "MatchedPID": pid, - "NamespacePID": "false", - } - specName, err := testutils.GetSpecFromTemplate("sigkill.yaml.tmpl", data) - if err != nil { - t.Fatal(err) - } - return specName - } - if err := testCmd.Start(); err != nil { t.Fatal(err) } @@ -94,6 +78,28 @@ func TestKprobeSigkill(t *testing.T) { t.Fatalf("command failed with %s. Context error: %s", err, ctx.Err()) } + err = jsonchecker.JsonTestCheck(t, checker) + assert.NoError(t, err) +} + +func TestKprobeSigkill(t *testing.T) { + if !kernels.MinKernelVersion("5.3.0") { + t.Skip("sigkill requires at least 5.3.0 version") + } + + // makeSpecFile creates a new spec file bsed on the template, and the provided arguments + makeSpecFile := func(pid string) string { + data := map[string]string{ + "MatchedPID": pid, + "NamespacePID": "false", + } + specName, err := testutils.GetSpecFromTemplate("sigkill.yaml.tmpl", data) + if err != nil { + t.Fatal(err) + } + return specName + } + kpChecker := ec.NewProcessKprobeChecker(""). WithFunctionName(sm.Full(arch.AddSyscallPrefixTestHelper(t, "sys_lseek"))). WithArgs(ec.NewKprobeArgumentListMatcher(). @@ -104,8 +110,7 @@ func TestKprobeSigkill(t *testing.T) { WithAction(tetragon.KprobeAction_KPROBE_ACTION_SIGKILL) checker := ec.NewUnorderedEventChecker(kpChecker) - err = jsonchecker.JsonTestCheck(t, checker) - assert.NoError(t, err) + testSigkill(t, makeSpecFile, checker) } func testUnprivilegedUsernsKill(t *testing.T, pidns bool) {