From 461a22bccb43263cfbf5674fe635f768735fdf86 Mon Sep 17 00:00:00 2001 From: Dean Herbert Date: Tue, 21 Feb 2017 13:52:52 +0900 Subject: [PATCH] Add resiliency to update process when delta patching fails. --- osu.Desktop/Overlays/VersionManager.cs | 57 +++++++++++++++++--------- 1 file changed, 37 insertions(+), 20 deletions(-) diff --git a/osu.Desktop/Overlays/VersionManager.cs b/osu.Desktop/Overlays/VersionManager.cs index c06b4cce10..a853c375ca 100644 --- a/osu.Desktop/Overlays/VersionManager.cs +++ b/osu.Desktop/Overlays/VersionManager.cs @@ -1,6 +1,7 @@ // Copyright (c) 2007-2017 ppy Pty Ltd . // Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE +using System.ComponentModel; using System.Diagnostics; using osu.Framework.Allocation; using osu.Framework.Graphics; @@ -23,7 +24,7 @@ namespace osu.Desktop.Overlays public class VersionManager : OverlayContainer { private UpdateManager updateManager; - private NotificationManager notification; + private NotificationManager notificationManager; AssemblyName assembly = Assembly.GetEntryAssembly().GetName(); @@ -36,7 +37,7 @@ namespace osu.Desktop.Overlays [BackgroundDependencyLoader] private void load(NotificationManager notification, OsuColour colours, TextureStore textures) { - this.notification = notification; + this.notificationManager = notification; AutoSizeAxes = Axes.Both; Anchor = Anchor.BottomCentre; @@ -115,43 +116,59 @@ namespace osu.Desktop.Overlays updateManager?.Dispose(); } - private async void updateChecker() + private async void updateChecker(bool useDeltaPatching = true, UpdateProgressNotification notification = null) { try { - updateManager = await UpdateManager.GitHubUpdateManager(@"https://github.com/ppy/osu", @"osulazer", null, null, true); - var info = await updateManager.CheckForUpdate(); + if (updateManager == null) updateManager = await UpdateManager.GitHubUpdateManager(@"https://github.com/ppy/osu", @"osulazer", null, null, true); + + var info = await updateManager.CheckForUpdate(!useDeltaPatching); if (info.ReleasesToApply.Count > 0) { - ProgressNotification n = new UpdateProgressNotification + if (notification == null) { - Text = @"Downloading update..." - }; + notification = new UpdateProgressNotification { State = ProgressNotificationState.Active }; + Schedule(() => notificationManager.Post(notification)); + } + Schedule(() => { - notification.Post(n); - n.State = ProgressNotificationState.Active; - }); - await updateManager.DownloadReleases(info.ReleasesToApply, p => Schedule(() => n.Progress = p / 100f)); - Schedule(() => - { - n.Progress = 0; - n.Text = @"Installing update..."; + notification.Progress = 0; + notification.Text = @"Downloading update..."; }); - await updateManager.ApplyReleases(info, p => Schedule(() => n.Progress = p / 100f)); - Schedule(() => n.State = ProgressNotificationState.Completed); + await updateManager.DownloadReleases(info.ReleasesToApply, p => Schedule(() => notification.Progress = p / 100f)); + + Schedule(() => + { + notification.Progress = 0; + notification.Text = @"Installing update..."; + }); + + try + { + await updateManager.ApplyReleases(info, p => Schedule(() => notification.Progress = p / 100f)); + } + catch (Win32Exception) + { + //could fail if deltas are unavailable for full update path (https://github.com/Squirrel/Squirrel.Windows/issues/959) + //try again without deltas. + updateChecker(false, notification); + return; + } + + Schedule(() => notification.State = ProgressNotificationState.Completed); } else { //check again every 30 minutes. - Scheduler.AddDelayed(updateChecker, 60000 * 30); + Scheduler.AddDelayed(() => updateChecker(), 60000 * 30); } } catch (HttpRequestException) { //check again every 30 minutes. - Scheduler.AddDelayed(updateChecker, 60000 * 30); + Scheduler.AddDelayed(() => updateChecker(), 60000 * 30); } }