2016-08-22 19:24:10 +00:00
|
|
|
|
using Microsoft.Build.Construction;
|
|
|
|
|
using Microsoft.DotNet.ProjectJsonMigration;
|
|
|
|
|
using Microsoft.DotNet.ProjectModel;
|
|
|
|
|
using Microsoft.DotNet.Tools.Test.Utilities;
|
|
|
|
|
using NuGet.Frameworks;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Xunit;
|
|
|
|
|
using FluentAssertions;
|
2016-08-23 20:50:05 +00:00
|
|
|
|
using Microsoft.DotNet.ProjectJsonMigration.Rules;
|
2016-08-22 19:24:10 +00:00
|
|
|
|
|
2016-09-14 22:30:11 +00:00
|
|
|
|
namespace Microsoft.DotNet.ProjectJsonMigration.Tests
|
2016-08-22 19:24:10 +00:00
|
|
|
|
{
|
|
|
|
|
public class GivenThatIWantToMigrateProjectDependencies : TestBase
|
|
|
|
|
{
|
|
|
|
|
// Workaround For P2P dependencies
|
|
|
|
|
// ISSUE: https://github.com/dotnet/sdk/issues/73
|
|
|
|
|
[Fact]
|
|
|
|
|
public void If_a_project_dependency_is_present_DesignTimeAutoUnify_and_AutoUnify_are_present()
|
|
|
|
|
{
|
|
|
|
|
var solutionDirectory =
|
2016-09-22 04:23:50 +00:00
|
|
|
|
TestAssetsManager.CreateTestInstance("TestAppWithLibrary", callingMethod: "p").Path;
|
2016-08-22 19:24:10 +00:00
|
|
|
|
|
|
|
|
|
var appDirectory = Path.Combine(solutionDirectory, "TestApp");
|
|
|
|
|
var libDirectory = Path.Combine(solutionDirectory, "TestLibrary");
|
|
|
|
|
|
|
|
|
|
var projectContext = ProjectContext.Create(appDirectory, FrameworkConstants.CommonFrameworks.NetCoreApp10);
|
|
|
|
|
var mockProj = ProjectRootElement.Create();
|
|
|
|
|
var testSettings = new MigrationSettings(appDirectory, appDirectory, "1.0.0", mockProj);
|
|
|
|
|
var testInputs = new MigrationRuleInputs(new[] {projectContext}, mockProj, mockProj.AddItemGroup(),
|
|
|
|
|
mockProj.AddPropertyGroup());
|
|
|
|
|
new MigrateProjectDependenciesRule().Apply(testSettings, testInputs);
|
|
|
|
|
|
|
|
|
|
var autoUnify = mockProj.Properties.Where(p => p.Name == "AutoUnify");
|
|
|
|
|
autoUnify.Count().Should().Be(1);
|
|
|
|
|
autoUnify.First().Value.Should().Be("true");
|
|
|
|
|
|
|
|
|
|
var designTimeAutoUnify = mockProj.Properties.Where(p => p.Name == "DesignTimeAutoUnify");
|
|
|
|
|
designTimeAutoUnify.Count().Should().Be(1);
|
|
|
|
|
designTimeAutoUnify.First().Value.Should().Be("true");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Fact]
|
|
|
|
|
public void Project_dependencies_are_migrated_to_ProjectReference()
|
|
|
|
|
{
|
|
|
|
|
var solutionDirectory =
|
2016-09-22 04:14:48 +00:00
|
|
|
|
TestAssetsManager.CreateTestInstance("TestAppWithLibrary", callingMethod: "p").Path;
|
2016-08-22 19:24:10 +00:00
|
|
|
|
|
|
|
|
|
var appDirectory = Path.Combine(solutionDirectory, "TestApp");
|
|
|
|
|
|
|
|
|
|
var projectContext = ProjectContext.Create(appDirectory, FrameworkConstants.CommonFrameworks.NetCoreApp10);
|
|
|
|
|
var mockProj = ProjectRootElement.Create();
|
2016-09-22 00:27:02 +00:00
|
|
|
|
var testSettings = new MigrationSettings(appDirectory, appDirectory, "1.0.0", mockProj, null);
|
2016-08-22 19:24:10 +00:00
|
|
|
|
var testInputs = new MigrationRuleInputs(new[] {projectContext}, mockProj, mockProj.AddItemGroup(),
|
|
|
|
|
mockProj.AddPropertyGroup());
|
|
|
|
|
new MigrateProjectDependenciesRule().Apply(testSettings, testInputs);
|
|
|
|
|
|
|
|
|
|
var projectReferences = mockProj.Items.Where(item => item.ItemType.Equals("ProjectReference", StringComparison.Ordinal));
|
|
|
|
|
projectReferences.Count().Should().Be(1);
|
|
|
|
|
|
2016-08-23 20:50:05 +00:00
|
|
|
|
projectReferences.First().Include.Should().Be(Path.Combine("..", "TestLibrary", "TestLibrary.csproj"));
|
2016-08-22 19:24:10 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Fact]
|
|
|
|
|
public void It_throws_when_project_dependency_is_unresolved()
|
|
|
|
|
{
|
|
|
|
|
// No Lock file => unresolved
|
|
|
|
|
var solutionDirectory =
|
|
|
|
|
TestAssetsManager.CreateTestInstance("TestAppWithLibrary").Path;
|
|
|
|
|
|
|
|
|
|
var appDirectory = Path.Combine(solutionDirectory, "TestApp");
|
2016-09-22 04:14:48 +00:00
|
|
|
|
var libraryDirectory = Path.Combine(solutionDirectory, "TestLibrary");
|
|
|
|
|
Directory.Delete(libraryDirectory, true);
|
2016-08-22 19:24:10 +00:00
|
|
|
|
|
|
|
|
|
var projectContext = ProjectContext.Create(appDirectory, FrameworkConstants.CommonFrameworks.NetCoreApp10);
|
|
|
|
|
var mockProj = ProjectRootElement.Create();
|
|
|
|
|
var testSettings = new MigrationSettings(appDirectory, appDirectory, "1.0.0", mockProj);
|
|
|
|
|
var testInputs = new MigrationRuleInputs(new[] {projectContext}, mockProj, mockProj.AddItemGroup(), mockProj.AddPropertyGroup());
|
|
|
|
|
|
|
|
|
|
Action action = () => new MigrateProjectDependenciesRule().Apply(testSettings, testInputs);
|
|
|
|
|
action.ShouldThrow<Exception>()
|
2016-08-23 20:50:05 +00:00
|
|
|
|
.Where(e => e.Message.Contains("MIGRATE1014::Unresolved Dependency: Unresolved project dependency (TestLibrary)"));
|
2016-08-22 19:24:10 +00:00
|
|
|
|
}
|
2016-09-22 00:27:02 +00:00
|
|
|
|
|
|
|
|
|
[Theory]
|
|
|
|
|
[InlineData(@"some/path/to.cSproj", new [] { @"some/path/to.cSproj" })]
|
|
|
|
|
[InlineData(@"to.CSPROJ",new [] { @"to.CSPROJ" })]
|
|
|
|
|
public void It_migrates_csproj_ProjectReference_in_xproj(string projectReference, string[] expectedMigratedReferences)
|
|
|
|
|
{
|
|
|
|
|
var xproj = ProjectRootElement.Create();
|
|
|
|
|
xproj.AddItem("ProjectReference", projectReference);
|
|
|
|
|
|
|
|
|
|
var projectReferenceName = Path.GetFileNameWithoutExtension(projectReference);
|
|
|
|
|
|
|
|
|
|
var projectJson = @"
|
|
|
|
|
{
|
|
|
|
|
""dependencies"": {" +
|
|
|
|
|
$"\"{projectReferenceName}\"" + @": {
|
|
|
|
|
""target"" : ""project""
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
";
|
|
|
|
|
|
|
|
|
|
var testDirectory = Temp.CreateDirectory().Path;
|
|
|
|
|
var migratedProj = TemporaryProjectFileRuleRunner.RunRules(new IMigrationRule[]
|
|
|
|
|
{
|
|
|
|
|
new MigrateProjectDependenciesRule()
|
|
|
|
|
}, projectJson, testDirectory, xproj);
|
|
|
|
|
|
|
|
|
|
var migratedProjectReferenceItems = migratedProj.Items.Where(i => i.ItemType == "ProjectReference");
|
|
|
|
|
migratedProjectReferenceItems.Should().HaveCount(expectedMigratedReferences.Length);
|
|
|
|
|
migratedProjectReferenceItems.Select(m => m.Include).Should().BeEquivalentTo(expectedMigratedReferences);
|
|
|
|
|
}
|
2016-09-22 19:51:23 +00:00
|
|
|
|
|
2016-09-22 21:30:56 +00:00
|
|
|
|
[Fact]
|
2016-09-22 19:51:23 +00:00
|
|
|
|
public void It_migrates_csproj_ProjectReference_in_xproj_including_condition_on_ProjectReference()
|
|
|
|
|
{
|
|
|
|
|
var projectReference = "some/to.csproj";
|
|
|
|
|
var xproj = ProjectRootElement.Create();
|
|
|
|
|
var csprojReferenceItem = xproj.AddItem("ProjectReference", projectReference);
|
|
|
|
|
csprojReferenceItem.Condition = " '$(Foo)' == 'bar' ";
|
|
|
|
|
|
|
|
|
|
var projectReferenceName = Path.GetFileNameWithoutExtension(projectReference);
|
|
|
|
|
|
|
|
|
|
var projectJson = @"
|
|
|
|
|
{
|
|
|
|
|
""dependencies"": {" +
|
|
|
|
|
$"\"{projectReferenceName}\"" + @": {
|
|
|
|
|
""target"" : ""project""
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
";
|
|
|
|
|
|
|
|
|
|
var testDirectory = Temp.CreateDirectory().Path;
|
|
|
|
|
var migratedProj = TemporaryProjectFileRuleRunner.RunRules(new IMigrationRule[]
|
|
|
|
|
{
|
|
|
|
|
new MigrateProjectDependenciesRule()
|
|
|
|
|
}, projectJson, testDirectory, xproj);
|
|
|
|
|
|
|
|
|
|
var migratedProjectReferenceItems = migratedProj.Items.Where(i => i.ItemType == "ProjectReference");
|
|
|
|
|
migratedProjectReferenceItems.Should().HaveCount(1);
|
|
|
|
|
|
|
|
|
|
var migratedProjectReferenceItem = migratedProjectReferenceItems.First();
|
|
|
|
|
migratedProjectReferenceItem.Include.Should().Be(projectReference);
|
|
|
|
|
migratedProjectReferenceItem.Condition.Should().Be(" '$(Foo)' == 'bar' ");
|
|
|
|
|
}
|
|
|
|
|
|
2016-09-22 21:30:56 +00:00
|
|
|
|
[Fact]
|
2016-09-22 19:51:23 +00:00
|
|
|
|
public void It_migrates_csproj_ProjectReference_in_xproj_including_condition_on_ProjectReference_parent()
|
|
|
|
|
{
|
|
|
|
|
var projectReference = "some/to.csproj";
|
|
|
|
|
var xproj = ProjectRootElement.Create();
|
|
|
|
|
var csprojReferenceItem = xproj.AddItem("ProjectReference", projectReference);
|
|
|
|
|
csprojReferenceItem.Parent.Condition = " '$(Foo)' == 'bar' ";
|
|
|
|
|
|
|
|
|
|
var projectReferenceName = Path.GetFileNameWithoutExtension(projectReference);
|
|
|
|
|
|
|
|
|
|
var projectJson = @"
|
|
|
|
|
{
|
|
|
|
|
""dependencies"": {" +
|
|
|
|
|
$"\"{projectReferenceName}\"" + @": {
|
|
|
|
|
""target"" : ""project""
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
";
|
|
|
|
|
|
|
|
|
|
var testDirectory = Temp.CreateDirectory().Path;
|
|
|
|
|
var migratedProj = TemporaryProjectFileRuleRunner.RunRules(new IMigrationRule[]
|
|
|
|
|
{
|
|
|
|
|
new MigrateProjectDependenciesRule()
|
|
|
|
|
}, projectJson, testDirectory, xproj);
|
|
|
|
|
|
|
|
|
|
var migratedProjectReferenceItems = migratedProj.Items.Where(i => i.ItemType == "ProjectReference");
|
|
|
|
|
migratedProjectReferenceItems.Should().HaveCount(1);
|
|
|
|
|
|
|
|
|
|
var migratedProjectReferenceItem = migratedProjectReferenceItems.First();
|
|
|
|
|
migratedProjectReferenceItem.Include.Should().Be(projectReference);
|
|
|
|
|
migratedProjectReferenceItem.Condition.Should().Be(" '$(Foo)' == 'bar' ");
|
|
|
|
|
}
|
|
|
|
|
|
2016-09-22 21:30:56 +00:00
|
|
|
|
[Fact]
|
2016-09-22 19:51:23 +00:00
|
|
|
|
public void It_migrates_csproj_ProjectReference_in_xproj_including_condition_on_ProjectReference_parent_and_item()
|
|
|
|
|
{
|
|
|
|
|
var projectReference = "some/to.csproj";
|
|
|
|
|
var xproj = ProjectRootElement.Create();
|
|
|
|
|
var csprojReferenceItem = xproj.AddItem("ProjectReference", projectReference);
|
|
|
|
|
csprojReferenceItem.Parent.Condition = " '$(Foo)' == 'bar' ";
|
|
|
|
|
csprojReferenceItem.Condition = " '$(Bar)' == 'foo' ";
|
|
|
|
|
|
|
|
|
|
var projectReferenceName = Path.GetFileNameWithoutExtension(projectReference);
|
|
|
|
|
|
|
|
|
|
var projectJson = @"
|
|
|
|
|
{
|
|
|
|
|
""dependencies"": {" +
|
|
|
|
|
$"\"{projectReferenceName}\"" + @": {
|
|
|
|
|
""target"" : ""project""
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
";
|
|
|
|
|
|
|
|
|
|
var testDirectory = Temp.CreateDirectory().Path;
|
|
|
|
|
var migratedProj = TemporaryProjectFileRuleRunner.RunRules(new IMigrationRule[]
|
|
|
|
|
{
|
|
|
|
|
new MigrateProjectDependenciesRule()
|
|
|
|
|
}, projectJson, testDirectory, xproj);
|
|
|
|
|
|
|
|
|
|
var migratedProjectReferenceItems = migratedProj.Items.Where(i => i.ItemType == "ProjectReference");
|
|
|
|
|
migratedProjectReferenceItems.Should().HaveCount(1);
|
|
|
|
|
|
|
|
|
|
var migratedProjectReferenceItem = migratedProjectReferenceItems.First();
|
|
|
|
|
migratedProjectReferenceItem.Include.Should().Be(projectReference);
|
2016-09-23 00:16:37 +00:00
|
|
|
|
migratedProjectReferenceItem.Condition.Should().Be(" '$(Bar)' == 'foo' and '$(Foo)' == 'bar' ");
|
2016-09-22 19:51:23 +00:00
|
|
|
|
}
|
2016-08-22 19:24:10 +00:00
|
|
|
|
}
|
|
|
|
|
}
|