From df8361c9b45f31304e062482faa19d1723a25534 Mon Sep 17 00:00:00 2001 From: Alaaeddine Chakroun Date: Thu, 9 May 2024 09:21:19 +0000 Subject: [PATCH] fix: json validation See merge request Linaro/WindowsPerf/wpa-plugin!20 === ChangeLog === * fix: json validation --- .../WperfProcessingSourceWithSourceParser.cs | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/WPAPlugin/WperfProcessingSourceWithSourceParser.cs b/WPAPlugin/WperfProcessingSourceWithSourceParser.cs index 2f77af5..727b6a7 100644 --- a/WPAPlugin/WperfProcessingSourceWithSourceParser.cs +++ b/WPAPlugin/WperfProcessingSourceWithSourceParser.cs @@ -29,11 +29,11 @@ // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -using Microsoft.Performance.SDK.Processing; -using NJsonSchema; using System.Collections.Generic; using System.IO; using System.Linq; +using Microsoft.Performance.SDK.Processing; +using NJsonSchema; using WPAPlugin.Schemas; namespace WPAPlugin @@ -64,7 +64,7 @@ public override ProcessingSourceInfo GetAboutInfo() new ContactInfo { Name = "Alaaeddine Chakroun", - EmailAddresses = new[]{ "alaaeddine.chakroun@daydevs.com" } + EmailAddresses = new[] { "alaaeddine.chakroun@daydevs.com" } }, }, ProjectInfo = new ProjectInfo @@ -92,6 +92,7 @@ ProcessorOptions options timelinePathList.Clear(); countingPathList.Clear(); + validationCache.Clear(); return new WperfCustomDataProcessorWithSourceParser( parser, options, @@ -100,9 +101,8 @@ ProcessorOptions options ); } - - private static Dictionary<(string, string), bool> validationCache = new Dictionary<(string, string), bool>(); - + private static Dictionary<(string, string), bool> validationCache = + new Dictionary<(string, string), bool>(); private static bool ValidateJson(string sourcePath, JsonSchemas.Schemas schema) { @@ -111,7 +111,8 @@ private static bool ValidateJson(string sourcePath, JsonSchemas.Schemas schema) { return validationCache[cacheKey]; } - var parsedSchema = JsonSchema.FromSampleJson(JsonSchemas.GetSchemaByKey(schema)); + var selectedSchema = JsonSchemas.GetSchemaByKey(schema); + var parsedSchema = JsonSchema.FromJsonAsync(selectedSchema).Result; var jsonContent = File.ReadAllText(sourcePath); var errors = parsedSchema.Validate(jsonContent);