/// The main entry of the application /// @para cmdArgs contains an array of commandline parameters that are parsed using CommandLine.Dll public static void Main(string[] cmdArgs) { //Global catch to prevent crash try { Run(cmdArgs); } catch (Exception ex) { if (null != _log) _log.Error("Exception during run: {0}", ex.Message); else Console.Error.WriteLine("Exception during run: {0}", ex.Message); var options = new Options(); Console.WriteLine(options.GetUsage()); #if DEBUG Console.ReadLine(); #endif Environment.Exit(2); } }
/// The main entry of the application /// @para cmdArgs contains an array of commandline parameters that are parsed using CommandLine.Dll public static void Main(string[] cmdArgs) { //Global catch to prevent crash try { Run(cmdArgs); } catch (Exception ex) { if (null != _log) { _log.Error("Exception during run: {0}", ex.Message); } else { Console.Error.WriteLine("Exception during run: {0}", ex.Message); } var options = new Options(); Console.WriteLine(options.GetUsage()); #if DEBUG Console.ReadLine(); #endif Environment.Exit(2); } }
private static void Run(string[] cmdArgs) { var options = new Options(); Parser parser = new Parser(); if (parser.ParseArguments(cmdArgs, options)) { if (options.Verbosity > 0) { _log.Verbosity = (LogLevel)options.Verbosity; } else #if DEBUG { _log.Verbosity = LogLevel.Debug; } #endif { _log.WriteLine(LogLevel.Debug, "Using CSV Compare Version {0} ({1})", Info.AssemblyVersion, Assembly.GetExecutingAssembly().GetName().ProcessorArchitecture); } _log.WriteLine(LogLevel.Debug, "Starting new result check @{0}", DateTime.Now); _log.WriteLine(LogLevel.Debug, "Parsing commandline options: {0} * {1}", Environment.NewLine, string.Join(" ", cmdArgs)); _log.WriteLine(LogLevel.Debug, "Successfully parsed the following options:"); _log.WriteLine(LogLevel.Debug, "Operation mode is {0}", options.Mode); _log.WriteLine(LogLevel.Debug, "Tolerance is {0}", options.Tolerance); if (options.Delimiter == 0) { _log.WriteLine(LogLevel.Debug, "Delimiter is not explicitly set, so I am using \";\""); options.Delimiter = ';'; } else { _log.WriteLine(LogLevel.Debug, "Delimiter to be used to parse csv has been explicitly set and is \"{0}\"", options.Delimiter); } if (null == options.Logfile) { _log.WriteLine(LogLevel.Debug, "Logfile is empty"); } else { if (!options.OverrideOutput && File.Exists(options.Logfile)) { options.Logfile = Path.Combine(Path.GetDirectoryName(options.Logfile), string.Format(CultureInfo.CurrentCulture, "{0:yyyy-MM-ddTHH-mm-ss}_log.txt", DateTime.Now)); _log.WriteLine(LogLevel.Warning, "Logfile already exists and --override has been set to false. Changed log file name to \"{0}\"", options.Logfile); } else { _log.WriteLine(LogLevel.Debug, "Logfile is {0}", options.Logfile); } _log.SetLogFile(new FileInfo(options.Logfile)); } if (options.Items.Count == 0) { _log.Error("No files or directories to be compared have been given."); Console.WriteLine(options.GetUsage()); Environment.Exit(2); } MetaReport meta = new MetaReport(); if (String.IsNullOrEmpty(options.ReportDir))//report to directory of compare file if no report directory has been set { FileAttributes attr = File.GetAttributes(options.Items[0]); if ((attr & FileAttributes.Directory) == FileAttributes.Directory) { options.ReportDir = Path.GetFullPath(options.Items[0]); } else { options.ReportDir = Path.GetDirectoryName(options.Items[0]); } _log.WriteLine(LogLevel.Warning, "No report directory has been set, using \"{0}\"", options.ReportDir); } else { meta.ReportDirSet = true; options.ReportDir = Path.GetFullPath(options.ReportDir);//normalize report dir (i.e. make absolut if relative) if (!Directory.Exists(options.ReportDir)) { Directory.CreateDirectory(options.ReportDir); } } meta.FileName = new FileInfo(Path.Combine(options.ReportDir, string.Format(CultureInfo.CurrentCulture, "{0:yyyy-MM-dd}-index.html", DateTime.Now))); switch (options.Mode) { case OperationMode.CsvFileCompare: //compare the file given as option 1 with the file given as option 2 if (options.Items.Count != 2) { _log.Error("Not enough arguments have been given. Please specify base and compare file."); Console.WriteLine(options.GetUsage()); Environment.Exit(2); } Report rep = CheckFiles(options); if (null != rep && !options.NoMetaReport) { meta.Reports.Add(rep); //Return "1" on invalid testresults meta.WriteReport(_log, options); } break; case OperationMode.CsvTreeCompare: //compare files in the dirctory option 1 with the files in directory option 2 if (options.Items.Count != 2) { _log.Error("Not enough arguments have been given. Please specify base and compare directory."); Console.WriteLine(options.GetUsage()); Environment.Exit(2); } CheckTrees(meta, options); if (!options.NoMetaReport) { meta.WriteReport(_log, options); } break; case OperationMode.FmuChecker: //run FMU checker on all fmus in directory given via option 1 and compare the result to CSVs in the source directory if (options.Items.Count != 1) { if (options.Items.Count == 0) { _log.Error("Not enough arguments have been given. Please specify a compare directory with FMUs."); } else { _log.Error("Too many arguments have been given. Please specify a compare directory with FMUs only."); } Console.WriteLine(options.GetUsage()); Environment.Exit(2); } if (string.IsNullOrEmpty(options.CheckerPath)) { _log.Error("No path to FMU Checker binary given."); Console.WriteLine(options.GetUsage()); } else { CheckFMUTree(ref meta, options); meta.WriteReport(_log, options); } break; case OperationMode.PlotOnly: foreach (string item in options.Items) { using (CsvFile file = new CsvFile(item, options, _log)) { meta.Reports.Add(file.PlotCsvFile(null, _log)); } } meta.WriteReport(_log, options); break; default: //Invalid mode Console.WriteLine(options.GetUsage()); break; } } else { Console.WriteLine(options.GetUsage()); } #if DEBUG //Keep window open in debug mode _log.WriteLine(LogLevel.Debug, "Done."); Console.ReadLine(); #endif }
private static void Run(string[] cmdArgs) { var options = new Options(); Parser parser = new Parser(); if (parser.ParseArguments(cmdArgs, options)) { if (options.Verbosity > 0) _log.Verbosity = (LogLevel)options.Verbosity; else #if DEBUG _log.Verbosity = LogLevel.Debug; #endif _log.WriteLine(LogLevel.Debug, "Using CSV Compare Version {0} ({1})", Info.AssemblyVersion, Assembly.GetExecutingAssembly().GetName().ProcessorArchitecture); _log.WriteLine(LogLevel.Debug, "Starting new result check @{0}", DateTime.Now); _log.WriteLine(LogLevel.Debug, "Parsing commandline options: {0} * {1}", Environment.NewLine, string.Join(" ", cmdArgs)); _log.WriteLine(LogLevel.Debug, "Successfully parsed the following options:"); _log.WriteLine(LogLevel.Debug, "Operation mode is {0}", options.Mode); _log.WriteLine(LogLevel.Debug, "Tolerance is {0}", options.Tolerance); if (options.Delimiter == 0) { _log.WriteLine(LogLevel.Debug, "Delimiter is not explicitly set, so I am using \";\""); options.Delimiter = ';'; } else _log.WriteLine(LogLevel.Debug, "Delimiter to be used to parse csv has been explicitly set and is \"{0}\"", options.Delimiter); if (null == options.Logfile) _log.WriteLine(LogLevel.Debug, "Logfile is empty"); else { if (!options.OverrideOutput && File.Exists(options.Logfile)) { options.Logfile = Path.Combine(Path.GetDirectoryName(options.Logfile), string.Format(CultureInfo.CurrentCulture, "{0:yyyy-MM-ddTHH-mm-ss}_log.txt", DateTime.Now)); _log.WriteLine(LogLevel.Warning, "Logfile already exists and --override has been set to false. Changed log file name to \"{0}\"", options.Logfile); } else _log.WriteLine(LogLevel.Debug, "Logfile is {0}", options.Logfile); _log.SetLogFile(new FileInfo(options.Logfile)); } if (options.Items.Count == 0) { _log.Error("No files or directories to be compared have been given."); Console.WriteLine(options.GetUsage()); Environment.Exit(2); } MetaReport meta = new MetaReport(); if (String.IsNullOrEmpty(options.ReportDir))//report to directory of compare file if no report directory has been set { FileAttributes attr = File.GetAttributes(options.Items[0]); if ((attr & FileAttributes.Directory) == FileAttributes.Directory) options.ReportDir = Path.GetFullPath(options.Items[0]); else options.ReportDir = Path.GetDirectoryName(options.Items[0]); _log.WriteLine(LogLevel.Warning, "No report directory has been set, using \"{0}\"", options.ReportDir); } else { meta.ReportDirSet = true; options.ReportDir = Path.GetFullPath(options.ReportDir);//normalize report dir (i.e. make absolut if relative) if (!Directory.Exists(options.ReportDir)) Directory.CreateDirectory(options.ReportDir); } meta.FileName = new FileInfo(Path.Combine(options.ReportDir, string.Format(CultureInfo.CurrentCulture, "{0:yyyy-MM-dd}-index.html", DateTime.Now))); switch (options.Mode) { case OperationMode.CsvFileCompare://compare the file given as option 1 with the file given as option 2 if (options.Items.Count != 2) { _log.Error("Not enough arguments have been given. Please specify base and compare file."); Console.WriteLine(options.GetUsage()); Environment.Exit(2); } Report rep = CheckFiles(options); if (null != rep && !options.NoMetaReport) { meta.Reports.Add(rep);//Return "1" on invalid testresults meta.WriteReport(_log, options); } break; case OperationMode.CsvTreeCompare://compare files in the dirctory option 1 with the files in directory option 2 if (options.Items.Count != 2) { _log.Error("Not enough arguments have been given. Please specify base and compare directory."); Console.WriteLine(options.GetUsage()); Environment.Exit(2); } CheckTrees(meta, options); if(!options.NoMetaReport) meta.WriteReport(_log, options); break; case OperationMode.FmuChecker://run FMU checker on all fmus in directory given via option 1 and compare the result to CSVs in the source directory if (options.Items.Count != 1) { if (options.Items.Count == 0) _log.Error("Not enough arguments have been given. Please specify a compare directory with FMUs."); else _log.Error("Too many arguments have been given. Please specify a compare directory with FMUs only."); Console.WriteLine(options.GetUsage()); Environment.Exit(2); } if (string.IsNullOrEmpty(options.CheckerPath)) { _log.Error("No path to FMU Checker binary given."); Console.WriteLine(options.GetUsage()); } else { CheckFMUTree(ref meta, options); meta.WriteReport(_log, options); } break; case OperationMode.PlotOnly: foreach (string item in options.Items) using (CsvFile file = new CsvFile(item, options, _log)) { meta.Reports.Add(file.PlotCsvFile(null, _log)); } meta.WriteReport(_log, options); break; default://Invalid mode Console.WriteLine(options.GetUsage()); break; } } else Console.WriteLine(options.GetUsage()); #if DEBUG //Keep window open in debug mode _log.WriteLine(LogLevel.Debug, "Done."); Console.ReadLine(); #endif }
public Report CompareFiles(Log log, CsvFile csvBase, string sReportPath, ref Options options) { int iInvalids = 0; Report rep = new Report(sReportPath); log.WriteLine("Comparing \"{0}\" to \"{1}\"", _fileName, csvBase.ToString()); rep.BaseFile = csvBase.ToString(); rep.CompareFile = _fileName; Curve reference = new Curve(); Curve compareCurve = new Curve(); TubeReport tubeReport = new TubeReport(); TubeSize size = null; Tube tube = new Tube(size); switch (options.Direction) { case ToleranceDirection.X: userchoice = 1; ///set to 1 for tolerenace in X axis break; case ToleranceDirection.Y: userchoice = 0; ///set to 0 for tolerance in Y-axis break; default: //Invalid mode Console.WriteLine(options.GetUsage()); break; } if (userchoice == 1) { IOptions tubeOptions = new Options1(_dRangeDelta, Axes.X); } else if (userchoice == 0) { IOptions tubeOptions = new Options1(_dRangeDelta, Axes.Y); } else { Console.WriteLine("opted for wrong choice"); Environment.ExitCode = 2; } foreach (KeyValuePair <string, List <double> > res in csvBase.Results) { if (!this.Results.ContainsKey(res.Key)) { log.Error("{0} not found in \"{1}\", skipping checks.", res.Key, this._fileName); rep.Chart.Add(new Chart() { Title = res.Key, Errors = 1 }); Environment.ExitCode = 1; continue; } else { compareCurve = new Curve(res.Key, this.XAxis.ToArray <double>(), this.Results[res.Key].ToArray <double>()); if (res.Value.Count == 0) { log.Error("{0} has no y-Values! Maybe error during parsing? Skipping", res.Key); continue; } reference = new Curve("Reference ", csvBase.XAxis.ToArray(), csvBase.Results[res.Key].ToArray()); if (!reference.ImportSuccessful) { log.Error("Error in the calculation of the tubes. Skipping {0}", res.Key); rep.Chart.Add(new Chart() { Title = res.Key, Errors = 1 }); continue; } if (reference.X.Length < compareCurve.X.Length) { log.WriteLine(LogLevel.Warning, "The resolution of the base x-axis is smaller than the compare x-axis. The better the base resolution is, the better the validation result will be!"); } else { log.WriteLine(LogLevel.Debug, "The resolution of the base x-axis is good."); } size = new TubeSize(reference, true); switch (options.Method) { case ExecutionMethod.Relative: if (userchoice == 1) { size.Calculate(_dRangeDelta, Axes.X, Relativity.Relative); } else { size.Calculate(_dRangeDelta, Axes.Y, Relativity.Relative); } break; case ExecutionMethod.Absolute: if (userchoice == 1) { size.Calculate(_dRangeDelta, Axes.X, Relativity.Absolute); } else { size.Calculate(_dRangeDelta, Axes.Y, Relativity.Absolute); } break; default: //Invalid mode Console.WriteLine(options.GetUsage()); break; } tube = new Tube(size); tubeReport = tube.Calculate(reference); tube.Validate(compareCurve); if (tubeReport.Valid == Validity.Valid) { log.WriteLine(res.Key + " is valid"); } else { log.WriteLine(LogLevel.Warning, "{0} is invalid! {1} errors have been found during validation.", res.Key, (null != tube.Report.Errors && null != tube.Report.Errors.X) ? tube.Report.Errors.X.Length : 0); iInvalids++; Environment.ExitCode = 1; } } if (null != tube.Report)//No charts for missing reports { PrepareCharts(reference, compareCurve, tube.Report.Errors, rep, tubeReport, res, options.UseBitmapPlots); } } rep.Tolerance = _dRangeDelta; string sResult = "na"; if (rep.TotalErrors == 0) { sResult = "passed"; } else { sResult = "failed"; } if (options.ComparisonFlag) { using (TextWriter writer = File.CreateText(string.Format("{0}{1}compare_{2}.log", Path.GetDirectoryName(_fileName), Path.DirectorySeparatorChar, sResult))) { //Content needs to be defined writer.WriteLine("CSV Compare Version {0} ({1})", Info.AssemblyVersion, Assembly.GetExecutingAssembly().GetName().ProcessorArchitecture); writer.WriteLine("Comparison result file for {0}", _fileName); writer.WriteLine(". Time: {0:o}", DateTime.Now); writer.WriteLine(". Operation: {0}", options.Mode); writer.WriteLine(". Tolerance: {0}", options.Tolerance); writer.WriteLine(". Execution Method: {0}", options.Method); writer.WriteLine(". Direction of Tolerence: {0}", options.Direction); writer.WriteLine(". Result: {0}", sResult); if (rep.TotalErrors > 0) { Chart pairMax = rep.Chart.Aggregate((l, r) => l.DeltaError > r.DeltaError ? l : r); if (pairMax.DeltaError > 0) { writer.WriteLine(". Largest error: {0}=>{1}", pairMax.Title, pairMax.DeltaError); writer.WriteLine(". Failed values:"); foreach (Chart c in (from r in rep.Chart where r.DeltaError > 0 select r).OrderByDescending(er => er.DeltaError)) { writer.WriteLine("{0}=>{1}", c.Title, c.DeltaError.ToString(CultureInfo.InvariantCulture)); } } } } } rep.WriteReport(log, (string.IsNullOrEmpty(options.ReportDir) || options.NoMetaReport) ? string.Empty : options.ReportDir, options); GC.Collect();//immediately forget big charts and data return(rep); }