From 4adfb2c6bbb85b4cbe958910aa25f4a865a05ab8 Mon Sep 17 00:00:00 2001 From: mvarendorff Date: Mon, 7 Oct 2024 13:30:14 +0200 Subject: [PATCH] fix: flaky test --- src/Fluss.PostgreSQL.IntegrationTest/PostgreSQLTest.cs | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/Fluss.PostgreSQL.IntegrationTest/PostgreSQLTest.cs b/src/Fluss.PostgreSQL.IntegrationTest/PostgreSQLTest.cs index 502e4d0..f232a83 100644 --- a/src/Fluss.PostgreSQL.IntegrationTest/PostgreSQLTest.cs +++ b/src/Fluss.PostgreSQL.IntegrationTest/PostgreSQLTest.cs @@ -398,6 +398,9 @@ public async Task TestDatabaseNotificationForwarding() } }; + // Short delay to allow database trigger to register + await Task.Delay(1000); + // Publish an event using the first repository await repository1.Publish([ new EventEnvelope @@ -410,13 +413,13 @@ await repository1.Publish([ ]); // Wait for both event handlers to be triggered or timeout after 5 seconds - var timeoutTask = Task.Delay(TimeSpan.FromSeconds(5)); - var allTasks = await Task.WhenAny( + var timeoutTask = Task.Delay(TimeSpan.FromSeconds(10)); + var fasterTask = await Task.WhenAny( Task.WhenAll(eventRaised1.Task, eventRaised2.Task), timeoutTask ); - Assert.NotEqual(timeoutTask, allTasks); + Assert.True(timeoutTask != fasterTask, "Ran into timeout"); Assert.True(await eventRaised1.Task, "NewEvents event was not raised on the first repository"); Assert.True(await eventRaised2.Task, "NewEvents event was not raised on the second repository"); }