6d57ca7e14
* WIP migrate tests * WIP fixing more tests * WIP fix test build break * Test results files are now trx * Get CI to pass until we get an xunit xml logger * Added DotNetTestPJ since that was needed for one test * Fix build break * Forgot to add DotNetTestPJ as a build task * Need to restore project.json for the project used in ubuntu test * Restore PJ for ubuntu test * Switch the Ubuntu test to csproj based
141 lines
5.4 KiB
C#
141 lines
5.4 KiB
C#
// Copyright (c) .NET Foundation and contributors. All rights reserved.
|
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
using System.Linq;
|
|
using Microsoft.DotNet.TestFramework;
|
|
using Microsoft.DotNet.Tools.Test.Utilities;
|
|
using Xunit;
|
|
using System.Threading.Tasks;
|
|
using FluentAssertions;
|
|
|
|
namespace Microsoft.DotNet.Kestrel.Tests
|
|
{
|
|
public class DotnetTest : TestBase
|
|
{
|
|
private const string KestrelSampleBase = "KestrelSample";
|
|
private const string KestrelPortable = "KestrelPortable";
|
|
private const string KestrelStandalone = "KestrelStandalone";
|
|
|
|
[Fact]
|
|
public void ItRunsKestrelPortableAfterBuild()
|
|
{
|
|
TestInstance instance = TestAssetsManager.CreateTestInstance(KestrelSampleBase)
|
|
.WithLockFiles();
|
|
|
|
var url = NetworkHelper.GetLocalhostUrlWithFreePort();
|
|
var args = $"{url} {Guid.NewGuid().ToString()}";
|
|
var dotnetCommand = new DotnetCommand();
|
|
var output = Build(Path.Combine(instance.TestRoot, KestrelPortable));
|
|
|
|
try
|
|
{
|
|
dotnetCommand.ExecuteAsync($"{output} {args}");
|
|
NetworkHelper.IsServerUp(url).Should().BeTrue($"Unable to connect to kestrel server - {KestrelPortable} @ {url}");
|
|
NetworkHelper.TestGetRequest(url, args);
|
|
}
|
|
finally
|
|
{
|
|
dotnetCommand.KillTree();
|
|
}
|
|
}
|
|
|
|
[Fact]
|
|
public void ItRunsKestrelStandaloneAfterBuild()
|
|
{
|
|
TestInstance instance = TestAssetsManager.CreateTestInstance(KestrelSampleBase)
|
|
.WithLockFiles();
|
|
|
|
var url = NetworkHelper.GetLocalhostUrlWithFreePort();
|
|
var args = $"{url} {Guid.NewGuid().ToString()}";
|
|
var dotnetCommand = new DotnetCommand();
|
|
var output = Build(Path.Combine(instance.TestRoot, KestrelStandalone));
|
|
|
|
try
|
|
{
|
|
dotnetCommand.ExecuteAsync($"{output} {args}");
|
|
NetworkHelper.IsServerUp(url).Should().BeTrue($"Unable to connect to kestrel server - {KestrelStandalone} @ {url}");
|
|
NetworkHelper.TestGetRequest(url, args);
|
|
}
|
|
finally
|
|
{
|
|
dotnetCommand.KillTree();
|
|
}
|
|
}
|
|
|
|
[Fact]
|
|
public void ItRunsKestrelPortableAfterPublish()
|
|
{
|
|
TestInstance instance = TestAssetsManager.CreateTestInstance(KestrelSampleBase)
|
|
.WithLockFiles();
|
|
|
|
var url = NetworkHelper.GetLocalhostUrlWithFreePort();
|
|
var args = $"{url} {Guid.NewGuid().ToString()}";
|
|
var dotnetCommand = new DotnetCommand();
|
|
var output = Publish(Path.Combine(instance.TestRoot, KestrelPortable), true);
|
|
|
|
try
|
|
{
|
|
dotnetCommand.ExecuteAsync($"{output} {args}");
|
|
NetworkHelper.IsServerUp(url).Should().BeTrue($"Unable to connect to kestrel server - {KestrelPortable} @ {url}");
|
|
NetworkHelper.TestGetRequest(url, args);
|
|
}
|
|
finally
|
|
{
|
|
dotnetCommand.KillTree();
|
|
}
|
|
}
|
|
|
|
[Fact]
|
|
public void ItRunsKestrelStandaloneAfterPublish()
|
|
{
|
|
TestInstance instance = TestAssetsManager.CreateTestInstance(KestrelSampleBase)
|
|
.WithLockFiles();
|
|
|
|
var url = NetworkHelper.GetLocalhostUrlWithFreePort();
|
|
var args = $"{url} {Guid.NewGuid().ToString()}";
|
|
var output = Publish(Path.Combine(instance.TestRoot, KestrelStandalone), false);
|
|
var command = new TestCommand(output);
|
|
|
|
try
|
|
{
|
|
command.ExecuteAsync($"{args}");
|
|
NetworkHelper.IsServerUp(url).Should().BeTrue($"Unable to connect to kestrel server - {KestrelStandalone} @ {url}");
|
|
NetworkHelper.TestGetRequest(url, args);
|
|
}
|
|
finally
|
|
{
|
|
command.KillTree();
|
|
}
|
|
}
|
|
|
|
private static string Build(string testRoot)
|
|
{
|
|
string appName = Path.GetFileName(testRoot);
|
|
|
|
var result = new BuildCommand(
|
|
projectPath: testRoot)
|
|
.ExecuteWithCapturedOutput();
|
|
|
|
result.Should().Pass();
|
|
|
|
// the correct build assembly is next to its deps.json file
|
|
var depsJsonFile = Directory.EnumerateFiles(testRoot, appName + FileNameSuffixes.DepsJson, SearchOption.AllDirectories).First();
|
|
return Path.Combine(Path.GetDirectoryName(depsJsonFile), appName + ".dll");
|
|
}
|
|
|
|
private static string Publish(string testRoot, bool isPortable)
|
|
{
|
|
string appName = Path.GetFileName(testRoot);
|
|
|
|
var publishCmd = new PublishCommand(projectPath: testRoot, output: Path.Combine(testRoot, "bin"));
|
|
var result = publishCmd.ExecuteWithCapturedOutput();
|
|
result.Should().Pass();
|
|
|
|
var publishDir = publishCmd.GetOutputDirectory(portable: isPortable).FullName;
|
|
return Path.Combine(publishDir, appName + (isPortable ? ".dll" : FileNameSuffixes.CurrentPlatform.Exe));
|
|
}
|
|
}
|
|
}
|