Skip to content

Commit

Permalink
Mitigate race condition in EventSource_ConnectionPoolAtMaxConnections…
Browse files Browse the repository at this point in the history
…_LogsRequestLeftQueue test

There is a unavoidable race condition between updating event counters and reading their values in WaitForEventCountersAsync. It waits for at least 2 sets of EventCounter event groups to ensure the last group is captured after any actual work (tests check that counters reset back to 0 if there is nothing happening).
Since it looks for `requests-started` which occurs before `http11-requests-queue-duration` event, what it may see is only the tail of the last group and the start of the second, without waiting for a fresh `http11-requests-queue-duration`. In this, the assert `Assert.Equal(0, http11requestQueueDurations[^1])` on the line 549 will see a non-zero counter value and fail.

This PR changes the condition to `< 3`  to guarantee there is at least one full group of events in the window.

Co-authored by @MihaZupan 

Fixes #46073
  • Loading branch information
alnikola authored Jul 15, 2021
1 parent 90b8ddd commit 2700b1c
Showing 1 changed file with 1 addition and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -673,7 +673,7 @@ private static async Task WaitForEventCountersAsync(ConcurrentQueue<(EventWritte
DateTime startTime = DateTime.UtcNow;
int startCount = events.Count;

while (events.Skip(startCount).Count(e => IsRequestsStartedEventCounter(e.Event)) < 2)
while (events.Skip(startCount).Count(e => IsRequestsStartedEventCounter(e.Event)) < 3)
{
if (DateTime.UtcNow.Subtract(startTime) > TimeSpan.FromSeconds(30))
throw new TimeoutException($"Timed out waiting for EventCounters");
Expand Down

0 comments on commit 2700b1c

Please sign in to comment.