|
|
@@ -1,4 +1,6 @@
|
|
|
-using System.Collections.Generic;
|
|
|
+using System;
|
|
|
+using System.Collections.Generic;
|
|
|
+using System.Diagnostics;
|
|
|
using System.Linq;
|
|
|
using BenchmarkDotNet.Attributes;
|
|
|
using BenchmarkDotNet.Configs;
|
|
|
@@ -7,6 +9,8 @@ using BenchmarkDotNet.Running;
|
|
|
using Microsoft.VisualStudio.TestPlatform.TestHost;
|
|
|
using NUnit.Framework;
|
|
|
using QuestPDF.Drawing;
|
|
|
+using QuestPDF.Drawing.Proxy;
|
|
|
+using QuestPDF.Elements;
|
|
|
using QuestPDF.Infrastructure;
|
|
|
using QuestPDF.ReportSample.Layouts;
|
|
|
|
|
|
@@ -16,7 +20,9 @@ namespace QuestPDF.ReportSample
|
|
|
[MinColumn, MaxColumn, MeanColumn, MedianColumn]
|
|
|
public class PerformanceTests
|
|
|
{
|
|
|
- private StandardReport Report { get; set; }
|
|
|
+ private PageContext PageContext { get; set; }
|
|
|
+ private DocumentMetadata Metadata { get; set; }
|
|
|
+ private Container Content { get; set; }
|
|
|
|
|
|
[Test]
|
|
|
public void Run()
|
|
|
@@ -32,21 +38,33 @@ namespace QuestPDF.ReportSample
|
|
|
public void GenerateReportData()
|
|
|
{
|
|
|
var model = DataSource.GetReport();
|
|
|
- Report = new StandardReport(model);
|
|
|
+ var report = new StandardReport(model);
|
|
|
+ Metadata = report.GetMetadata();
|
|
|
+
|
|
|
+ var documentContainer = new DocumentContainer();
|
|
|
+ report.Compose(documentContainer);
|
|
|
+ Content = documentContainer.Compose();
|
|
|
+
|
|
|
+ PageContext = new PageContext();
|
|
|
+ DocumentGenerator.RenderPass(PageContext, new FreeCanvas(), Content, Metadata, null);
|
|
|
+
|
|
|
+ var sw = new Stopwatch();
|
|
|
+ sw.Start();
|
|
|
+
|
|
|
+ Content.HandleVisitor(x =>
|
|
|
+ {
|
|
|
+ if (x is ICacheable)
|
|
|
+ x.CreateProxy(y => new CacheProxy(y));
|
|
|
+ });
|
|
|
+
|
|
|
+ sw.Stop();
|
|
|
+ Console.WriteLine($"Creating cache took: {sw.ElapsedMilliseconds}");
|
|
|
}
|
|
|
|
|
|
[Benchmark]
|
|
|
public void GenerationTest()
|
|
|
{
|
|
|
- var container = new DocumentContainer();
|
|
|
- Report.Compose(container);
|
|
|
- var content = container.Compose();
|
|
|
-
|
|
|
- var metadata = Report.GetMetadata();
|
|
|
- var pageContext = new PageContext();
|
|
|
-
|
|
|
- DocumentGenerator.RenderPass(pageContext, new FreeCanvas(), content, metadata, null);
|
|
|
- DocumentGenerator.RenderPass(pageContext, new FreeCanvas(), content, metadata, null);
|
|
|
+ DocumentGenerator.RenderPass(PageContext, new FreeCanvas(), Content, Metadata, null);
|
|
|
}
|
|
|
}
|
|
|
}
|