diff options
| author | Paul Buetow <paul@buetow.org> | 2026-05-19 15:40:34 +0300 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-05-19 15:40:34 +0300 |
| commit | 03a3513e0d8366fb2d04e3d055a3a98b63b9e708 (patch) | |
| tree | 43e3924d9537c73369ac599a360e948cf6216c7b /internal/eventloop_socket_test.go | |
| parent | 71ef23ae16b0e310e66f3bf622cebefb9ec6b208 (diff) | |
v6: cover plain accept integration and filter path
Diffstat (limited to 'internal/eventloop_socket_test.go')
| -rw-r--r-- | internal/eventloop_socket_test.go | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/internal/eventloop_socket_test.go b/internal/eventloop_socket_test.go index 19c1fa8..59e995d 100644 --- a/internal/eventloop_socket_test.go +++ b/internal/eventloop_socket_test.go @@ -139,6 +139,40 @@ func TestHandleAcceptExitTracksAcceptedFd(t *testing.T) { verifyFileDescriptor(t, el, 77, "socket:1:1:0") } +func TestHandleAcceptExitAppliesPairFilter(t *testing.T) { + el := mustNewEventLoop(t, eventLoopConfig{ + filter: globalfilter.Filter{ + Syscall: &globalfilter.StringFilter{Pattern: "openat"}, + }, + }) + + el.fdState().set(11, file.NewFd(11, "socket:1:1:0", -1)) + + enter := &types.AcceptEvent{ + EventType: types.ENTER_ACCEPT_EVENT, + TraceId: types.SYS_ENTER_ACCEPT, + Time: 100, + Pid: 91, + Tid: 92, + Fd: 11, + Ret: -1, + } + exit := &types.AcceptEvent{ + EventType: types.EXIT_ACCEPT_EVENT, + TraceId: types.SYS_EXIT_ACCEPT, + Time: 200, + Pid: 91, + Tid: 92, + Fd: -1, + Ret: 77, + } + ep := &event.Pair{EnterEv: enter, ExitEv: exit} + + if ok := el.handleAcceptExit(ep, enter); ok { + t.Fatal("handleAcceptExit should reject pair due to filter mismatch") + } +} + func TestInitRawHandlersRegistersSocketEvents(t *testing.T) { el := mustNewEventLoop(t, eventLoopConfig{}) if _, ok := el.rawHandlers[types.ENTER_SOCKET_EVENT]; !ok { |
