diff --git a/test/Microsoft.TestPlatform.CrossPlatEngine.UnitTests/MultiTestRunFinalization/MultiTestRunFinalizationManagerTests.cs b/test/Microsoft.TestPlatform.CrossPlatEngine.UnitTests/MultiTestRunFinalization/MultiTestRunFinalizationManagerTests.cs index 5a681f38c4..094d26fa05 100644 --- a/test/Microsoft.TestPlatform.CrossPlatEngine.UnitTests/MultiTestRunFinalization/MultiTestRunFinalizationManagerTests.cs +++ b/test/Microsoft.TestPlatform.CrossPlatEngine.UnitTests/MultiTestRunFinalization/MultiTestRunFinalizationManagerTests.cs @@ -392,20 +392,27 @@ public async Task FinalizeMultiTestRunAsync_ShouldReturnNullThroughEventsHandler mockAttachmentHandler1.Setup(h => h.HandleDataCollectionAttachmentSets(It.IsAny>(), It.IsAny())).Returns((ICollection i1, CancellationToken cancellation) => { - for (int i = 0; i < 1000; ++i) - { - Task.Delay(100); - Console.WriteLine($"Iteration: {i}"); + try + { + for (int i = 0; i < 1000; ++i) + { + Task.Delay(100).Wait(); + Console.WriteLine($"Iteration: {i}"); - if (cancellation.IsCancellationRequested) break; + cancellation.ThrowIfCancellationRequested(); - if (i == 3) - { - cancellationTokenSource.Cancel(); + if (i == 3) + { + cancellationTokenSource.Cancel(); + Task.Delay(500).Wait(); + } } } - - innerTaskCompletionSource.TrySetResult(null); + finally + { + innerTaskCompletionSource.TrySetResult(null); + } + return outputAttachments; });