diff --git a/src/NzbDrone.Core.Test/Messaging/Commands/CommandExecutorFixture.cs b/src/NzbDrone.Core.Test/Messaging/Commands/CommandExecutorFixture.cs index 33b61c523..fb79b04eb 100644 --- a/src/NzbDrone.Core.Test/Messaging/Commands/CommandExecutorFixture.cs +++ b/src/NzbDrone.Core.Test/Messaging/Commands/CommandExecutorFixture.cs @@ -18,7 +18,6 @@ public class CommandExecutorFixture : TestBase private CommandQueue _commandQueue; private Mock> _executorA; private Mock> _executorB; - private bool _commandExecuted = false; [SetUp] public void Setup() @@ -53,26 +52,34 @@ private void GivenCommandQueue() .Returns(_commandQueue.GetConsumingEnumerable); } - private void QueueAndWaitForExecution(CommandModel commandModel) + private void QueueAndWaitForExecution(CommandModel commandModel, bool waitPublish = false) { - Thread.Sleep(10); + var waitEventComplete = new ManualResetEventSlim(); + var waitEventPublish = new ManualResetEventSlim(); Mocker.GetMock() .Setup(s => s.Complete(It.Is(c => c == commandModel), It.IsAny())) - .Callback(() => _commandExecuted = true); + .Callback(() => waitEventComplete.Set()); Mocker.GetMock() .Setup(s => s.Fail(It.Is(c => c == commandModel), It.IsAny(), It.IsAny())) - .Callback(() => _commandExecuted = true); + .Callback(() => waitEventComplete.Set()); + + Mocker.GetMock() + .Setup(s => s.PublishEvent(It.IsAny())) + .Callback(() => waitEventPublish.Set()); _commandQueue.Add(commandModel); - while (!_commandExecuted) + if (!waitEventComplete.Wait(2000)) { - Thread.Sleep(100); + Assert.Fail("Command did not Complete/Fail within 2 sec"); } - Thread.Sleep(10); + if (waitPublish && !waitEventPublish.Wait(500)) + { + Assert.Fail("Command did not Publish within 500 msec"); + } } [Test] @@ -138,8 +145,6 @@ public void broken_executor_should_publish_executed_event() VerifyEventPublished(); - Thread.Sleep(10); - ExceptionVerification.ExpectedErrors(1); } @@ -175,18 +180,17 @@ public void should_use_completion_message() QueueAndWaitForExecution(commandModel); Mocker.GetMock() - .Setup(s => s.Complete(It.Is(c => c == commandModel), commandA.CompletionMessage)) - .Callback(() => _commandExecuted = true); + .Verify(s => s.Complete(It.Is(c => c == commandModel), commandA.CompletionMessage), Times.Once()); } [Test] public void should_use_last_progress_message_if_completion_message_is_null() { GivenCommandQueue(); - var commandA = new CommandA(); + var commandB = new CommandB(); var commandModel = new CommandModel { - Body = commandA, + Body = commandB, Message = "Do work" }; @@ -195,8 +199,7 @@ public void should_use_last_progress_message_if_completion_message_is_null() QueueAndWaitForExecution(commandModel); Mocker.GetMock() - .Setup(s => s.Complete(It.Is(c => c == commandModel), commandModel.Message)) - .Callback(() => _commandExecuted = true); + .Verify(s => s.Complete(It.Is(c => c == commandModel), commandModel.Message), Times.Once()); } }