summaryrefslogtreecommitdiff
path: root/internal
diff options
context:
space:
mode:
Diffstat (limited to 'internal')
-rw-r--r--internal/eventloop_socket_test.go34
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 {