Skip to content

Commit

Permalink
Merge pull request #3948 from devlead/feature/gh-3947
Browse files Browse the repository at this point in the history
GH3947: Add Command aliases
  • Loading branch information
gep13 authored Sep 4, 2022
2 parents 51e73fe + 496854f commit 6d4f48c
Show file tree
Hide file tree
Showing 14 changed files with 1,486 additions and 1 deletion.
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.

using System.Collections.Generic;
using Cake.Common.Tools.Command;
using Cake.Core.IO;
using Cake.Testing.Fixtures;

namespace Cake.Common.Tests.Fixtures.Tools.Command
{
internal class CommandRunnerFixture : ToolFixture<CommandSettings>
{
public ProcessArgumentBuilder Arguments { get; set; }

public string ToolName
{
get => Settings.ToolName;
set => Settings.ToolName = value;
}

public ICollection<string> ToolExecutableNames
{
get => Settings.ToolExecutableNames;
set => Settings.ToolExecutableNames = value;
}

public CommandRunnerFixture()
: base("dotnet.exe")
{
Arguments = new ProcessArgumentBuilder();
Settings.ToolName = "dotnet";
Settings.ToolExecutableNames = new[] { "dotnet.exe", "dotnet" };
}

protected override void RunTool()
{
GetRunner().RunCommand(Arguments);
}

protected CommandRunner GetRunner()
=> new CommandRunner(
Settings,
FileSystem,
Environment,
ProcessRunner,
Tools);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.

namespace Cake.Common.Tests.Fixtures.Tools.Command
{
internal class CommandRunnerStandardErrorFixture : CommandRunnerStandardOutputFixture
{
public string StandardError { get; private set; }

protected override void RunTool()
{
ExitCode = GetRunner().RunCommand(Arguments, out var standardOutput, out var standardError);
StandardOutput = standardOutput;
StandardError = standardError;
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.

namespace Cake.Common.Tests.Fixtures.Tools.Command
{
internal class CommandRunnerStandardOutputFixture : CommandRunnerFixture
{
public int ExitCode { get; protected set; }
public string StandardOutput { get; protected set; }

protected override void RunTool()
{
ExitCode = GetRunner().RunCommand(Arguments, out var standardOutput);
StandardOutput = standardOutput;
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.

namespace Cake.Common.Tests.Fixtures.Tools.Command
{
internal static class CommandRunnerStandardOutputFixtureExtentions
{
public static T GivenStandardOutput<T>(this T fixture, params string[] standardOutput)
where T : CommandRunnerStandardOutputFixture
{
fixture.ProcessRunner.Process.SetStandardOutput(standardOutput);
return fixture;
}

public static T GivenStandardError<T>(this T fixture, params string[] standardError)
where T : CommandRunnerStandardOutputFixture
{
fixture.ProcessRunner.Process.SetStandardError(standardError);
return fixture;
}
}
}
207 changes: 207 additions & 0 deletions src/Cake.Common.Tests/Unit/Tools/Command/CommandRunnerTests.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,207 @@
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.

using System;
using Cake.Common.Tests.Fixtures.Tools.Command;
using Xunit;

namespace Cake.Common.Tests.Unit.Tools.Command
{
public sealed class CommandRunnerTests
{
public sealed class TheRunCommandMethod
{
[Fact]
public void Should_Throw_If_Arguments_Was_Null()
{
// Given
var fixture = new CommandRunnerFixture
{
Arguments = null
};

// When
var result = Record.Exception(() => fixture.Run());

// Then
AssertEx.IsArgumentNullException(result, "arguments");
}

[Fact]
public void Should_Throw_If_Settings_Was_Null()
{
// Given
var fixture = new CommandRunnerFixture
{
Settings = null
};

// When
var result = Record.Exception(() => fixture.Run());

// Then
AssertEx.IsArgumentNullException(result, "settings");
}

[Fact]
public void Should_Throw_If_ToolName_Was_Null()
{
// Given
var fixture = new CommandRunnerFixture
{
ToolName = null
};

// When
var result = Record.Exception(() => fixture.Run());

// Then
AssertEx.IsArgumentNullException(result, "ToolName");
}
}

[Fact]
public void Should_Throw_If_ToolExecutableNames_Was_Null()
{
// Given
var fixture = new CommandRunnerFixture
{
ToolExecutableNames = null
};

// When
var result = Record.Exception(() => fixture.Run());

// Then
AssertEx.IsArgumentNullException(result, "ToolExecutableNames");
}

[Fact]
public void Should_Throw_If_ToolExecutableNames_Was_Empty()
{
// Given
var fixture = new CommandRunnerFixture
{
ToolExecutableNames = Array.Empty<string>()
};

// When
var result = Record.Exception(() => fixture.Run());

// Then
AssertEx.IsArgumentNullException(result, "ToolExecutableNames");
}

[Fact]
public void Should_Call_Settings_PostAction()
{
// Given
var called = false;
var fixture = new CommandRunnerFixture
{
Settings = { PostAction = _ => called = true }
};

// When
var result = fixture.Run();

// Then
Assert.True(called, "Settings PostAction not called");
}

[Fact]
public void Should_Return_StandardOutput()
{
// Given
const string expectedStandardOutput = "LINE1";
const int expectedExitCode = 0;

var fixture = new CommandRunnerStandardOutputFixture()
.GivenStandardOutput(expectedStandardOutput);

// When
fixture.Run();

// Then
Assert.Equal(expectedStandardOutput, fixture.StandardOutput);
Assert.Equal(expectedExitCode, fixture.ExitCode);
}

[Fact]
public void Should_Return_StandardOutput_ExitCode()
{
// Given
const string expectedStandardOutput = "LINE1";
const int expectedExitCode = 1337;

var fixture = new CommandRunnerStandardOutputFixture
{
Settings =
{
HandleExitCode = exitCode => exitCode == expectedExitCode
}
}
.GivenStandardOutput(expectedStandardOutput);

fixture.ProcessRunner.Process.SetExitCode(expectedExitCode);

// When
fixture.Run();

// Then
Assert.Equal(expectedStandardOutput, fixture.StandardOutput);
Assert.Equal(expectedExitCode, fixture.ExitCode);
}

[Fact]
public void Should_Return_StandardError()
{
// Given
const string expectedStandardOutput = "LINE1";
const string expectedStandardError = "ERRORLINE1";
const int expectedExitCode = 0;

var fixture = new CommandRunnerStandardErrorFixture()
.GivenStandardError(expectedStandardError)
.GivenStandardOutput(expectedStandardOutput);

// When
fixture.Run();

// Then
Assert.Equal(expectedStandardOutput, fixture.StandardOutput);
Assert.Equal(expectedStandardError, fixture.StandardError);
Assert.Equal(expectedExitCode, fixture.ExitCode);
}

[Fact]
public void Should_Return_StandardError_ExitCode()
{
// Given
const string expectedStandardOutput = "LINE1";
const string expectedStandardError = "ERRORLINE1";
const int expectedExitCode = 1337;

var fixture = new CommandRunnerStandardErrorFixture
{
Settings =
{
HandleExitCode = exitCode => exitCode == expectedExitCode
}
}
.GivenStandardError(expectedStandardError)
.GivenStandardOutput(expectedStandardOutput);

fixture.ProcessRunner.Process.SetExitCode(expectedExitCode);

// When
fixture.Run();

// Then
Assert.Equal(expectedStandardOutput, fixture.StandardOutput);
Assert.Equal(expectedStandardError, fixture.StandardError);
Assert.Equal(expectedExitCode, fixture.ExitCode);
}
}
}
Loading

0 comments on commit 6d4f48c

Please sign in to comment.