Merge pull request #2792 from eerhardt/Relative

Execute 'csc' with working directory set to the project directory.
This commit is contained in:
Eric Erhardt 2016-05-02 18:53:57 -05:00
commit 9a85205781
18 changed files with 124 additions and 13 deletions

View file

@ -0,0 +1,26 @@
// 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.IO;
namespace TestLibrary
{
public class AttributeWithoutUsage : Attribute
{
}
public class ClassWithUndisposedStream
{
private Stream _nonDisposedStream = new MemoryStream();
public ClassWithUndisposedStream()
{
}
public Stream GetStream()
{
return _nonDisposedStream;
}
}
}

View file

@ -0,0 +1,16 @@
{
"version": "1.0.0-*",
"buildOptions": {
"additionalArguments": [ "/ruleset:../global.ruleset" ]
},
"dependencies": {
"NETStandard.Library": "1.5.0-rc2-24027",
"System.Runtime.Analyzers": {
"version": "1.1.0",
"type": "build"
}
},
"frameworks": {
"netstandard1.5": {}
}
}

View file

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<RuleSet Name="New Rule Set" Description=" " ToolsVersion="14.0">
<Rules AnalyzerId="Microsoft.Analyzers.ManagedCodeAnalysis" RuleNamespace="Microsoft.Rules.Managed">
<Rule Id="CA1018" Action="Hidden" />
</Rules>
</RuleSet>

View file

@ -20,6 +20,7 @@ namespace Microsoft.DotNet.Cli.Utils
private readonly Func<string[], int> _builtInCommand; private readonly Func<string[], int> _builtInCommand;
private readonly StreamForwarder _stdOut; private readonly StreamForwarder _stdOut;
private readonly StreamForwarder _stdErr; private readonly StreamForwarder _stdErr;
private string _workingDirectory;
public string CommandName { get; } public string CommandName { get; }
public string CommandArgs => string.Join(" ", _commandArgs); public string CommandArgs => string.Join(" ", _commandArgs);
@ -38,6 +39,7 @@ namespace Microsoft.DotNet.Cli.Utils
{ {
TextWriter originalConsoleOut = Console.Out; TextWriter originalConsoleOut = Console.Out;
TextWriter originalConsoleError = Console.Error; TextWriter originalConsoleError = Console.Error;
string originalWorkingDirectory = Directory.GetCurrentDirectory();
try try
{ {
@ -52,6 +54,11 @@ namespace Microsoft.DotNet.Cli.Utils
// Reset the Reporters to the new Console Out and Error. // Reset the Reporters to the new Console Out and Error.
Reporter.Reset(); Reporter.Reset();
if (!string.IsNullOrEmpty(_workingDirectory))
{
Directory.SetCurrentDirectory(_workingDirectory);
}
var taskOut = _stdOut.BeginRead(new StreamReader(outStream)); var taskOut = _stdOut.BeginRead(new StreamReader(outStream));
var taskErr = _stdErr.BeginRead(new StreamReader(errorStream)); var taskErr = _stdErr.BeginRead(new StreamReader(errorStream));
@ -71,6 +78,7 @@ namespace Microsoft.DotNet.Cli.Utils
{ {
Console.SetOut(originalConsoleOut); Console.SetOut(originalConsoleOut);
Console.SetError(originalConsoleError); Console.SetError(originalConsoleError);
Directory.SetCurrentDirectory(originalWorkingDirectory);
Reporter.Reset(); Reporter.Reset();
} }
@ -100,6 +108,13 @@ namespace Microsoft.DotNet.Cli.Utils
return this; return this;
} }
public ICommand WorkingDirectory(string workingDirectory)
{
_workingDirectory = workingDirectory;
return this;
}
public CommandResolutionStrategy ResolutionStrategy public CommandResolutionStrategy ResolutionStrategy
{ {
get get
@ -132,10 +147,5 @@ namespace Microsoft.DotNet.Cli.Utils
{ {
throw new NotImplementedException(); throw new NotImplementedException();
} }
public ICommand WorkingDirectory(string projectDirectory)
{
throw new NotImplementedException();
}
} }
} }

View file

@ -223,5 +223,19 @@ namespace Microsoft.DotNet.Tools.Common
return Path.GetExtension(filePath).Equals(extension, comparison); return Path.GetExtension(filePath).Equals(extension, comparison);
} }
/// <summary>
/// Gets the fully-qualified path without failing if the
/// path is empty.
/// </summary>
public static string GetFullPath(string path)
{
if (string.IsNullOrWhiteSpace(path))
{
return path;
}
return Path.GetFullPath(path);
}
} }
} }

View file

@ -36,7 +36,7 @@ namespace Microsoft.DotNet.ProjectModel
public string RootDirectory => GlobalSettings?.DirectoryPath; public string RootDirectory => GlobalSettings?.DirectoryPath;
public string ProjectDirectory => ProjectFile.ProjectDirectory; public string ProjectDirectory => ProjectFile?.ProjectDirectory;
public string PackagesDirectory { get; } public string PackagesDirectory { get; }

View file

@ -6,6 +6,7 @@ using Microsoft.DotNet.Cli.CommandLine;
using Microsoft.DotNet.Cli.Utils; using Microsoft.DotNet.Cli.Utils;
using Microsoft.DotNet.InternalAbstractions; using Microsoft.DotNet.InternalAbstractions;
using Microsoft.DotNet.ProjectModel; using Microsoft.DotNet.ProjectModel;
using Microsoft.DotNet.Tools.Common;
using NuGet.Frameworks; using NuGet.Frameworks;
// This class is responsible with defining the arguments for the Compile verb. // This class is responsible with defining the arguments for the Compile verb.
@ -97,7 +98,7 @@ namespace Microsoft.DotNet.Tools.Compiler
} }
OutputValue = _outputOption.Value(); OutputValue = _outputOption.Value();
BuildBasePathValue = _buildBasePath.Value(); BuildBasePathValue = PathUtility.GetFullPath(_buildBasePath.Value());
ConfigValue = _configurationOption.Value() ?? Constants.DefaultConfiguration; ConfigValue = _configurationOption.Value() ?? Constants.DefaultConfiguration;
RuntimeValue = _runtimeOption.Value(); RuntimeValue = _runtimeOption.Value();
VersionSuffixValue = _versionSuffixOption.Value(); VersionSuffixValue = _versionSuffixOption.Value();

View file

@ -84,6 +84,7 @@ namespace Microsoft.DotNet.Tools.Compiler.Csc
// Execute CSC! // Execute CSC!
var result = RunCsc(new string[] { $"-noconfig", "@" + $"{rsp}" }) var result = RunCsc(new string[] { $"-noconfig", "@" + $"{rsp}" })
.WorkingDirectory(Directory.GetCurrentDirectory())
.ForwardStdErr() .ForwardStdErr()
.ForwardStdOut() .ForwardStdOut()
.Execute(); .Execute();

View file

@ -189,6 +189,7 @@ namespace Microsoft.DotNet.Tools.Compiler
Reporter outputReporter = Reporter.Output; Reporter outputReporter = Reporter.Output;
CommandResult result = _commandFactory.Create($"compile-{compilerName}", new[] { $"@{rsp}" }) CommandResult result = _commandFactory.Create($"compile-{compilerName}", new[] { $"@{rsp}" })
.WorkingDirectory(context.ProjectDirectory)
.OnErrorLine(line => HandleCompilerOutputLine(line, context, diagnostics, errorReporter)) .OnErrorLine(line => HandleCompilerOutputLine(line, context, diagnostics, errorReporter))
.OnOutputLine(line => HandleCompilerOutputLine(line, context, diagnostics, outputReporter)) .OnOutputLine(line => HandleCompilerOutputLine(line, context, diagnostics, outputReporter))
.Execute(); .Execute();

View file

@ -7,6 +7,7 @@ using System.Linq;
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.ProjectModel;
using Microsoft.DotNet.Tools.Common;
using Microsoft.DotNet.Tools.Pack; using Microsoft.DotNet.Tools.Pack;
namespace Microsoft.DotNet.Tools.Compiler namespace Microsoft.DotNet.Tools.Compiler
@ -55,7 +56,7 @@ namespace Microsoft.DotNet.Tools.Compiler
var configValue = configuration.Value() ?? Cli.Utils.Constants.DefaultConfiguration; var configValue = configuration.Value() ?? Cli.Utils.Constants.DefaultConfiguration;
var outputValue = output.Value(); var outputValue = output.Value();
var buildBasePathValue = buildBasePath.Value(); var buildBasePathValue = PathUtility.GetFullPath(buildBasePath.Value());
var contexts = workspace.GetProjectContextCollection(pathValue).FrameworkOnlyContexts; var contexts = workspace.GetProjectContextCollection(pathValue).FrameworkOnlyContexts;
var project = contexts.First().ProjectFile; var project = contexts.First().ProjectFile;

View file

@ -6,6 +6,7 @@ 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.ProjectModel;
using Microsoft.DotNet.Tools.Common;
namespace Microsoft.DotNet.Tools.Publish namespace Microsoft.DotNet.Tools.Publish
{ {
@ -37,7 +38,7 @@ namespace Microsoft.DotNet.Tools.Publish
publish.Framework = framework.Value(); publish.Framework = framework.Value();
publish.Runtime = runtime.Value(); publish.Runtime = runtime.Value();
publish.BuildBasePath = buildBasePath.Value(); publish.BuildBasePath = PathUtility.GetFullPath(buildBasePath.Value());
publish.OutputPath = output.Value(); publish.OutputPath = output.Value();
publish.Configuration = configuration.Value() ?? Constants.DefaultConfiguration; publish.Configuration = configuration.Value() ?? Constants.DefaultConfiguration;
publish.NativeSubdirectories = nativeSubdirectories.HasValue(); publish.NativeSubdirectories = nativeSubdirectories.HasValue();

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.Tools.Common;
using NuGet.Frameworks; using NuGet.Frameworks;
using static System.Int32; using static System.Int32;
@ -106,7 +107,7 @@ namespace Microsoft.DotNet.Tools.Test
} }
Output = _outputOption.Value(); Output = _outputOption.Value();
BuildBasePath = _buildBasePath.Value(); BuildBasePath = PathUtility.GetFullPath(_buildBasePath.Value());
Config = _configurationOption.Value() ?? Constants.DefaultConfiguration; Config = _configurationOption.Value() ?? Constants.DefaultConfiguration;
Runtime = _runtimeOption.Value(); Runtime = _runtimeOption.Value();
NoBuild = _noBuildOption.HasValue(); NoBuild = _noBuildOption.HasValue();

View file

@ -81,6 +81,13 @@ namespace Microsoft.DotNet.Tools.Test.Utilities
return new AndConstraint<CommandResultAssertions>(this); return new AndConstraint<CommandResultAssertions>(this);
} }
public AndConstraint<CommandResultAssertions> NotHaveStdErrContaining(string pattern)
{
Execute.Assertion.ForCondition(!_commandResult.StdErr.Contains(pattern))
.FailWith(AppendDiagnosticsTo($"The command error output contained a result it should not have contained: {pattern}{Environment.NewLine}"));
return new AndConstraint<CommandResultAssertions>(this);
}
public AndConstraint<CommandResultAssertions> HaveStdErrMatching(string pattern, RegexOptions options = RegexOptions.None) public AndConstraint<CommandResultAssertions> HaveStdErrMatching(string pattern, RegexOptions options = RegexOptions.None)
{ {
Execute.Assertion.ForCondition(Regex.Match(_commandResult.StdErr, pattern, options).Success) Execute.Assertion.ForCondition(Regex.Match(_commandResult.StdErr, pattern, options).Success)

View file

@ -217,11 +217,16 @@ namespace Microsoft.DotNet.Tools.Test.Utilities
string cppCompilerFlags="", string cppCompilerFlags="",
bool buildProfile=true, bool buildProfile=true,
bool noIncremental=false, bool noIncremental=false,
bool noDependencies=false) bool noDependencies=false,
bool skipLoadProject=false)
: base("dotnet") : base("dotnet")
{ {
_projectPath = projectPath; _projectPath = projectPath;
if (!skipLoadProject)
{
_project = ProjectReader.GetProject(projectPath); _project = ProjectReader.GetProject(projectPath);
}
_outputDirectory = output; _outputDirectory = output;
_buildBasePathDirectory = buildBasePath; _buildBasePathDirectory = buildBasePath;

View file

@ -43,6 +43,26 @@ namespace Microsoft.DotNet.Tools.Builder.Tests
.Pass(); .Pass();
} }
[Fact]
public void It_builds_projects_with_ruleset_relative_path()
{
var testInstance = TestAssetsManager
.CreateTestInstance("TestRuleSet")
.WithLockFiles();
new BuildCommand(Path.Combine("TestLibraryWithRuleSet", "project.json"), skipLoadProject: true)
.WithWorkingDirectory(testInstance.TestRoot)
.ExecuteWithCapturedOutput()
.Should()
.Pass()
.And
.HaveStdErrContaining("CA1001")
.And
.HaveStdErrContaining("CA2213")
.And
.NotHaveStdErrContaining("CA1018"); // this violation is hidden in the ruleset
}
[Fact] [Fact]
public void It_builds_projects_with_a_local_project_json_path() public void It_builds_projects_with_a_local_project_json_path()
{ {

View file

@ -176,6 +176,7 @@ namespace Microsoft.DotNet.Tools.Compiler.Tests
var projectJson = Path.Combine(TestAssetPath, "project.json"); var projectJson = Path.Combine(TestAssetPath, "project.json");
var command = new Mock<ICommand>(); var command = new Mock<ICommand>();
command.Setup(c => c.Execute()).Returns(new CommandResult()); command.Setup(c => c.Execute()).Returns(new CommandResult());
command.Setup(c => c.WorkingDirectory(It.IsAny<string>())).Returns(() => command.Object);
command.Setup(c => c.OnErrorLine(It.IsAny<Action<string>>())).Returns(() => command.Object); command.Setup(c => c.OnErrorLine(It.IsAny<Action<string>>())).Returns(() => command.Object);
command.Setup(c => c.OnOutputLine(It.IsAny<Action<string>>())).Returns(() => command.Object); command.Setup(c => c.OnOutputLine(It.IsAny<Action<string>>())).Returns(() => command.Object);
var commandFactory = new Mock<ICommandFactory>(); var commandFactory = new Mock<ICommandFactory>();

View file

@ -141,7 +141,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(BuildBasePath); _dotnetTestFullParams.BuildBasePath.Should().Be(Path.GetFullPath(BuildBasePath));
} }
[Fact] [Fact]