Merge branch 'upstart-update' into develop

pull/3113/head
Taloth Saldono 10 years ago
commit 527663e27e

@ -78,8 +78,11 @@ namespace NzbDrone.Update.UpdateEngine
var appType = _detectApplicationType.GetAppType(); var appType = _detectApplicationType.GetAppType();
try try
{
if (OsInfo.IsWindows)
{ {
_terminateNzbDrone.Terminate(processId); _terminateNzbDrone.Terminate(processId);
}
_backupAndRestore.Backup(installationFolder); _backupAndRestore.Backup(installationFolder);
_backupAppData.Backup(); _backupAppData.Backup();
@ -92,7 +95,7 @@ namespace NzbDrone.Update.UpdateEngine
_logger.Info("Copying new files to target folder"); _logger.Info("Copying new files to target folder");
_diskProvider.CopyFolder(_appFolderInfo.GetUpdatePackageFolder(), installationFolder); _diskProvider.CopyFolder(_appFolderInfo.GetUpdatePackageFolder(), installationFolder);
// Set executable flag on SOnarr app // Set executable flag on Sonarr app
if (OsInfo.IsOsx) if (OsInfo.IsOsx)
{ {
_diskProvider.SetPermissions(Path.Combine(installationFolder, "Sonarr"), "0755", null, null); _diskProvider.SetPermissions(Path.Combine(installationFolder, "Sonarr"), "0755", null, null);
@ -105,9 +108,33 @@ namespace NzbDrone.Update.UpdateEngine
} }
} }
finally finally
{
if (OsInfo.IsWindows)
{ {
_startNzbDrone.Start(appType, installationFolder); _startNzbDrone.Start(appType, installationFolder);
} }
else
{
_terminateNzbDrone.Terminate(processId);
_logger.Info("Waiting for external auto-restart.");
for (int i = 0; i < 5; i++)
{
System.Threading.Thread.Sleep(1000);
if (_processProvider.Exists(ProcessProvider.NZB_DRONE_PROCESS_NAME))
{
_logger.Info("Sonarr was restarted by external process.");
break;
}
}
if (!_processProvider.Exists(ProcessProvider.NZB_DRONE_PROCESS_NAME))
{
_startNzbDrone.Start(appType, installationFolder);
}
}
}
} }
} }

Loading…
Cancel
Save