Adding new unit tests to cover TestRunner in DotnetTestParams.

This commit is contained in:
Livar Cunha 2016-08-23 11:26:37 -07:00
parent 0667e84069
commit dddfb6bb45
2 changed files with 101 additions and 15 deletions

View file

@ -6,6 +6,7 @@ using System.Collections.Generic;
using System.IO; using System.IO;
using Microsoft.DotNet.Cli.CommandLine; using Microsoft.DotNet.Cli.CommandLine;
using Microsoft.DotNet.Cli.Utils; using Microsoft.DotNet.Cli.Utils;
using Microsoft.DotNet.ProjectModel;
using Microsoft.DotNet.Tools.Common; using Microsoft.DotNet.Tools.Common;
using NuGet.Frameworks; using NuGet.Frameworks;
using static System.Int32; using static System.Int32;
@ -105,6 +106,16 @@ namespace Microsoft.DotNet.Tools.Test
Port = port; Port = port;
} }
if (_testRunner.HasValue())
{
if (!IsAssembly(ProjectOrAssemblyPath))
{
throw new InvalidOperationException("You can only specify a test runner with a dll.");
}
TestRunner = _testRunner.Value();
}
UnparsedFramework = _frameworkOption.Value(); UnparsedFramework = _frameworkOption.Value();
if (_frameworkOption.HasValue()) if (_frameworkOption.HasValue())
{ {
@ -127,6 +138,11 @@ namespace Microsoft.DotNet.Tools.Test
_app.Execute(args); _app.Execute(args);
} }
private bool IsAssembly(string projectOrAssemblyPath)
{
return projectOrAssemblyPath.EndsWith(".dll");
}
private void AddDotnetTestParameters() private void AddDotnetTestParameters()
{ {
_app.HelpOption("-?|-h|--help"); _app.HelpOption("-?|-h|--help");

View file

@ -19,16 +19,20 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
private const string Runtime = "some runtime"; private const string Runtime = "some runtime";
private const int ParentProcessId = 1010; private const int ParentProcessId = 1010;
private const int Port = 2314; private const int Port = 2314;
private const string TestRunner = "someTestRunner";
private const string PathToAssemblyUnderTest = "c:/some/path/assemblyUnderTest.dll";
private DotnetTestParams _dotnetTestFullParams; private readonly DotnetTestParams _dotnetTestFullParamsWithProjectJson;
private DotnetTestParams _emptyDotnetTestParams; private readonly DotnetTestParams _emptyDotnetTestParams;
private readonly DotnetTestParams _dotnetTestParamsWithAssembly;
public GivenThatWeWantToParseArgumentsForDotnetTest() public GivenThatWeWantToParseArgumentsForDotnetTest()
{ {
_dotnetTestFullParams = new DotnetTestParams(); _dotnetTestFullParamsWithProjectJson = new DotnetTestParams();
_dotnetTestParamsWithAssembly = new DotnetTestParams();
_emptyDotnetTestParams = new DotnetTestParams(); _emptyDotnetTestParams = new DotnetTestParams();
_dotnetTestFullParams.Parse(new[] _dotnetTestFullParamsWithProjectJson.Parse(new[]
{ {
ProjectJson, ProjectJson,
"--parentProcessId", ParentProcessId.ToString(), "--parentProcessId", ParentProcessId.ToString(),
@ -42,6 +46,12 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
"--additional-parameters", "additional-parameter-value" "--additional-parameters", "additional-parameter-value"
}); });
_dotnetTestParamsWithAssembly.Parse(new[]
{
PathToAssemblyUnderTest,
"--test-runner", TestRunner
});
_emptyDotnetTestParams.Parse(new string[] { }); _emptyDotnetTestParams.Parse(new string[] { });
} }
@ -54,7 +64,7 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
[Fact] [Fact]
public void It_sets_the_project_path_to_the_passed_value() public void It_sets_the_project_path_to_the_passed_value()
{ {
_dotnetTestFullParams.ProjectOrAssemblyPath.Should().Be(ProjectJson); _dotnetTestFullParamsWithProjectJson.ProjectOrAssemblyPath.Should().Be(ProjectJson);
} }
[Fact] [Fact]
@ -72,7 +82,7 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
[Fact] [Fact]
public void It_converts_the_parent_process_id_to_int_when_a_valid_one_is_passed() public void It_converts_the_parent_process_id_to_int_when_a_valid_one_is_passed()
{ {
_dotnetTestFullParams.ParentProcessId.Should().Be(ParentProcessId); _dotnetTestFullParamsWithProjectJson.ParentProcessId.Should().Be(ParentProcessId);
} }
[Fact] [Fact]
@ -96,7 +106,7 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
[Fact] [Fact]
public void It_converts_the_port_to_int_when_a_valid_one_is_passed() public void It_converts_the_port_to_int_when_a_valid_one_is_passed()
{ {
_dotnetTestFullParams.Port.Should().Be(Port); _dotnetTestFullParamsWithProjectJson.Port.Should().Be(Port);
} }
[Fact] [Fact]
@ -108,7 +118,7 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
[Fact] [Fact]
public void It_converts_the_framework_to_NugetFramework() public void It_converts_the_framework_to_NugetFramework()
{ {
_dotnetTestFullParams.Framework.DotNetFrameworkName.Should().Be(".NETCoreApp,Version=v1.0"); _dotnetTestFullParamsWithProjectJson.Framework.DotNetFrameworkName.Should().Be(".NETCoreApp,Version=v1.0");
} }
[Fact] [Fact]
@ -129,7 +139,7 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
[Fact] [Fact]
public void It_sets_Output_when_one_is_passed_in() public void It_sets_Output_when_one_is_passed_in()
{ {
_dotnetTestFullParams.Output.Should().Be(Output); _dotnetTestFullParamsWithProjectJson.Output.Should().Be(Output);
} }
[Fact] [Fact]
@ -141,7 +151,7 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
[Fact] [Fact]
public void It_sets_BuildBasePath_when_one_is_passed_in() public void It_sets_BuildBasePath_when_one_is_passed_in()
{ {
_dotnetTestFullParams.BuildBasePath.Should().Be(Path.GetFullPath(BuildBasePath)); _dotnetTestFullParamsWithProjectJson.BuildBasePath.Should().Be(Path.GetFullPath(BuildBasePath));
} }
[Fact] [Fact]
@ -153,7 +163,7 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
[Fact] [Fact]
public void It_sets_Config_to_passed_in_value() public void It_sets_Config_to_passed_in_value()
{ {
_dotnetTestFullParams.Config.Should().Be(Config); _dotnetTestFullParamsWithProjectJson.Config.Should().Be(Config);
} }
[Fact] [Fact]
@ -165,7 +175,7 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
[Fact] [Fact]
public void It_sets_Runtime_when_one_is_passed_in() public void It_sets_Runtime_when_one_is_passed_in()
{ {
_dotnetTestFullParams.Runtime.Should().Be(Runtime); _dotnetTestFullParamsWithProjectJson.Runtime.Should().Be(Runtime);
} }
[Fact] [Fact]
@ -177,14 +187,14 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
[Fact] [Fact]
public void It_sets_any_remaining_params_to_RemainingArguments() public void It_sets_any_remaining_params_to_RemainingArguments()
{ {
_dotnetTestFullParams.RemainingArguments.ShouldBeEquivalentTo( _dotnetTestFullParamsWithProjectJson.RemainingArguments.ShouldBeEquivalentTo(
new [] { "--additional-parameters", "additional-parameter-value" }); new [] { "--additional-parameters", "additional-parameter-value" });
} }
[Fact] [Fact]
public void It_sets_no_build_to_true_when_it_is_passed() public void It_sets_no_build_to_true_when_it_is_passed()
{ {
_dotnetTestFullParams.NoBuild.Should().BeTrue(); _dotnetTestFullParamsWithProjectJson.NoBuild.Should().BeTrue();
} }
[Fact] [Fact]
@ -196,7 +206,7 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
[Fact] [Fact]
public void It_sets_Help_to_false_when_help_is_not_passed_in() public void It_sets_Help_to_false_when_help_is_not_passed_in()
{ {
_dotnetTestFullParams.Help.Should().BeFalse(); _dotnetTestFullParamsWithProjectJson.Help.Should().BeFalse();
} }
[Fact] [Fact]
@ -207,5 +217,65 @@ namespace Microsoft.Dotnet.Tools.Test.Tests
dotnetTestParams.Help.Should().BeTrue(); dotnetTestParams.Help.Should().BeTrue();
} }
[Fact]
public void It_has_the_testRunner_null_by_default()
{
_emptyDotnetTestParams.TestRunner.Should().BeNull();
}
[Fact]
public void It_throws_when_you_specify_a_testRunner_along_with_a_folder()
{
var dotnetTestParams = new DotnetTestParams();
Action action = () => dotnetTestParams.Parse(new[]
{
"c:/some/path",
"--test-runner", "someTestRunner"
});
action
.ShouldThrow<InvalidOperationException>()
.WithMessage("You can only specify a test runner with a dll.");
}
[Fact]
public void It_throws_when_you_specify_a_testRunner_along_with_a_project_json()
{
var dotnetTestParams = new DotnetTestParams();
Action action = () => dotnetTestParams.Parse(new[]
{
ProjectJson,
"--test-runner", "someTestRunner"
});
action
.ShouldThrow<InvalidOperationException>()
.WithMessage("You can only specify a test runner with a dll.");
}
[Fact]
public void It_succeeds_when_specifying_an_assembly()
{
_dotnetTestParamsWithAssembly.ProjectOrAssemblyPath.Should().Be(PathToAssemblyUnderTest);
}
[Fact]
public void It_succeeds_when_specifying_a_test_runner_along_with_an_assembly()
{
_dotnetTestParamsWithAssembly.TestRunner.Should().Be(TestRunner);
}
[Fact]
public void When_a_testRunner_is_successfully_specified_then_HasTestRunner_returns_true()
{
_dotnetTestParamsWithAssembly.HasTestRunner.Should().BeTrue();
}
[Fact]
public void When_a_testRunner_is_noy_specified_then_HasTestRunner_returns_false()
{
_dotnetTestFullParamsWithProjectJson.HasTestRunner.Should().BeFalse();
}
} }
} }