From b766efdd3547b4f8a0d0374dafb83b6832d6e43e Mon Sep 17 00:00:00 2001 From: Paul Buetow Date: Sat, 21 Feb 2026 13:13:14 +0200 Subject: Track io_uring setup fds in event loop Amp-Thread-ID: https://ampcode.com/threads/T-019c7fd9-5870-77b7-9909-3eb7550d17bb Co-authored-by: Amp --- internal/eventloop_test.go | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) (limited to 'internal/eventloop_test.go') diff --git a/internal/eventloop_test.go b/internal/eventloop_test.go index f608eab..f53e6f3 100644 --- a/internal/eventloop_test.go +++ b/internal/eventloop_test.go @@ -50,6 +50,7 @@ func TestEventloop(t *testing.T) { // NullEvent tests "SyncEventTest": makeSyncEventTestData(t), "IoUringSetupEventTest": makeIoUringSetupEventTestData(t), + "IoUringSetupFailureTest": makeIoUringSetupFailureTestData(t), // Dup3Event tests "Dup3EventTest": makeDup3EventTestData(t), "Dup3WithCloexecTest": makeDup3WithCloexecTestData(t), @@ -901,6 +902,38 @@ func makeIoUringSetupEventTestData(t *testing.T) (td testData) { if !exitEv.Equals(ep.ExitEv) { t.Errorf("Expected '%v' but got '%v'", exitEv, ep.ExitEv) } + if ep.File == nil { + t.Errorf("Expected io_uring fd to be tracked") + } + if _, ok := el.files[48]; !ok { + t.Errorf("Expected io_uring fd 48 to be tracked") + } + }) + + return td +} + +func makeIoUringSetupFailureTestData(t *testing.T) (td testData) { + enterEv, enterEvBytes := makeEnterNullEvent(t, defaulTime, defaultPid, defaultTid, types.SYS_ENTER_IO_URING_SETUP) + td.rawTracepoints = append(td.rawTracepoints, enterEvBytes) + + // io_uring_setup returns -1 on failure + exitEv, exitEvBytes := makeExitRetEvent(t, defaulTime+100, defaultPid, defaultTid, types.SYS_EXIT_IO_URING_SETUP, -1) + td.rawTracepoints = append(td.rawTracepoints, exitEvBytes) + + td.validates = append(td.validates, func(t *testing.T, el *eventLoop, ep *event.Pair) { + if !enterEv.Equals(ep.EnterEv) { + t.Errorf("Expected '%v' but got '%v'", enterEv, ep.EnterEv) + } + if !exitEv.Equals(ep.ExitEv) { + t.Errorf("Expected '%v' but got '%v'", exitEv, ep.ExitEv) + } + if ep.File != nil { + t.Errorf("Expected io_uring_setup failure to have no file tracked") + } + if len(el.files) != 0 { + t.Errorf("Expected no fds to be tracked after io_uring_setup failure") + } }) return td -- cgit v1.2.3