Fixed: Make ProcessProviderTests less flaky

pull/928/head
ta264 5 years ago committed by Qstick
parent ee7d47d044
commit 1a0b95de03

@ -3,6 +3,7 @@ using System.ComponentModel;
using System.Diagnostics; using System.Diagnostics;
using System.IO; using System.IO;
using System.Linq; using System.Linq;
using System.Threading;
using FluentAssertions; using FluentAssertions;
using NUnit.Framework; using NUnit.Framework;
using NzbDrone.Common.Model; using NzbDrone.Common.Model;
@ -12,6 +13,8 @@ using NzbDrone.Test.Dummy;
namespace NzbDrone.Common.Test namespace NzbDrone.Common.Test
{ {
// We don't want one tests setup killing processes used in another
[NonParallelizable]
[TestFixture] [TestFixture]
public class ProcessProviderTests : TestBase<ProcessProvider> public class ProcessProviderTests : TestBase<ProcessProvider>
{ {
@ -63,9 +66,25 @@ namespace NzbDrone.Common.Test
ExceptionVerification.ExpectedWarns(1); ExceptionVerification.ExpectedWarns(1);
} }
[Test]
public void should_be_able_to_start_process()
{
var process = StartDummyProcess();
var check = Subject.GetProcessById(process.Id);
check.Should().NotBeNull();
process.Refresh();
process.HasExited.Should().BeFalse();
process.Kill();
process.WaitForExit();
process.HasExited.Should().BeTrue();
}
[Test] [Test]
[Platform(Exclude="MacOsX")] [Platform(Exclude="MacOsX")]
public void Should_be_able_to_start_process() public void exists_should_find_running_process()
{ {
var process = StartDummyProcess(); var process = StartDummyProcess();
@ -94,8 +113,22 @@ namespace NzbDrone.Common.Test
private Process StartDummyProcess() private Process StartDummyProcess()
{ {
var processStarted = new ManualResetEventSlim();
var path = Path.Combine(TestContext.CurrentContext.TestDirectory, DummyApp.DUMMY_PROCCESS_NAME + ".exe"); var path = Path.Combine(TestContext.CurrentContext.TestDirectory, DummyApp.DUMMY_PROCCESS_NAME + ".exe");
return Subject.Start(path); var process = Subject.Start(path, onOutputDataReceived: (string data) => {
if (data.StartsWith("Dummy process. ID:"))
{
processStarted.Set();
}
});
if (!processStarted.Wait(2000))
{
Assert.Fail("Failed to start process within 2 sec");
}
return process;
} }
[Test] [Test]

Loading…
Cancel
Save