|
|
|
@ -9,6 +9,7 @@ using NLog;
|
|
|
|
|
using NUnit.Framework;
|
|
|
|
|
using NzbDrone.Common.EnvironmentInfo;
|
|
|
|
|
using NzbDrone.Common.Processes;
|
|
|
|
|
using NzbDrone.Core.Configuration;
|
|
|
|
|
using RestSharp;
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Test.Common
|
|
|
|
@ -30,8 +31,11 @@ namespace NzbDrone.Test.Common
|
|
|
|
|
|
|
|
|
|
public void Start()
|
|
|
|
|
{
|
|
|
|
|
AppData = Path.Combine(TestContext.CurrentContext.TestDirectory, "_intg_" + DateTime.Now.Ticks);
|
|
|
|
|
AppData = Path.Combine(TestContext.CurrentContext.TestDirectory, "_intg_" + TestBase.GetUID());
|
|
|
|
|
Directory.CreateDirectory(AppData);
|
|
|
|
|
|
|
|
|
|
GenerateApiKey();
|
|
|
|
|
|
|
|
|
|
var sonarrConsoleExe = OsInfo.IsWindows ? "Sonarr.Console.exe" : "Sonarr.exe";
|
|
|
|
|
|
|
|
|
|
if (BuildInfo.IsDebug)
|
|
|
|
@ -52,8 +56,6 @@ namespace NzbDrone.Test.Common
|
|
|
|
|
Assert.Fail("Process has exited");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SetApiKey();
|
|
|
|
|
|
|
|
|
|
var request = new RestRequest("system/status");
|
|
|
|
|
request.AddHeader("Authorization", ApiKey);
|
|
|
|
|
request.AddHeader("X-Api-Key", ApiKey);
|
|
|
|
@ -74,13 +76,23 @@ namespace NzbDrone.Test.Common
|
|
|
|
|
|
|
|
|
|
public void KillAll()
|
|
|
|
|
{
|
|
|
|
|
if (_nzbDroneProcess != null)
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
if (_nzbDroneProcess != null)
|
|
|
|
|
{
|
|
|
|
|
_processProvider.Kill(_nzbDroneProcess.Id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_processProvider.KillAll(ProcessProvider.SONARR_CONSOLE_PROCESS_NAME);
|
|
|
|
|
_processProvider.KillAll(ProcessProvider.SONARR_PROCESS_NAME);
|
|
|
|
|
}
|
|
|
|
|
catch (InvalidOperationException)
|
|
|
|
|
{
|
|
|
|
|
_processProvider.Kill(_nzbDroneProcess.Id);
|
|
|
|
|
// May happen if the process closes while being closed
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_processProvider.KillAll(ProcessProvider.SONARR_CONSOLE_PROCESS_NAME);
|
|
|
|
|
_processProvider.KillAll(ProcessProvider.SONARR_PROCESS_NAME);
|
|
|
|
|
|
|
|
|
|
TestBase.DeleteTempFolder(AppData);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Start(string outputNzbdroneConsoleExe)
|
|
|
|
@ -100,33 +112,25 @@ namespace NzbDrone.Test.Common
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void SetApiKey()
|
|
|
|
|
private void GenerateApiKey()
|
|
|
|
|
{
|
|
|
|
|
var configFile = Path.Combine(AppData, "config.xml");
|
|
|
|
|
var attempts = 0;
|
|
|
|
|
|
|
|
|
|
while (ApiKey == null && attempts < 50)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
if (File.Exists(configFile))
|
|
|
|
|
{
|
|
|
|
|
var apiKeyElement = XDocument.Load(configFile)
|
|
|
|
|
.XPathSelectElement("Config/ApiKey");
|
|
|
|
|
if (apiKeyElement != null)
|
|
|
|
|
{
|
|
|
|
|
ApiKey = apiKeyElement.Value;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
catch (XmlException ex)
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine("Error getting API Key from XML file: " + ex.Message, ex);
|
|
|
|
|
}
|
|
|
|
|
// Generate and set the api key so we don't have to poll the config file
|
|
|
|
|
var apiKey = Guid.NewGuid().ToString().Replace("-", "");
|
|
|
|
|
|
|
|
|
|
attempts++;
|
|
|
|
|
Thread.Sleep(1000);
|
|
|
|
|
}
|
|
|
|
|
var xDoc = new XDocument(
|
|
|
|
|
new XDeclaration("1.0", "utf-8", "yes"),
|
|
|
|
|
new XElement(ConfigFileProvider.CONFIG_ELEMENT_NAME,
|
|
|
|
|
new XElement(nameof(ConfigFileProvider.ApiKey), apiKey)
|
|
|
|
|
)
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
var data = xDoc.ToString();
|
|
|
|
|
|
|
|
|
|
File.WriteAllText(configFile, data);
|
|
|
|
|
|
|
|
|
|
ApiKey = apiKey;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|