Example #1
0
        public async Task <(TestExecutingResult ExecutionResult, (string HumanMessage, string IssueLink)? KnownFailure)> ExecuteAsync(
            string projectPlatform,
            string projectConfiguration,
            string projectFile,
            IAcquiredResource resource,
            bool dryRun,
            IFileBackedLog buildLog,
            ILog mainLog)
        {
            BuildLog = buildLog;
            (TestExecutingResult ExecutionResult, (string HumanMessage, string IssueLink)? KnownFailure)result = (TestExecutingResult.NotStarted, ((string HumanMessage, string IssueLink)?)null);
            var restoreResult = await RestoreNugetsAsync(buildLog, resource);

            if ((restoreResult & TestExecutingResult.Failed) == TestExecutingResult.Failed)
            {
                BuildLog.WriteLine($"Failed to restore nugets: {restoreResult}");
                result.ExecutionResult = restoreResult;
                return(result);
            }

            using (var xbuild = new Process()) {
                xbuild.StartInfo.FileName         = msbuildPath();
                xbuild.StartInfo.Arguments        = StringUtils.FormatArguments(GetToolArguments(projectPlatform, projectConfiguration, projectFile, buildLog));
                xbuild.StartInfo.WorkingDirectory = Path.GetDirectoryName(projectFile);
                EnvironmentManager.SetEnvironmentVariables(xbuild);
                xbuild.StartInfo.EnvironmentVariables ["MSBuildExtensionsPath"] = null;
                EventLogger.LogEvent(buildLog, "Building {0} ({1})", TestName, Mode);
                if (!dryRun)
                {
                    var timeout       = TimeSpan.FromMinutes(60);
                    var processResult = await ProcessManager.RunAsync(xbuild, buildLog, timeout);

                    if (processResult.TimedOut)
                    {
                        result.ExecutionResult = TestExecutingResult.TimedOut;
                        buildLog.WriteLine("Build timed out after {0} seconds.", timeout.TotalSeconds);
                    }
                    else if (processResult.Succeeded)
                    {
                        result.ExecutionResult = TestExecutingResult.Succeeded;
                    }
                    else
                    {
                        result.ExecutionResult = TestExecutingResult.Failed;
                        if (errorKnowledgeBase.IsKnownBuildIssue(buildLog, out result.KnownFailure))
                        {
                            buildLog.WriteLine($"Build has a known failure: '{result.KnownFailure}'");
                        }
                    }
                }
                mainLog.WriteLine("Built {0} ({1})", TestName, Mode);
            }
            return(result);
        }