This repository has been archived by the owner on Feb 15, 2021. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy pathSchemaPerformance.cs
105 lines (87 loc) · 2.67 KB
/
SchemaPerformance.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
using System;
using System.Diagnostics;
using System.IO;
using System.Threading;
using System.Threading.Tasks;
using Newtonsoft.Json.Linq;
using Newtonsoft.Json.Schema;
using JsonSchema = Manatee.Json.Schema.JsonSchema;
using JsonSerializer = Manatee.Json.Serialization.JsonSerializer;
namespace Manatee.Json.Tests.Benchmark
{
public class SchemaPerformance
{
private static readonly Stopwatch _manateeWatch = new Stopwatch();
private static bool _shouldOutput;
private static readonly JsonSerializer _serializer = new JsonSerializer
{
Options =
{
CaseSensitiveDeserialization = false
}
};
public static async Task Run()
{
JsonOptions.LogCategory = LogCategory.Schema;
await _RunBulk();
}
private static async Task _RunBulk()
{
var dataString = await File.ReadAllTextAsync("TestData/large_message.json");
var schemaString = await File.ReadAllTextAsync("TestData/schema.json");
Console.WriteLine($"Data length: {dataString.Length}");
Console.WriteLine($"Schema length: {schemaString.Length}");
var runCount = 1;
var page = 1;
for (int i = 0; i < runCount; i++)
{
_shouldOutput = i % page == 0 || i == runCount - 1;
Log($"Run {i}");
_ExecuteTest(dataString, schemaString);
Log();
Log();
}
}
private static void _ExecuteTest(string dataString, string schemaString)
{
Log($"\nNewton");
_Run(dataString, schemaString, _NewtonDeserializeAndValidate, true);
Log($"\nManatee");
_Run(dataString, schemaString, _ManateeDeserializeAndValidate, true);
}
private static void _Run(string dataString, string schemaString, Action<string, string> deserializeAndValidate, bool details = false)
{
Thread.Sleep(1);
var watch = new Stopwatch();
watch.Start();
deserializeAndValidate(dataString, schemaString);
watch.Stop();
Log($" Deserialize and validate: {watch.Elapsed}");
}
private static void Log(string message = null)
{
if (_shouldOutput)
Console.WriteLine(message);
}
private static void _ManateeDeserializeAndValidate(string dataString, string schemaString)
{
_manateeWatch.Reset();
_manateeWatch.Start();
var json = JsonValue.Parse(dataString);
var schemaJson = JsonValue.Parse(schemaString);
var schema = new JsonSchema();
schema.FromJson(schemaJson, _serializer);
var result = schema.Validate(json);
_manateeWatch.Stop();
}
private static void _NewtonDeserializeAndValidate(string dataString, string schemaString)
{
_manateeWatch.Reset();
_manateeWatch.Start();
var schema = JSchema.Parse(schemaString);
var json = JObject.Parse(dataString);
var result = json.IsValid(schema);
_manateeWatch.Stop();
}
}
}