|
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
using Microsoft.Build.Framework;
using System.Collections;
using System.Collections.Generic;
using System.Collections.Immutable;
using System.Linq;
using System.Xml.Linq;
using Xunit.Abstractions;
namespace Microsoft.DotNet.SignTool.Tests
{
class FakeBuildEngine : IBuildEngine
{
// It's just a test helper so public fields is fine.
public List<BuildErrorEventArgs> LogErrorEvents = new List<BuildErrorEventArgs>();
public List<BuildMessageEventArgs> LogMessageEvents =
new List<BuildMessageEventArgs>();
public List<CustomBuildEventArgs> LogCustomEvents =
new List<CustomBuildEventArgs>();
public List<BuildWarningEventArgs> LogWarningEvents =
new List<BuildWarningEventArgs>();
public readonly List<ImmutableArray<XElement>> FilesToSign = new List<ImmutableArray<XElement>>();
private readonly ITestOutputHelper _output;
public FakeBuildEngine()
{
}
public FakeBuildEngine(ITestOutputHelper output)
{
_output = output;
}
public bool BuildProjectFile(string projectFileName, string[] targetNames, IDictionary globalProperties, IDictionary targetOutputs)
{
var xml = XDocument.Load(projectFileName);
// When signing OSX files, we have an item group that contains a package reference.
// This item group contains a label, so we need to look for the itemgroup that doesn't have a label.
var itemGroupNode = xml
.Descendants("ItemGroup")
.Where(ig => ig.Attribute("Label") == null);
if (itemGroupNode.Count() == 0)
{
LogErrorEvent(new BuildErrorEventArgs(string.Empty, string.Empty, string.Empty, 0, 0, 0, 0, "Didn't find a project node.", "", ""));
return false;
}
else if (itemGroupNode.Count() > 1)
{
LogErrorEvent(new BuildErrorEventArgs(string.Empty, string.Empty, string.Empty, 0, 0, 0, 0, "Only one <ItemGroup> is expected on this file.", "", ""));
return false;
}
else
{
var filesToSign = itemGroupNode.Descendants("FilesToSign").ToImmutableArray();
FilesToSign.Add(filesToSign);
foreach (var file in filesToSign)
{
FakeSignTool.SignFile(file.Attribute("Include").Value);
}
return true;
}
}
public int ColumnNumberOfTaskNode
{
get { return 0; }
}
public bool ContinueOnError
{
get; set;
}
public int LineNumberOfTaskNode
{
get { return 0; }
}
public void LogCustomEvent(CustomBuildEventArgs e)
{
if (_output != null)
{
_output.WriteLine(e.Message ?? string.Empty);
}
LogCustomEvents.Add(e);
}
public void LogErrorEvent(BuildErrorEventArgs e)
{
if (_output != null)
{
_output.WriteLine($"error {e.Code}: {e.Message}");
}
LogErrorEvents.Add(e);
}
public void LogMessageEvent(BuildMessageEventArgs e)
{
if (_output != null)
{
_output.WriteLine(e.Message ?? string.Empty);
}
LogMessageEvents.Add(e);
}
public void LogWarningEvent(BuildWarningEventArgs e)
{
if (_output != null)
{
_output.WriteLine($"warning {e.Code}: {e.Message}");
}
LogWarningEvents.Add(e);
}
public string ProjectFileOfTaskNode
{
get { return "fake ProjectFileOfTaskNode"; }
}
}
}
|