private BenchmarkBuildResult Build(IBenchmarkLogger logger, IBenchmarkToolchainFacade toolchain, BenchmarkGenerateResult generateResult) { logger.WriteLineInfo("// *** Build ***"); var buildResult = toolchain.Build(generateResult); if (buildResult.IsBuildSuccess) { logger.WriteLineInfo("// Result = Success"); } else { logger.WriteLineError("// Result = Failure"); if (buildResult.BuildException != null) { logger.WriteLineError($"// Exception: {buildResult.BuildException.Message}"); } } logger.NewLine(); return(buildResult); }
private BenchmarkGenerateResult Generate(IBenchmarkLogger logger, IBenchmarkToolchainFacade toolchain) { logger.WriteLineInfo("// *** Generate *** "); var generateResult = toolchain.Generate(); if (generateResult.IsGenerateSuccess) { logger.WriteLineInfo("// Result = Success"); logger.WriteLineInfo($"// {nameof(generateResult.DirectoryPath)} = {generateResult.DirectoryPath}"); } else { logger.WriteLineError("// Result = Failure"); if (generateResult.GenerateException != null) { logger.WriteLineError($"// Exception: {generateResult.GenerateException.Message}"); } } logger.NewLine(); return(generateResult); }
private List <BenchmarkRunReport> Execute(IBenchmarkLogger logger, Benchmark benchmark, IList <string> importantPropertyNames, BenchmarkParameters parameters, IBenchmarkToolchainFacade toolchain, BenchmarkBuildResult buildResult) { logger.WriteLineInfo("// *** Execute ***"); var processCount = Math.Max(1, benchmark.Task.ProcessCount); var runReports = new List <BenchmarkRunReport>(); for (int processNumber = 0; processNumber < processCount; processNumber++) { logger.WriteLineInfo($"// Run, Process: {processNumber + 1} / {processCount}"); if (parameters != null) { logger.WriteLineInfo($"// {parameters.ToInfo()}"); } if (importantPropertyNames.Any()) { logger.WriteInfo("// "); foreach (var name in importantPropertyNames) { logger.WriteInfo($"{name}={benchmark.Properties.GetValue(name)} "); } logger.NewLine(); } var execResult = toolchain.Execute(buildResult, parameters, Plugins.CompositeDiagnoser); if (execResult.FoundExecutable) { var iterRunReports = execResult.Data.Select(line => BenchmarkRunReport.Parse(logger, line)).Where(r => r != null).ToList(); runReports.AddRange(iterRunReports); } else { logger.WriteLineError("Executable not found"); } } logger.NewLine(); return(runReports); }
private BenchmarkBuildResult Build(IBenchmarkToolchainFacade toolchain, BenchmarkGenerateResult generateResult) { Logger.WriteLineInfo("// *** Build ***"); var buildResult = toolchain.Build(generateResult); if (buildResult.IsBuildSuccess) { Logger.WriteLineInfo("// Result = Success"); } else { Logger.WriteLineError("// Result = Failure"); if (buildResult.BuildException != null) Logger.WriteLineError($"// Exception: {buildResult.BuildException.Message}"); } Logger.NewLine(); return buildResult; }
private BenchmarkGenerateResult Generate(IBenchmarkToolchainFacade toolchain) { Logger.WriteLineInfo("// *** Generate *** "); var generateResult = toolchain.Generate(); if (generateResult.IsGenerateSuccess) { Logger.WriteLineInfo("// Result = Success"); Logger.WriteLineInfo($"// {nameof(generateResult.DirectoryPath)} = {generateResult.DirectoryPath}"); } else { Logger.WriteLineError("// Result = Failure"); if (generateResult.GenerateException != null) Logger.WriteLineError($"// Exception: {generateResult.GenerateException.Message}"); } Logger.NewLine(); return generateResult; }
private List<BenchmarkRunReport> Exec(Benchmark benchmark, IList<string> importantPropertyNames, BenchmarkParameters parameters, IBenchmarkToolchainFacade toolchain, BenchmarkBuildResult buildResult) { Logger.WriteLineInfo("// *** Exec ***"); var processCount = Math.Max(1, benchmark.Task.ProcessCount); var runReports = new List<BenchmarkRunReport>(); for (int processNumber = 0; processNumber < processCount; processNumber++) { Logger.WriteLineInfo($"// Run, Process: {processNumber + 1} / {processCount}"); if (parameters != null) Logger.WriteLineInfo($"// {parameters.ToInfo()}"); if (importantPropertyNames.Any()) { Logger.WriteInfo("// "); foreach (var name in importantPropertyNames) Logger.WriteInfo($"{name}={benchmark.Properties.GetValue(name)} "); Logger.NewLine(); } var execResult = toolchain.Exec(buildResult, parameters); if (execResult.FoundExecutable) { var iterRunReports = execResult.Data.Select(line => BenchmarkRunReport.Parse(Logger, line)).Where(r => r != null).ToList(); runReports.AddRange(iterRunReports); } else { Logger.WriteLineError("Executable not found"); } } Logger.NewLine(); return runReports; }