public void Start() { AppData = Path.Combine(TestContext.CurrentContext.TestDirectory, "_intg_" + TestBase.GetUID()); Directory.CreateDirectory(AppData); GenerateConfigFile(); string consoleExe; if (OsInfo.IsWindows) { consoleExe = "Radarr.Console.exe"; } else if (PlatformInfo.IsMono) { consoleExe = "Radarr.exe"; } else { consoleExe = "Radarr"; } if (BuildInfo.IsDebug) { var frameworkFolder = PlatformInfo.IsNetCore ? "netcoreapp3.1" : "net462"; Start(Path.Combine(TestContext.CurrentContext.TestDirectory, "..", "..", "_output", frameworkFolder, consoleExe)); } else { Start(Path.Combine(TestContext.CurrentContext.TestDirectory, "..", "bin", consoleExe)); } while (true) { _nzbDroneProcess.Refresh(); if (_nzbDroneProcess.HasExited) { Assert.Fail("Process has exited"); } var request = new RestRequest("system/status"); request.AddHeader("Authorization", ApiKey); request.AddHeader("X-Api-Key", ApiKey); var statusCall = _restClient.Get(request); if (statusCall.ResponseStatus == ResponseStatus.Completed) { TestContext.Progress.WriteLine($"Radarr {Port} is started. Running Tests"); return; } TestContext.Progress.WriteLine("Waiting for Radarr to start. Response Status : {0} [{1}] {2}", statusCall.ResponseStatus, statusCall.StatusDescription, statusCall.ErrorException.Message); Thread.Sleep(500); } }