From f97eb003330aed7cf61aadb4ea4f6a3eb64b79fa Mon Sep 17 00:00:00 2001 From: Arthur Gavlyukovskiy Date: Sun, 19 Nov 2023 17:14:47 +0100 Subject: [PATCH] Rework benchmarks to use different jsons (#14) * Rework benchmarks to use different jsons * Added benchmark results * Polish documentation Co-authored-by: Breus * Fix link, maybe * Fix link, maybe * Fix link, certainly --------- Co-authored-by: Breus --- README.adoc | 25 ++- src/jmh/benchmark-history/2022-06-09.md | 11 ++ src/jmh/benchmark-history/2022-07-02.md | 11 ++ src/jmh/benchmark-history/2022-07-12.md | 11 ++ src/jmh/benchmark-history/2022-09-11.md | 11 ++ src/jmh/benchmark-history/2023-11-17.md | 53 ++++++ src/jmh/benchmark-history/README.md | 3 + .../masker/json/BaselineBenchmark.java | 0 .../JsonMaskSingleTargetKeyBenchmark.java | 120 ------------- src/jmh/resources/benchmark-history.adoc | 73 -------- src/jmh/resources/json-128kb.json | 0 src/jmh/resources/json-200b.json | 0 src/jmh/resources/json-2mb.json | 0 src/jmh/resources/json-4kb.json | 0 src/jmh/resources/large-input-benchmark.json | 168 ------------------ 15 files changed, 123 insertions(+), 363 deletions(-) create mode 100644 src/jmh/benchmark-history/2022-06-09.md create mode 100644 src/jmh/benchmark-history/2022-07-02.md create mode 100644 src/jmh/benchmark-history/2022-07-12.md create mode 100644 src/jmh/benchmark-history/2022-09-11.md create mode 100644 src/jmh/benchmark-history/2023-11-17.md create mode 100644 src/jmh/benchmark-history/README.md create mode 100644 src/jmh/java/dev/blaauwendraad/masker/json/BaselineBenchmark.java delete mode 100644 src/jmh/java/dev/blaauwendraad/masker/json/JsonMaskSingleTargetKeyBenchmark.java delete mode 100644 src/jmh/resources/benchmark-history.adoc create mode 100644 src/jmh/resources/json-128kb.json create mode 100644 src/jmh/resources/json-200b.json create mode 100644 src/jmh/resources/json-2mb.json create mode 100644 src/jmh/resources/json-4kb.json delete mode 100644 src/jmh/resources/large-input-benchmark.json diff --git a/README.adoc b/README.adoc index 39cfaa84..45e1b651 100644 --- a/README.adoc +++ b/README.adoc @@ -6,7 +6,8 @@ image:https://img.shields.io/maven-central/v/dev.blaauwendraad/json-masker[Maven JSON masker which can be used to mask strings and numbers from JSON messages, corresponding to a (set of) target key(s). Alternatively, it can be used to mask all strings and numbers from a JSON message except the ones corresponding to the target keys. -The implementation is focused on maximum (time) performance using Java and requires no additional third-party runtime dependencies. +The library provides a convenient API and its implementation is focused on maximum (time) performance using Java. +No additional third-party runtime dependencies are required for this library. == Features @@ -144,8 +145,28 @@ String output = JsonMasker.getMasker(JsonMaskingConfig.custom( == Performance considerations -This library uses a dedicated multi-target algorithm by looking for a JSON key and checking whether the target key set contains this key in constant time. +This library uses a dedicated multi-target algorithm by looking for a JSON key and checking whether the target key set +contains this key in constant time. The time complexity of this algorithm scales only linear in the message input length. Additionally, the target key set size has negligible impact on the performance. + +== Benchmarks + +[source] +---- +Benchmark (jsonSize) (numberOfKeys) Mode Score Units +BaselineBenchmark.noop 4kb 100 thrpt 1567094.010 ops/s +BaselineBenchmark.jackson 4kb 100 thrpt 75569.597 ops/s +JsonMaskerBenchmark.maskJsonBytes 4kb 100 thrpt 405496.513 ops/s +JsonMaskerBenchmark.maskJsonString 4kb 100 thrpt 346559.740 ops/s + +BaselineBenchmark.noop 2mb 100 thrpt 2263.683 ops/s +BaselineBenchmark.jackson 2mb 100 thrpt 7.923 ops/s +JsonMaskerBenchmark.maskJsonBytes 2mb 100 thrpt 2493.899 ops/s +JsonMaskerBenchmark.maskJsonString 2mb 100 thrpt 1312.198 ops/s +---- + +For full benchmark results see link:src/jmh/benchmark-history[benchmark-history] + diff --git a/src/jmh/benchmark-history/2022-06-09.md b/src/jmh/benchmark-history/2022-06-09.md new file mode 100644 index 00000000..3ce7f677 --- /dev/null +++ b/src/jmh/benchmark-history/2022-06-09.md @@ -0,0 +1,11 @@ +CPU: MacBook Pro M1 + +```text +Benchmark Mode Cnt Score Error Units +JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysLargeJson avgt 2649,220 ns/op +JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysSmallJson avgt 246,187 ns/op +JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysLargeJson avgt 260032,673 ns/op +JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysSmallJson avgt 15819,945 ns/op +JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysLargeJson avgt 142586,845 ns/op +JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysSmallJson avgt 3156,930 ns/op +``` diff --git a/src/jmh/benchmark-history/2022-07-02.md b/src/jmh/benchmark-history/2022-07-02.md new file mode 100644 index 00000000..b84c2729 --- /dev/null +++ b/src/jmh/benchmark-history/2022-07-02.md @@ -0,0 +1,11 @@ +CPU: MacBook Pro M1 + +```text +Benchmark Mode Cnt Score Error Units +JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysLargeJson avgt 2741,496 ns/op +JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysSmallJson avgt 153,333 ns/op +JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysLargeJson avgt 259726,763 ns/op +JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysSmallJson avgt 14396,989 ns/op +JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysLargeJson avgt 146207,944 ns/op +JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysSmallJson avgt 3102,921 ns/op +``` diff --git a/src/jmh/benchmark-history/2022-07-12.md b/src/jmh/benchmark-history/2022-07-12.md new file mode 100644 index 00000000..8c5caf7b --- /dev/null +++ b/src/jmh/benchmark-history/2022-07-12.md @@ -0,0 +1,11 @@ +CPU: MacBook Pro M1 + +```text +Benchmark Mode Cnt Score Error Units +JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysLargeJson avgt 2512,185 ns/op +JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysSmallJson avgt 165,912 ns/op +JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysLargeJson avgt 262763,770 ns/op +JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysSmallJson avgt 14650,831 ns/op +JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysLargeJson avgt 142375,488 ns/op +JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysSmallJson avgt 3125,639 ns/op +``` diff --git a/src/jmh/benchmark-history/2022-09-11.md b/src/jmh/benchmark-history/2022-09-11.md new file mode 100644 index 00000000..94b5ffc8 --- /dev/null +++ b/src/jmh/benchmark-history/2022-09-11.md @@ -0,0 +1,11 @@ +CPU: MacBook Pro M1 + +```text +Benchmark Mode Cnt Score Error Units +JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysLargeJson avgt 2560,033 ns/op +JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysSmallJson avgt 156,414 ns/op +JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysLargeJson avgt 258476,113 ns/op +JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysSmallJson avgt 14488,738 ns/op +JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysLargeJson avgt 141392,930 ns/op +JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysSmallJson avgt 3079,517 ns/op +``` diff --git a/src/jmh/benchmark-history/2023-11-17.md b/src/jmh/benchmark-history/2023-11-17.md new file mode 100644 index 00000000..9b8d3291 --- /dev/null +++ b/src/jmh/benchmark-history/2023-11-17.md @@ -0,0 +1,53 @@ +CPU: AMD Ryzen 5 7600X + +```text +Benchmark (jsonSize) (numberOfKeys) (obfuscationLength) Mode Cnt Score Error Units +BaselineBenchmark.jackson 200b 1 N/A thrpt 1262056.726 ops/s +BaselineBenchmark.jackson 200b 100 N/A thrpt 1065026.221 ops/s +BaselineBenchmark.jackson 4kb 1 N/A thrpt 92561.560 ops/s +BaselineBenchmark.jackson 4kb 100 N/A thrpt 75569.597 ops/s +BaselineBenchmark.jackson 128kb 1 N/A thrpt 1879.056 ops/s +BaselineBenchmark.jackson 128kb 100 N/A thrpt 1911.682 ops/s +BaselineBenchmark.jackson 2mb 1 N/A thrpt 18.959 ops/s +BaselineBenchmark.jackson 2mb 100 N/A thrpt 7.923 ops/s +BaselineBenchmark.noop 200b 1 N/A thrpt 26769763.013 ops/s +BaselineBenchmark.noop 200b 100 N/A thrpt 27416983.668 ops/s +BaselineBenchmark.noop 4kb 1 N/A thrpt 1566917.285 ops/s +BaselineBenchmark.noop 4kb 100 N/A thrpt 1567094.010 ops/s +BaselineBenchmark.noop 128kb 1 N/A thrpt 36703.455 ops/s +BaselineBenchmark.noop 128kb 100 N/A thrpt 36643.225 ops/s +BaselineBenchmark.noop 2mb 1 N/A thrpt 2263.673 ops/s +BaselineBenchmark.noop 2mb 100 N/A thrpt 2263.683 ops/s +JsonMaskerBenchmark.maskJsonBytes 200b 1 -1 thrpt 3153816.154 ops/s +JsonMaskerBenchmark.maskJsonBytes 200b 1 8 thrpt 3182263.676 ops/s +JsonMaskerBenchmark.maskJsonBytes 200b 100 -1 thrpt 2821470.475 ops/s +JsonMaskerBenchmark.maskJsonBytes 200b 100 8 thrpt 2187225.371 ops/s +JsonMaskerBenchmark.maskJsonBytes 4kb 1 -1 thrpt 451014.030 ops/s +JsonMaskerBenchmark.maskJsonBytes 4kb 1 8 thrpt 445217.877 ops/s +JsonMaskerBenchmark.maskJsonBytes 4kb 100 -1 thrpt 405496.513 ops/s +JsonMaskerBenchmark.maskJsonBytes 4kb 100 8 thrpt 281729.243 ops/s +JsonMaskerBenchmark.maskJsonBytes 128kb 1 -1 thrpt 8979.774 ops/s +JsonMaskerBenchmark.maskJsonBytes 128kb 1 8 thrpt 9111.752 ops/s +JsonMaskerBenchmark.maskJsonBytes 128kb 100 -1 thrpt 8294.319 ops/s +JsonMaskerBenchmark.maskJsonBytes 128kb 100 8 thrpt 5517.200 ops/s +JsonMaskerBenchmark.maskJsonBytes 2mb 1 -1 thrpt 2643.338 ops/s +JsonMaskerBenchmark.maskJsonBytes 2mb 1 8 thrpt 2646.343 ops/s +JsonMaskerBenchmark.maskJsonBytes 2mb 100 -1 thrpt 2493.899 ops/s +JsonMaskerBenchmark.maskJsonBytes 2mb 100 8 thrpt 731.205 ops/s +JsonMaskerBenchmark.maskJsonString 200b 1 -1 thrpt 2945155.807 ops/s +JsonMaskerBenchmark.maskJsonString 200b 1 8 thrpt 2930495.471 ops/s +JsonMaskerBenchmark.maskJsonString 200b 100 -1 thrpt 2646630.427 ops/s +JsonMaskerBenchmark.maskJsonString 200b 100 8 thrpt 2091125.858 ops/s +JsonMaskerBenchmark.maskJsonString 4kb 1 -1 thrpt 381344.021 ops/s +JsonMaskerBenchmark.maskJsonString 4kb 1 8 thrpt 391209.641 ops/s +JsonMaskerBenchmark.maskJsonString 4kb 100 -1 thrpt 346559.740 ops/s +JsonMaskerBenchmark.maskJsonString 4kb 100 8 thrpt 235969.211 ops/s +JsonMaskerBenchmark.maskJsonString 128kb 1 -1 thrpt 7982.235 ops/s +JsonMaskerBenchmark.maskJsonString 128kb 1 8 thrpt 7969.799 ops/s +JsonMaskerBenchmark.maskJsonString 128kb 100 -1 thrpt 7284.012 ops/s +JsonMaskerBenchmark.maskJsonString 128kb 100 8 thrpt 5076.018 ops/s +JsonMaskerBenchmark.maskJsonString 2mb 1 -1 thrpt 1324.640 ops/s +JsonMaskerBenchmark.maskJsonString 2mb 1 8 thrpt 1314.710 ops/s +JsonMaskerBenchmark.maskJsonString 2mb 100 -1 thrpt 1312.198 ops/s +JsonMaskerBenchmark.maskJsonString 2mb 100 8 thrpt 311.324 ops/s +``` diff --git a/src/jmh/benchmark-history/README.md b/src/jmh/benchmark-history/README.md new file mode 100644 index 00000000..0d12302e --- /dev/null +++ b/src/jmh/benchmark-history/README.md @@ -0,0 +1,3 @@ +### Benchmark history + +To prevent performance regressions, we keep track of changes in JMH benchmarks (10 s warmup, 10s average time) after each commit that could impact the performance of the masker. \ No newline at end of file diff --git a/src/jmh/java/dev/blaauwendraad/masker/json/BaselineBenchmark.java b/src/jmh/java/dev/blaauwendraad/masker/json/BaselineBenchmark.java new file mode 100644 index 00000000..e69de29b diff --git a/src/jmh/java/dev/blaauwendraad/masker/json/JsonMaskSingleTargetKeyBenchmark.java b/src/jmh/java/dev/blaauwendraad/masker/json/JsonMaskSingleTargetKeyBenchmark.java deleted file mode 100644 index edc20c74..00000000 --- a/src/jmh/java/dev/blaauwendraad/masker/json/JsonMaskSingleTargetKeyBenchmark.java +++ /dev/null @@ -1,120 +0,0 @@ -package dev.blaauwendraad.masker.json; - -import com.fasterxml.jackson.databind.JsonNode; -import com.fasterxml.jackson.databind.ObjectMapper; -import com.fasterxml.jackson.databind.node.JsonNodeFactory; -import com.fasterxml.jackson.databind.node.ObjectNode; -import dev.blaauwendraad.masker.json.config.JsonMaskingConfig; -import org.openjdk.jmh.annotations.Benchmark; -import org.openjdk.jmh.annotations.BenchmarkMode; -import org.openjdk.jmh.annotations.Fork; -import org.openjdk.jmh.annotations.Measurement; -import org.openjdk.jmh.annotations.Mode; -import org.openjdk.jmh.annotations.OutputTimeUnit; -import org.openjdk.jmh.annotations.Scope; -import org.openjdk.jmh.annotations.Warmup; -import org.openjdk.jmh.infra.Blackhole; - -import java.nio.charset.StandardCharsets; -import java.util.Set; -import java.util.concurrent.TimeUnit; - -@Warmup(iterations = 1, time = 3) -@Fork(value = 1) -@Measurement(iterations = 1, time = 3) -@OutputTimeUnit(TimeUnit.NANOSECONDS) -@BenchmarkMode(Mode.AverageTime) -public class JsonMaskSingleTargetKeyBenchmark { - - @org.openjdk.jmh.annotations.State(Scope.Thread) - public static class State { - String keyToBeMasked = "someSecret"; - - ObjectMapper mapper = new ObjectMapper(); - - String simpleJsonAsString = objectNode().set("someKey", objectNode().put("someSecret", "hello")).toString(); - byte[] simpleJsonAsBytes = simpleJsonAsString.getBytes(StandardCharsets.UTF_8); - - String largeJsonAsString = - ParseAndMaskUtil.readJsonFromFileAsString("large-input-benchmark.json", this.getClass()); - byte[] largeJsonAsBytes = largeJsonAsString.getBytes(StandardCharsets.UTF_8); - - JsonMasker defaultMasker = JsonMasker.getMasker(keyToBeMasked); - JsonMasker twoCharObfuscationLengthMasker = - JsonMasker.getMasker(JsonMaskingConfig.custom(Set.of(keyToBeMasked), - JsonMaskingConfig.TargetKeyMode.MASK).obfuscationLength(2).build()); - JsonMasker fiveCharObfuscationLengthMasker = - JsonMasker.getMasker(JsonMaskingConfig.custom(Set.of(keyToBeMasked), - JsonMaskingConfig.TargetKeyMode.MASK).obfuscationLength(5).build()); - JsonMasker sixCharObfuscationLengthMasker = - JsonMasker.getMasker(JsonMaskingConfig.custom(Set.of(keyToBeMasked), - JsonMaskingConfig.TargetKeyMode.MASK).obfuscationLength(6).build()); - - private ObjectNode objectNode() { - return JsonNodeFactory.instance.objectNode(); - } - } - - @Benchmark - public void maskSimpleJsonObjectString(State state, Blackhole blackhole) { - blackhole.consume(state.defaultMasker.mask(state.simpleJsonAsString)); - } - - @Benchmark - public void maskLargeJsonObjectString(State state, Blackhole blackhole) { - blackhole.consume(state.defaultMasker.mask(state.largeJsonAsString)); - } - - @Benchmark - public void maskSimpleJsonObjectBytes(State state, Blackhole blackhole) { - blackhole.consume(state.defaultMasker.mask(state.simpleJsonAsBytes)); - } - - @Benchmark - public void maskLargeJsonObjectBytes(State state, Blackhole blackhole) { - blackhole.consume(state.defaultMasker.mask(state.largeJsonAsBytes)); - } - - @Benchmark - public void maskSimpleJsonObjectObfuscateLengthShorterThanTargetValue(State state, Blackhole blackhole) { - blackhole.consume(state.twoCharObfuscationLengthMasker.mask(state.simpleJsonAsString)); - } - - @Benchmark - public void maskSimpleJsonObjectObfuscateLengthEqualToTargetValue(State state, Blackhole blackhole) { - blackhole.consume(state.fiveCharObfuscationLengthMasker.mask(state.simpleJsonAsString)); - } - - @Benchmark - public void maskSimpleJsonObjectObfuscateLengthLongerThanTargetValue(State state, Blackhole blackhole) { - blackhole.consume(state.sixCharObfuscationLengthMasker.mask(state.simpleJsonAsString)); - } - - @Benchmark - public void parseAndMaskSmallJsonObjectAsByte(State state, Blackhole blackhole) throws Exception { - JsonNode jsonNode = - ParseAndMaskUtil.mask(state.simpleJsonAsBytes, state.keyToBeMasked, JsonMaskingConfig.TargetKeyMode.MASK, state.mapper); - blackhole.consume(jsonNode); - } - - @Benchmark - public void parseAndMaskSmallJsonObjectAsString(State state, Blackhole blackhole) throws Exception { - JsonNode jsonNode = - ParseAndMaskUtil.mask(state.simpleJsonAsString, state.keyToBeMasked, JsonMaskingConfig.TargetKeyMode.MASK, state.mapper); - blackhole.consume(jsonNode); - } - - @Benchmark - public void parseAndMaskLargeJsonObjectAsString(State state, Blackhole blackhole) throws Exception { - JsonNode jsonNode = - ParseAndMaskUtil.mask(state.largeJsonAsString, state.keyToBeMasked, JsonMaskingConfig.TargetKeyMode.MASK, state.mapper); - blackhole.consume(jsonNode); - } - - @Benchmark - public void parseAndMaskLargeJsonObjectAsBytes(State state, Blackhole blackhole) throws Exception { - JsonNode jsonNode = - ParseAndMaskUtil.mask(state.largeJsonAsBytes, state.keyToBeMasked, JsonMaskingConfig.TargetKeyMode.MASK, state.mapper); - blackhole.consume(jsonNode); - } -} diff --git a/src/jmh/resources/benchmark-history.adoc b/src/jmh/resources/benchmark-history.adoc deleted file mode 100644 index b4768f2b..00000000 --- a/src/jmh/resources/benchmark-history.adoc +++ /dev/null @@ -1,73 +0,0 @@ -= Benchmark history - -To prevent performance regressions, we keep track of changes in JMH benchmarks (10 s warmup, 10s average time) after each commit that could impact the performance of the masker. - -== Measurements - -19-06-2022 - -[source] ----- -Benchmark Mode Cnt Score Error Units -JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysLargeJson avgt 2649,220 ns/op -JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysSmallJson avgt 246,187 ns/op -JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysLargeJson avgt 260032,673 ns/op -JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysSmallJson avgt 15819,945 ns/op -JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysLargeJson avgt 142586,845 ns/op -JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysSmallJson avgt 3156,930 ns/op ----- - -[source] ----- -Benchmark Mode Cnt Score Error Units -JsonMaskSingleTargetKeyBenchmark.maskLargeJsonObjectBytes avgt 3464,961 ns/op -JsonMaskSingleTargetKeyBenchmark.maskLargeJsonObjectString avgt 3461,907 ns/op -JsonMaskSingleTargetKeyBenchmark.maskSimpleJsonObjectBytes avgt 171,354 ns/op -JsonMaskSingleTargetKeyBenchmark.maskSimpleJsonObjectObfuscateLengthEqualToTargetValue avgt 171,603 ns/op -JsonMaskSingleTargetKeyBenchmark.maskSimpleJsonObjectObfuscateLengthLongerThanTargetValue avgt 166,287 ns/op -JsonMaskSingleTargetKeyBenchmark.maskSimpleJsonObjectObfuscateLengthShorterThanTargetValue avgt 146,020 ns/op -JsonMaskSingleTargetKeyBenchmark.maskSimpleJsonObjectString avgt 173,057 ns/op -JsonMaskSingleTargetKeyBenchmark.parseAndMaskLargeJsonObjectAsBytes avgt 7674,787 ns/op -JsonMaskSingleTargetKeyBenchmark.parseAndMaskLargeJsonObjectAsString avgt 8871,494 ns/op -JsonMaskSingleTargetKeyBenchmark.parseAndMaskSmallJsonObjectAsByte avgt 184,661 ns/op -JsonMaskSingleTargetKeyBenchmark.parseAndMaskSmallJsonObjectAsString avgt 203,854 ns/op ----- - -02-07-2022 - -[source] ----- -Benchmark Mode Cnt Score Error Units -JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysLargeJson avgt 2741,496 ns/op -JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysSmallJson avgt 153,333 ns/op -JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysLargeJson avgt 259726,763 ns/op -JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysSmallJson avgt 14396,989 ns/op -JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysLargeJson avgt 146207,944 ns/op -JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysSmallJson avgt 3102,921 ns/op ----- - -12-07-2022 - -[source] ----- -Benchmark Mode Cnt Score Error Units -JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysLargeJson avgt 2512,185 ns/op -JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysSmallJson avgt 165,912 ns/op -JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysLargeJson avgt 262763,770 ns/op -JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysSmallJson avgt 14650,831 ns/op -JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysLargeJson avgt 142375,488 ns/op -JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysSmallJson avgt 3125,639 ns/op ----- - -11-09-2022 - -[source] ----- -Benchmark Mode Cnt Score Error Units -JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysLargeJson avgt 2560,033 ns/op -JsonMaskMultipleTargetKeysBenchmark.keyContainsMaskMultiKeysSmallJson avgt 156,414 ns/op -JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysLargeJson avgt 258476,113 ns/op -JsonMaskMultipleTargetKeysBenchmark.loopMaskMultipleKeysSmallJson avgt 14488,738 ns/op -JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysLargeJson avgt 141392,930 ns/op -JsonMaskMultipleTargetKeysBenchmark.parseAndMaskMultiKeysSmallJson avgt 3079,517 ns/op ----- \ No newline at end of file diff --git a/src/jmh/resources/json-128kb.json b/src/jmh/resources/json-128kb.json new file mode 100644 index 00000000..e69de29b diff --git a/src/jmh/resources/json-200b.json b/src/jmh/resources/json-200b.json new file mode 100644 index 00000000..e69de29b diff --git a/src/jmh/resources/json-2mb.json b/src/jmh/resources/json-2mb.json new file mode 100644 index 00000000..e69de29b diff --git a/src/jmh/resources/json-4kb.json b/src/jmh/resources/json-4kb.json new file mode 100644 index 00000000..e69de29b diff --git a/src/jmh/resources/large-input-benchmark.json b/src/jmh/resources/large-input-benchmark.json deleted file mode 100644 index 7c0c6aef..00000000 --- a/src/jmh/resources/large-input-benchmark.json +++ /dev/null @@ -1,168 +0,0 @@ -{ - "_id": "620bdbb727f7966c44697929", - "index": 0, - "guid": "859a2c29-3634-4741-9059-a00b706f3b1c", - "isActive": false, - "balance": "$3,780.28", - "age": 23, - "eyeColor": "green", - "name": "Nolan Velez", - "gender": "male", - "company": "DATAGENE", - "email": "nolanvelez@datagene.com", - "phone": "+1 (957) 419-3878", - "address": "305 Furman Street, Munjor, District Of Columbia, 1562", - "about": "Lorem adipisicing consectetur ullamco officia Lorem sint exercitation anim incididunt cupidatat. Dolor officia aute esse do laborum. Enim non minim minim adipisicing do cupidatat irure cillum dolor et dolor consectetur officia occaecat.\r\nEnim magna consequat ex incididunt sint anim consequat sit qui veniam anim. Magna enim in incididunt velit. Fugiat sint do reprehenderit sint voluptate sit cupidatat nostrud culpa aliqua anim eu. Aute velit nostrud ipsum do aliquip.\r\n", - "registered": "2016-05-26T12:20:37 -02:00", - "latitude": -37.026658, - "longitude": -170.60657, - "someObject": { - "random": 83, - "random float": 69.136, - "bool": true, - "date": "1983-04-27", - "regEx": "helloooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo to you", - "enum": "generator", - "firstname": "Britni", - "lastname": "Brittani", - "city": "Yokohama", - "country": "United Arab Emirates", - "countryCode": "GT", - "email uses current data": "Britni.Brittani@gmail.com", - "email from expression": "Britni.Brittani@yopmail.com", - "array": [ - "Petronia", - "Natka", - "Cristabel", - "Inga", - "Agathe" - ], - "array of objects": [ - { - "index": 0, - "index start at 5": 5 - }, - { - "index": 1, - "index start at 5": 6 - }, - { - "index": 2, - "index start at 5": 7 - } - ], - "Ann-Marie": { - "age": 36 - } - }, - "someKey": [ - "cupidatat ullamco qui", - "reprehenderit ipsum proident", - "ullamco ex adipisicing", - "nulla magna cupidatat", - "quis eiusmod mollit", - "in mollit nostrud", - "reprehenderit laborum duis", - "cillum laborum ex", - "esse irure cupidatat", - "nulla velit incididunt", - "adipisicing qui irure", - "ad et Lorem" - ], - "friends": [ - { - "id": 0, - "name": "Talley Espinoza" - }, - { - "id": 1, - "someKey": "Meyers Dudley" - }, - { - "id": 2, - "name": "Peck Robbins" - }, - { - "id": 3, - "name": "Sheree Davidson" - }, - { - "id": 4, - "name": "Ortega Norton" - }, - { - "id": 5, - "name": "Beard Mccarty" - }, - { - "id": 6, - "name": "Esperanza Camacho" - }, - { - "id": 7, - "name": "Dillard Barr" - }, - { - "id": 8, - "name": "Nicholson Baxter" - }, - { - "id": 9, - "name": "Peters Ortega" - }, - { - "id": 10, - "name": "Morse Salazar" - }, - { - "id": 11, - "name": "Emerson Koch" - }, - { - "id": 12, - "name": "Vanessa Mclaughlin" - }, - { - "id": 13, - "name": "Annmarie Dalton" - }, - { - "id": 14, - "name": "Walsh Bird" - }, - { - "id": 15, - "name": "Brigitte Daniel" - }, - { - "someKey": 16, - "name": "Angel Randall" - }, - { - "id": 17, - "name": "Pearson Fitzgerald" - }, - { - "id": 18, - "name": "Dunlap Lara" - }, - { - "id": 19, - "name": "Eddie Parks" - }, - { - "id": 20, - "name": "Vilma Nguyen" - }, - { - "id": 21, - "name": "Lina Saunders" - }, - { - "id": 22, - "name": "Stefanie Hayes" - } - ], - "someSecret": "Hello, Nolan Velez! You have 6 unread messages.", - "favoriteFruit": "strawberry" -} \ No newline at end of file