5fea7c3ae6
* remove some try catches choking all exceptions * rename ExceptionExtension to ReportAsWarning, show full stack instead of just message * dotnet-migrate try catch clean-up * fix migration test failures
78 lines
2.7 KiB
C#
78 lines
2.7 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.IO;
|
|
using FluentAssertions;
|
|
using Microsoft.DotNet.Tools.Test.Utilities;
|
|
using Xunit;
|
|
|
|
namespace Microsoft.DotNet.Cli.Utils.Tests
|
|
{
|
|
public class GivenAppThrowingException : TestBase
|
|
{
|
|
[Fact]
|
|
public void ItShowsStackTraceWhenRun()
|
|
{
|
|
var root = TestAssets.Get("NonRestoredTestProjects", "AppThrowingException")
|
|
.CreateInstance()
|
|
.WithSourceFiles()
|
|
.Root;
|
|
|
|
var appRoot = Path.Combine(root.FullName, "App");
|
|
|
|
new RestoreCommand()
|
|
.WithWorkingDirectory(appRoot)
|
|
.Execute()
|
|
.Should().Pass();
|
|
|
|
string msg1 = "Unhandled Exception: AppThrowing.MyException: "
|
|
+ "Exception of type 'AppThrowing.MyException' was thrown.";
|
|
string msg2 = "at AppThrowing.MyException.Main(String[] args)";
|
|
new RunCommand()
|
|
.WithWorkingDirectory(appRoot)
|
|
.ExecuteWithCapturedOutput()
|
|
.Should().Fail()
|
|
.And.HaveStdErrContaining(msg1)
|
|
.And.HaveStdErrContaining(msg2);
|
|
}
|
|
|
|
[Fact]
|
|
public void ItShowsStackTraceWhenRunAsTool()
|
|
{
|
|
var root = TestAssets.Get("NonRestoredTestProjects", "AppThrowingException")
|
|
.CreateInstance()
|
|
.WithSourceFiles()
|
|
.Root;
|
|
|
|
var appRoot = Path.Combine(root.FullName, "App");
|
|
|
|
new RestoreCommand()
|
|
.WithWorkingDirectory(appRoot)
|
|
.Execute()
|
|
.Should().Pass();
|
|
|
|
new PackCommand()
|
|
.WithWorkingDirectory(appRoot)
|
|
.Execute("-o ../pkgs")
|
|
.Should()
|
|
.Pass();
|
|
|
|
var appWithToolDepRoot = Path.Combine(root.FullName, "AppDependingOnOtherAsTool");
|
|
|
|
new RestoreCommand()
|
|
.WithWorkingDirectory(appWithToolDepRoot)
|
|
.Execute()
|
|
.Should().Pass();
|
|
|
|
string msg1 = "Unhandled Exception: AppThrowing.MyException: "
|
|
+ "Exception of type 'AppThrowing.MyException' was thrown.";
|
|
string msg2 = "at AppThrowing.MyException.Main(String[] args)";
|
|
new TestCommand("dotnet")
|
|
.WithWorkingDirectory(appWithToolDepRoot)
|
|
.ExecuteWithCapturedOutput("throwingtool")
|
|
.Should().Fail()
|
|
.And.HaveStdErrContaining(msg1)
|
|
.And.HaveStdErrContaining(msg2);
|
|
}
|
|
}
|
|
}
|