File: FakeBuildEngine.cs
Web Access
Project: src\src\Microsoft.DotNet.SignTool.Tests\Microsoft.DotNet.SignTool.Tests.csproj (Microsoft.DotNet.SignTool.Tests)
// 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"; }
        }
 
    }
}