mirror of
https://github.com/velopack/velopack.git
synced 2025-10-25 15:19:22 +00:00
Update tests
This commit is contained in:
@@ -1,8 +1,35 @@
|
|||||||
using System.Windows;
|
using System.Windows;
|
||||||
|
using Velopack;
|
||||||
|
|
||||||
namespace CSharpWpf
|
namespace CSharpWpf
|
||||||
{
|
{
|
||||||
public partial class App : Application
|
public partial class App : Application
|
||||||
{
|
{
|
||||||
|
public static MemoryLogger Log { get; private set; }
|
||||||
|
|
||||||
|
// Since WPF has an "automatic" Program.Main, we need to create our own.
|
||||||
|
// In order for this to work, you must also add the following to your .csproj:
|
||||||
|
// <StartupObject>CSharpWpf.App</StartupObject>
|
||||||
|
[STAThread]
|
||||||
|
private static void Main(string[] args)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
// Logging is essential for debugging! Ideally you should write it to a file.
|
||||||
|
Log = new MemoryLogger();
|
||||||
|
|
||||||
|
// It's important to Run() the VelopackApp as early as possible in app startup.
|
||||||
|
VelopackApp.Build()
|
||||||
|
.WithFirstRun((v) => { /* Your first run code here */ })
|
||||||
|
.Run(Log);
|
||||||
|
|
||||||
|
// We can now launch the WPF application as normal.
|
||||||
|
var app = new App();
|
||||||
|
app.InitializeComponent();
|
||||||
|
app.Run();
|
||||||
|
|
||||||
|
} catch (Exception ex) {
|
||||||
|
MessageBox.Show("Unhandled exception: " + ex.ToString());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,9 +10,14 @@
|
|||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<!-- This overrides the default Program.Main that WPF creates for you, and allows you to add VelopackApp -->
|
<!-- This overrides the default Program.Main that WPF creates for you, and allows you to add VelopackApp -->
|
||||||
<StartupObject>CSharpWpf.Program</StartupObject>
|
<StartupObject>CSharpWpf.App</StartupObject>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<ApplicationDefinition Remove="App.xaml" />
|
||||||
|
<Page Include="App.xaml" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<!--Condition below is only needed to test this sample project against the local projects instead of the NuGet package. Remove it in your app.-->
|
<!--Condition below is only needed to test this sample project against the local projects instead of the NuGet package. Remove it in your app.-->
|
||||||
<PackageReference Include="Velopack" Version="0.*" Condition="$(UseLocalVelopack) == ''" />
|
<PackageReference Include="Velopack" Version="0.*" Condition="$(UseLocalVelopack) == ''" />
|
||||||
|
|||||||
@@ -15,10 +15,10 @@ namespace CSharpWpf
|
|||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
|
||||||
string updateUrl = SampleHelper.GetReleasesDir(); // replace with your update url
|
string updateUrl = SampleHelper.GetReleasesDir(); // replace with your update url
|
||||||
_um = new UpdateManager(updateUrl, logger: Program.Log);
|
_um = new UpdateManager(updateUrl, logger: App.Log);
|
||||||
|
|
||||||
TextLog.Text = Program.Log.ToString();
|
TextLog.Text = App.Log.ToString();
|
||||||
Program.Log.LogUpdated += LogUpdated;
|
App.Log.LogUpdated += LogUpdated;
|
||||||
UpdateStatus();
|
UpdateStatus();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -29,7 +29,7 @@ namespace CSharpWpf
|
|||||||
// ConfigureAwait(true) so that UpdateStatus() is called on the UI thread
|
// ConfigureAwait(true) so that UpdateStatus() is called on the UI thread
|
||||||
_update = await _um.CheckForUpdatesAsync().ConfigureAwait(true);
|
_update = await _um.CheckForUpdatesAsync().ConfigureAwait(true);
|
||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
Program.Log.LogError(ex, "Error checking for updates");
|
App.Log.LogError(ex, "Error checking for updates");
|
||||||
}
|
}
|
||||||
UpdateStatus();
|
UpdateStatus();
|
||||||
}
|
}
|
||||||
@@ -41,7 +41,7 @@ namespace CSharpWpf
|
|||||||
// ConfigureAwait(true) so that UpdateStatus() is called on the UI thread
|
// ConfigureAwait(true) so that UpdateStatus() is called on the UI thread
|
||||||
await _um.DownloadUpdatesAsync(_update, Progress).ConfigureAwait(true);
|
await _um.DownloadUpdatesAsync(_update, Progress).ConfigureAwait(true);
|
||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
Program.Log.LogError(ex, "Error downloading updates");
|
App.Log.LogError(ex, "Error downloading updates");
|
||||||
}
|
}
|
||||||
UpdateStatus();
|
UpdateStatus();
|
||||||
}
|
}
|
||||||
@@ -70,7 +70,7 @@ namespace CSharpWpf
|
|||||||
|
|
||||||
private void Working()
|
private void Working()
|
||||||
{
|
{
|
||||||
Program.Log.LogInformation("");
|
App.Log.LogInformation("");
|
||||||
BtnCheckUpdate.IsEnabled = false;
|
BtnCheckUpdate.IsEnabled = false;
|
||||||
BtnDownloadUpdate.IsEnabled = false;
|
BtnDownloadUpdate.IsEnabled = false;
|
||||||
BtnRestartApply.IsEnabled = false;
|
BtnRestartApply.IsEnabled = false;
|
||||||
|
|||||||
@@ -1,35 +0,0 @@
|
|||||||
using System.Windows;
|
|
||||||
using Velopack;
|
|
||||||
|
|
||||||
namespace CSharpWpf
|
|
||||||
{
|
|
||||||
// Since WPF has an "automatic" Program.Main, we need to create our own.
|
|
||||||
// In order for this to work, you must also add the following to your .csproj:
|
|
||||||
// <StartupObject>CSharpWpf.Program</StartupObject>
|
|
||||||
public class Program
|
|
||||||
{
|
|
||||||
public static MemoryLogger Log { get; private set; }
|
|
||||||
|
|
||||||
[STAThread]
|
|
||||||
public static void Main(string[] args)
|
|
||||||
{
|
|
||||||
try {
|
|
||||||
// Logging is essential for debugging! Ideally you should write it to a file.
|
|
||||||
Log = new MemoryLogger();
|
|
||||||
|
|
||||||
// It's important to Run() the VelopackApp as early as possible in app startup.
|
|
||||||
VelopackApp.Build()
|
|
||||||
.WithFirstRun((v) => { /* Your first run code here */ })
|
|
||||||
.Run(Log);
|
|
||||||
|
|
||||||
// We can now launch the WPF application as normal.
|
|
||||||
var app = new App();
|
|
||||||
app.InitializeComponent();
|
|
||||||
app.Run();
|
|
||||||
|
|
||||||
} catch (Exception ex) {
|
|
||||||
MessageBox.Show("Unhandled exception: " + ex.ToString());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -80,14 +80,19 @@ public class CompatUtilTests
|
|||||||
using var logger = GetCompat(out var compat);
|
using var logger = GetCompat(out var compat);
|
||||||
using var _1 = TempUtil.GetTempDirectory(out var dir);
|
using var _1 = TempUtil.GetTempDirectory(out var dir);
|
||||||
var sample = PathHelper.GetWpfSample();
|
var sample = PathHelper.GetWpfSample();
|
||||||
Exe.InvokeAndThrowIfNonZero(
|
string stdOut = Exe.InvokeAndThrowIfNonZero(
|
||||||
"dotnet",
|
"dotnet",
|
||||||
new string[] { "publish", "-o", dir },
|
new string[] { "publish", "-o", dir },
|
||||||
sample);
|
sample);
|
||||||
|
|
||||||
var path = Path.Combine(dir, "VelopackCSharpWpf.exe");
|
var path = Path.Combine(dir, "VelopackCSharpWpf.exe");
|
||||||
Assert.NotNull(compat.Verify(path));
|
Assert.NotNull(compat.Verify(path));
|
||||||
|
//We do not expect to see the warning about VelopackApp.Run() not being at the start of the main method
|
||||||
|
Assert.DoesNotContain(logger.Entries, logEntry =>
|
||||||
|
logEntry.LogLevel == LogLevel.Warning &&
|
||||||
|
logEntry.Message.Contains("VelopackApp.Run()")
|
||||||
|
);
|
||||||
|
|
||||||
var newPath = Path.Combine(dir, "VelopackCSharpWpf-asd2.exe");
|
var newPath = Path.Combine(dir, "VelopackCSharpWpf-asd2.exe");
|
||||||
File.Move(path, newPath);
|
File.Move(path, newPath);
|
||||||
Assert.NotNull(compat.Verify(newPath));
|
Assert.NotNull(compat.Verify(newPath));
|
||||||
|
|||||||
Reference in New Issue
Block a user