Fixed: Fixed an issue where there could be a race condition during app update.

This commit is contained in:
kay.one 2012-02-26 13:22:35 -08:00
commit 39be4c567d
3 changed files with 16 additions and 7 deletions

View file

@ -47,7 +47,7 @@ namespace NzbDrone.Core.Jobs
}
public virtual void Start(ProgressNotification notification, int targetId, int secondaryTargetId)
{
{
notification.CurrentMessage = "Checking for updates";
var updatePackage = _updateProvider.GetAvilableUpdate(_enviromentProvider.Version);
@ -82,12 +82,14 @@ namespace NzbDrone.Core.Jobs
logger.Info("Starting update client");
var startInfo = new ProcessStartInfo
{
FileName = _enviromentProvider.GetUpdateClientExePath(),
Arguments = string.Format("{0} {1}", _enviromentProvider.NzbDroneProcessIdFromEnviroment, _configFileProvider.Guid)
};
FileName = _enviromentProvider.GetUpdateClientExePath(),
Arguments = string.Format("{0} {1}", _enviromentProvider.NzbDroneProcessIdFromEnviroment, _configFileProvider.Guid)
};
_processProvider.Start(startInfo);
var process = _processProvider.Start(startInfo);
notification.CurrentMessage = "Update in progress. NzbDrone will restart shortly.";
_processProvider.WaitForExit(process);
}
}
}