From abf9843e2a217656c4fa4bc79ffd771b13680281 Mon Sep 17 00:00:00 2001 From: Clint Wylie Date: Thu, 11 Jul 2019 23:03:16 -0700 Subject: [PATCH] fail complex type 'serde' registration when registered type does not match expected type (#7985) * make ComplexMetrics.registerSerde type check on register, resolves #7959 * add test * simplify * unused imports :/ * simplify * burned by imports yet again * remove unused constructor * switch to getName * heh oops --- .../benchmark/FilterPartitionBenchmark.java | 3 +- .../FilteredAggregatorBenchmark.java | 3 +- .../GroupByTypeInterfaceBenchmark.java | 3 +- .../benchmark/TopNTypeInterfaceBenchmark.java | 3 +- .../benchmark/datagen/SegmentGenerator.java | 3 +- .../IncrementalIndexReadBenchmark.java | 3 +- .../indexing/IndexIngestionBenchmark.java | 3 +- .../indexing/IndexMergeBenchmark.java | 3 +- .../indexing/IndexPersistBenchmark.java | 3 +- .../benchmark/query/GroupByBenchmark.java | 3 +- .../druid/benchmark/query/ScanBenchmark.java | 3 +- .../benchmark/query/SearchBenchmark.java | 3 +- .../benchmark/query/SelectBenchmark.java | 3 +- .../benchmark/query/TimeseriesBenchmark.java | 3 +- .../druid/benchmark/query/TopNBenchmark.java | 3 +- .../timecompare/TimeCompareBenchmark.java | 3 +- .../momentsketch/MomentSketchModule.java | 2 +- .../tdigestsketch/TDigestSketchModule.java | 3 +- .../datasketches/hll/HllSketchModule.java | 6 +- .../quantiles/DoublesSketchModule.java | 2 +- .../datasketches/theta/SketchModule.java | 6 +- .../theta/oldapi/OldApiSketchModule.java | 12 +-- .../tuple/ArrayOfDoublesSketchModule.java | 6 +- .../guice/BloomFilterSerializersModule.java | 2 +- .../ApproximateHistogramDruidModule.java | 4 +- .../aggregation/stats/DruidStatsModule.java | 2 +- .../druid/jackson/AggregatorsModule.java | 10 +-- .../hyperloglog/HyperUniquesSerde.java | 5 ++ .../PreComputedHyperUniquesSerde.java | 5 +- .../druid/segment/serde/ComplexMetrics.java | 17 ++-- .../druid/segment/SchemalessIndexTest.java | 3 +- .../org/apache/druid/segment/TestIndex.java | 3 +- .../segment/serde/ComplexMetricsTest.java | 78 +++++++++++++++++++ 33 files changed, 139 insertions(+), 75 deletions(-) create mode 100644 processing/src/test/java/org/apache/druid/segment/serde/ComplexMetricsTest.java diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/FilterPartitionBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/FilterPartitionBenchmark.java index ecf502718d0..0309ac7a5da 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/FilterPartitionBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/FilterPartitionBenchmark.java @@ -29,7 +29,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.common.config.NullHandling; import org.apache.druid.data.input.InputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.granularity.Granularities; import org.apache.druid.java.util.common.guava.Sequence; @@ -149,7 +148,7 @@ public class FilterPartitionBenchmark { log.info("SETUP CALLED AT " + System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); schemaInfo = BenchmarkSchemas.SCHEMA_MAP.get(schema); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/FilteredAggregatorBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/FilteredAggregatorBenchmark.java index 4aafcc38c9d..448cc006114 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/FilteredAggregatorBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/FilteredAggregatorBenchmark.java @@ -27,7 +27,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.benchmark.query.QueryBenchmarkUtil; import org.apache.druid.data.input.InputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.granularity.Granularities; import org.apache.druid.java.util.common.guava.Sequence; @@ -145,7 +144,7 @@ public class FilteredAggregatorBenchmark { log.info("SETUP CALLED AT " + System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); schemaInfo = BenchmarkSchemas.SCHEMA_MAP.get(schema); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/GroupByTypeInterfaceBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/GroupByTypeInterfaceBenchmark.java index dd66cc49722..20c5a10ed74 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/GroupByTypeInterfaceBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/GroupByTypeInterfaceBenchmark.java @@ -35,7 +35,6 @@ import org.apache.druid.collections.NonBlockingPool; import org.apache.druid.collections.StupidPool; import org.apache.druid.data.input.InputRow; import org.apache.druid.data.input.Row; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.granularity.Granularities; import org.apache.druid.java.util.common.granularity.Granularity; @@ -265,7 +264,7 @@ public class GroupByTypeInterfaceBenchmark { log.info("SETUP CALLED AT %d", System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); setupQueries(); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/TopNTypeInterfaceBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/TopNTypeInterfaceBenchmark.java index 8d2c01c91d3..cb7981117ae 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/TopNTypeInterfaceBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/TopNTypeInterfaceBenchmark.java @@ -27,7 +27,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.benchmark.query.QueryBenchmarkUtil; import org.apache.druid.collections.StupidPool; import org.apache.druid.data.input.InputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.granularity.Granularities; import org.apache.druid.java.util.common.guava.Sequence; @@ -233,7 +232,7 @@ public class TopNTypeInterfaceBenchmark { log.info("SETUP CALLED AT " + System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); setupQueries(); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/datagen/SegmentGenerator.java b/benchmarks/src/main/java/org/apache/druid/benchmark/datagen/SegmentGenerator.java index 3ba4a48c1c8..c716d476de4 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/datagen/SegmentGenerator.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/datagen/SegmentGenerator.java @@ -30,7 +30,6 @@ import org.apache.druid.data.input.impl.DoubleDimensionSchema; import org.apache.druid.data.input.impl.FloatDimensionSchema; import org.apache.druid.data.input.impl.LongDimensionSchema; import org.apache.druid.data.input.impl.StringDimensionSchema; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.java.util.common.ISE; import org.apache.druid.java.util.common.granularity.Granularity; import org.apache.druid.java.util.common.logger.Logger; @@ -79,7 +78,7 @@ public class SegmentGenerator implements Closeable ) { // In case we need to generate hyperUniques. - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); final BenchmarkDataGenerator dataGenerator = new BenchmarkDataGenerator( schemaInfo.getColumnSchemas(), diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IncrementalIndexReadBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IncrementalIndexReadBenchmark.java index b86fe7be165..122577dff8c 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IncrementalIndexReadBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IncrementalIndexReadBenchmark.java @@ -23,7 +23,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkDataGenerator; import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.data.input.InputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.java.util.common.granularity.Granularities; import org.apache.druid.java.util.common.guava.Sequence; import org.apache.druid.java.util.common.logger.Logger; @@ -93,7 +92,7 @@ public class IncrementalIndexReadBenchmark { log.info("SETUP CALLED AT " + +System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); schemaInfo = BenchmarkSchemas.SCHEMA_MAP.get(schema); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexIngestionBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexIngestionBenchmark.java index f1df5aa87bf..907ec9bd3c7 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexIngestionBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexIngestionBenchmark.java @@ -23,7 +23,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkDataGenerator; import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.data.input.InputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.java.util.common.logger.Logger; import org.apache.druid.query.aggregation.hyperloglog.HyperUniquesSerde; import org.apache.druid.segment.incremental.IncrementalIndex; @@ -71,7 +70,7 @@ public class IndexIngestionBenchmark @Setup public void setup() { - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); rows = new ArrayList(); schemaInfo = BenchmarkSchemas.SCHEMA_MAP.get(schema); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexMergeBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexMergeBenchmark.java index 00382fdcd8a..da08e0bac8c 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexMergeBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexMergeBenchmark.java @@ -27,7 +27,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkDataGenerator; import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.data.input.InputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.logger.Logger; import org.apache.druid.math.expr.ExprMacroTable; @@ -113,7 +112,7 @@ public class IndexMergeBenchmark { log.info("SETUP CALLED AT " + System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); indexesToMerge = new ArrayList<>(); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexPersistBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexPersistBenchmark.java index 1df0e60bed0..19d109cccdb 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexPersistBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/indexing/IndexPersistBenchmark.java @@ -26,7 +26,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkDataGenerator; import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.data.input.InputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.logger.Logger; import org.apache.druid.query.aggregation.hyperloglog.HyperUniquesSerde; @@ -99,7 +98,7 @@ public class IndexPersistBenchmark { log.info("SETUP CALLED AT " + System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); rows = new ArrayList(); schemaInfo = BenchmarkSchemas.SCHEMA_MAP.get(schema); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/query/GroupByBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/query/GroupByBenchmark.java index 9b0c99d2cad..2a61341ca9e 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/query/GroupByBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/query/GroupByBenchmark.java @@ -36,7 +36,6 @@ import org.apache.druid.collections.NonBlockingPool; import org.apache.druid.collections.StupidPool; import org.apache.druid.data.input.InputRow; import org.apache.druid.data.input.Row; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.concurrent.Execs; import org.apache.druid.java.util.common.granularity.Granularities; @@ -353,7 +352,7 @@ public class GroupByBenchmark { log.info("SETUP CALLED AT " + +System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); executorService = Execs.multiThreaded(numProcessingThreads, "GroupByThreadPool[%d]"); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/query/ScanBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/query/ScanBenchmark.java index bdb6aad8c82..60d47e3537c 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/query/ScanBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/query/ScanBenchmark.java @@ -29,7 +29,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.data.input.InputRow; import org.apache.druid.data.input.Row; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.Intervals; import org.apache.druid.java.util.common.concurrent.Execs; @@ -244,7 +243,7 @@ public class ScanBenchmark { log.info("SETUP CALLED AT " + +System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); executorService = Execs.multiThreaded(numProcessingThreads, "ScanThreadPool"); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/query/SearchBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/query/SearchBenchmark.java index 50b2949a2a2..04f1ca74338 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/query/SearchBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/query/SearchBenchmark.java @@ -31,7 +31,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.data.input.InputRow; import org.apache.druid.data.input.Row; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.concurrent.Execs; import org.apache.druid.java.util.common.granularity.Granularities; @@ -314,7 +313,7 @@ public class SearchBenchmark { log.info("SETUP CALLED AT " + +System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); executorService = Execs.multiThreaded(numSegments, "SearchThreadPool"); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/query/SelectBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/query/SelectBenchmark.java index 6161a5d864c..647160d55c5 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/query/SelectBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/query/SelectBenchmark.java @@ -29,7 +29,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.data.input.InputRow; import org.apache.druid.data.input.Row; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.concurrent.Execs; import org.apache.druid.java.util.common.granularity.Granularities; @@ -175,7 +174,7 @@ public class SelectBenchmark { log.info("SETUP CALLED AT " + System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); executorService = Execs.multiThreaded(numSegments, "SelectThreadPool"); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/query/TimeseriesBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/query/TimeseriesBenchmark.java index 050aaca3f1f..eb7600b01b9 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/query/TimeseriesBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/query/TimeseriesBenchmark.java @@ -26,7 +26,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkDataGenerator; import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.data.input.InputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.Intervals; import org.apache.druid.java.util.common.concurrent.Execs; @@ -240,7 +239,7 @@ public class TimeseriesBenchmark { log.info("SETUP CALLED AT " + System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); executorService = Execs.multiThreaded(numSegments, "TimeseriesThreadPool"); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/query/TopNBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/query/TopNBenchmark.java index a691cc78ac9..7a9e48e995d 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/query/TopNBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/query/TopNBenchmark.java @@ -27,7 +27,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkSchemaInfo; import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.collections.StupidPool; import org.apache.druid.data.input.InputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.concurrent.Execs; import org.apache.druid.java.util.common.granularity.Granularities; @@ -215,7 +214,7 @@ public class TopNBenchmark { log.info("SETUP CALLED AT " + System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); executorService = Execs.multiThreaded(numSegments, "TopNThreadPool"); diff --git a/benchmarks/src/main/java/org/apache/druid/benchmark/query/timecompare/TimeCompareBenchmark.java b/benchmarks/src/main/java/org/apache/druid/benchmark/query/timecompare/TimeCompareBenchmark.java index b035e14724b..e5ea310a269 100644 --- a/benchmarks/src/main/java/org/apache/druid/benchmark/query/timecompare/TimeCompareBenchmark.java +++ b/benchmarks/src/main/java/org/apache/druid/benchmark/query/timecompare/TimeCompareBenchmark.java @@ -29,7 +29,6 @@ import org.apache.druid.benchmark.datagen.BenchmarkSchemas; import org.apache.druid.benchmark.query.QueryBenchmarkUtil; import org.apache.druid.collections.StupidPool; import org.apache.druid.data.input.InputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.Intervals; import org.apache.druid.java.util.common.concurrent.Execs; @@ -286,7 +285,7 @@ public class TimeCompareBenchmark { log.info("SETUP CALLED AT " + System.currentTimeMillis()); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); executorService = Execs.multiThreaded(numSegments, "TopNThreadPool"); diff --git a/extensions-contrib/momentsketch/src/main/java/org/apache/druid/query/aggregation/momentsketch/MomentSketchModule.java b/extensions-contrib/momentsketch/src/main/java/org/apache/druid/query/aggregation/momentsketch/MomentSketchModule.java index 09bdba8980b..65c655bf811 100644 --- a/extensions-contrib/momentsketch/src/main/java/org/apache/druid/query/aggregation/momentsketch/MomentSketchModule.java +++ b/extensions-contrib/momentsketch/src/main/java/org/apache/druid/query/aggregation/momentsketch/MomentSketchModule.java @@ -81,6 +81,6 @@ public class MomentSketchModule implements DruidModule @VisibleForTesting public static void registerSerde() { - ComplexMetrics.registerSerde(MomentSketchAggregatorFactory.TYPE_NAME, MomentSketchComplexMetricSerde::new); + ComplexMetrics.registerSerde(MomentSketchAggregatorFactory.TYPE_NAME, new MomentSketchComplexMetricSerde()); } } diff --git a/extensions-contrib/tdigestsketch/src/main/java/org/apache/druid/query/aggregation/tdigestsketch/TDigestSketchModule.java b/extensions-contrib/tdigestsketch/src/main/java/org/apache/druid/query/aggregation/tdigestsketch/TDigestSketchModule.java index dd0240a98e5..a84785a76ba 100644 --- a/extensions-contrib/tdigestsketch/src/main/java/org/apache/druid/query/aggregation/tdigestsketch/TDigestSketchModule.java +++ b/extensions-contrib/tdigestsketch/src/main/java/org/apache/druid/query/aggregation/tdigestsketch/TDigestSketchModule.java @@ -68,7 +68,6 @@ public class TDigestSketchModule implements DruidModule @VisibleForTesting static void registerSerde() { - ComplexMetrics.registerSerde(TDigestBuildSketchAggregatorFactory.TYPE_NAME, TDigestSketchComplexMetricSerde::new); + ComplexMetrics.registerSerde(TDigestBuildSketchAggregatorFactory.TYPE_NAME, new TDigestSketchComplexMetricSerde()); } - } diff --git a/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/hll/HllSketchModule.java b/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/hll/HllSketchModule.java index 1bd19e37731..b5fea829c3f 100644 --- a/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/hll/HllSketchModule.java +++ b/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/hll/HllSketchModule.java @@ -72,8 +72,8 @@ public class HllSketchModule implements DruidModule @VisibleForTesting public static void registerSerde() { - ComplexMetrics.registerSerde(TYPE_NAME, HllSketchMergeComplexMetricSerde::new); - ComplexMetrics.registerSerde(BUILD_TYPE_NAME, HllSketchBuildComplexMetricSerde::new); - ComplexMetrics.registerSerde(MERGE_TYPE_NAME, HllSketchMergeComplexMetricSerde::new); + ComplexMetrics.registerSerde(TYPE_NAME, new HllSketchMergeComplexMetricSerde()); + ComplexMetrics.registerSerde(BUILD_TYPE_NAME, new HllSketchBuildComplexMetricSerde()); + ComplexMetrics.registerSerde(MERGE_TYPE_NAME, new HllSketchMergeComplexMetricSerde()); } } diff --git a/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/quantiles/DoublesSketchModule.java b/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/quantiles/DoublesSketchModule.java index f914cefeef5..48e6d8606ed 100644 --- a/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/quantiles/DoublesSketchModule.java +++ b/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/quantiles/DoublesSketchModule.java @@ -74,6 +74,6 @@ public class DoublesSketchModule implements DruidModule @VisibleForTesting public static void registerSerde() { - ComplexMetrics.registerSerde(DOUBLES_SKETCH, DoublesSketchComplexMetricSerde::new); + ComplexMetrics.registerSerde(DOUBLES_SKETCH, new DoublesSketchComplexMetricSerde()); } } diff --git a/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/theta/SketchModule.java b/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/theta/SketchModule.java index 0a6b732237f..32b1192e7fa 100644 --- a/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/theta/SketchModule.java +++ b/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/theta/SketchModule.java @@ -70,8 +70,8 @@ public class SketchModule implements DruidModule @VisibleForTesting public static void registerSerde() { - ComplexMetrics.registerSerde(THETA_SKETCH, SketchMergeComplexMetricSerde::new); - ComplexMetrics.registerSerde(THETA_SKETCH_MERGE_AGG, SketchMergeComplexMetricSerde::new); - ComplexMetrics.registerSerde(THETA_SKETCH_BUILD_AGG, SketchBuildComplexMetricSerde::new); + ComplexMetrics.registerSerde(THETA_SKETCH, new SketchMergeComplexMetricSerde()); + ComplexMetrics.registerSerde(THETA_SKETCH_MERGE_AGG, new SketchMergeComplexMetricSerde()); + ComplexMetrics.registerSerde(THETA_SKETCH_BUILD_AGG, new SketchBuildComplexMetricSerde()); } } diff --git a/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/theta/oldapi/OldApiSketchModule.java b/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/theta/oldapi/OldApiSketchModule.java index 10c12101c7f..513ff3ef2fa 100644 --- a/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/theta/oldapi/OldApiSketchModule.java +++ b/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/theta/oldapi/OldApiSketchModule.java @@ -44,12 +44,12 @@ public class OldApiSketchModule implements DruidModule @Override public void configure(Binder binder) { - ComplexMetrics.registerSerde(SKETCH_BUILD, SketchBuildComplexMetricSerde::new); - ComplexMetrics.registerSerde(SET_SKETCH, SketchMergeComplexMetricSerde::new); - ComplexMetrics.registerSerde(SKETCH_MERGE, SketchMergeComplexMetricSerde::new); - ComplexMetrics.registerSerde(SketchModule.THETA_SKETCH, SketchMergeComplexMetricSerde::new); - ComplexMetrics.registerSerde(SketchModule.THETA_SKETCH_MERGE_AGG, SketchMergeComplexMetricSerde::new); - ComplexMetrics.registerSerde(SketchModule.THETA_SKETCH_BUILD_AGG, SketchBuildComplexMetricSerde::new); + ComplexMetrics.registerSerde(SKETCH_BUILD, new SketchBuildComplexMetricSerde()); + ComplexMetrics.registerSerde(SET_SKETCH, new SketchMergeComplexMetricSerde()); + ComplexMetrics.registerSerde(SKETCH_MERGE, new SketchMergeComplexMetricSerde()); + ComplexMetrics.registerSerde(SketchModule.THETA_SKETCH, new SketchMergeComplexMetricSerde()); + ComplexMetrics.registerSerde(SketchModule.THETA_SKETCH_MERGE_AGG, new SketchMergeComplexMetricSerde()); + ComplexMetrics.registerSerde(SketchModule.THETA_SKETCH_BUILD_AGG, new SketchBuildComplexMetricSerde()); } @Override diff --git a/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/tuple/ArrayOfDoublesSketchModule.java b/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/tuple/ArrayOfDoublesSketchModule.java index 08a5a80307f..fb996f617df 100644 --- a/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/tuple/ArrayOfDoublesSketchModule.java +++ b/extensions-core/datasketches/src/main/java/org/apache/druid/query/aggregation/datasketches/tuple/ArrayOfDoublesSketchModule.java @@ -47,9 +47,9 @@ public class ArrayOfDoublesSketchModule implements DruidModule @Override public void configure(final Binder binder) { - ComplexMetrics.registerSerde(ARRAY_OF_DOUBLES_SKETCH, ArrayOfDoublesSketchMergeComplexMetricSerde::new); - ComplexMetrics.registerSerde(ARRAY_OF_DOUBLES_SKETCH_MERGE_AGG, ArrayOfDoublesSketchMergeComplexMetricSerde::new); - ComplexMetrics.registerSerde(ARRAY_OF_DOUBLES_SKETCH_BUILD_AGG, ArrayOfDoublesSketchBuildComplexMetricSerde::new); + ComplexMetrics.registerSerde(ARRAY_OF_DOUBLES_SKETCH, new ArrayOfDoublesSketchMergeComplexMetricSerde()); + ComplexMetrics.registerSerde(ARRAY_OF_DOUBLES_SKETCH_MERGE_AGG, new ArrayOfDoublesSketchMergeComplexMetricSerde()); + ComplexMetrics.registerSerde(ARRAY_OF_DOUBLES_SKETCH_BUILD_AGG, new ArrayOfDoublesSketchBuildComplexMetricSerde()); } @Override diff --git a/extensions-core/druid-bloom-filter/src/main/java/org/apache/druid/guice/BloomFilterSerializersModule.java b/extensions-core/druid-bloom-filter/src/main/java/org/apache/druid/guice/BloomFilterSerializersModule.java index 6d43385873a..7f89627b257 100644 --- a/extensions-core/druid-bloom-filter/src/main/java/org/apache/druid/guice/BloomFilterSerializersModule.java +++ b/extensions-core/druid-bloom-filter/src/main/java/org/apache/druid/guice/BloomFilterSerializersModule.java @@ -52,7 +52,7 @@ public class BloomFilterSerializersModule extends SimpleModule addDeserializer(BloomKFilter.class, new BloomKFilterDeserializer()); addDeserializer(BloomKFilterHolder.class, new BloomKFilterHolderDeserializer()); - ComplexMetrics.registerSerde(BLOOM_FILTER_TYPE_NAME, BloomFilterSerde::new); + ComplexMetrics.registerSerde(BLOOM_FILTER_TYPE_NAME, new BloomFilterSerde()); } private static class BloomKFilterSerializer extends StdSerializer diff --git a/extensions-core/histogram/src/main/java/org/apache/druid/query/aggregation/histogram/ApproximateHistogramDruidModule.java b/extensions-core/histogram/src/main/java/org/apache/druid/query/aggregation/histogram/ApproximateHistogramDruidModule.java index 30487e35856..d2bc2d2af94 100644 --- a/extensions-core/histogram/src/main/java/org/apache/druid/query/aggregation/histogram/ApproximateHistogramDruidModule.java +++ b/extensions-core/histogram/src/main/java/org/apache/druid/query/aggregation/histogram/ApproximateHistogramDruidModule.java @@ -66,7 +66,7 @@ public class ApproximateHistogramDruidModule implements DruidModule @VisibleForTesting public static void registerSerde() { - ComplexMetrics.registerSerde("approximateHistogram", ApproximateHistogramFoldingSerde::new); - ComplexMetrics.registerSerde(FixedBucketsHistogramAggregator.TYPE_NAME, FixedBucketsHistogramSerde::new); + ComplexMetrics.registerSerde("approximateHistogram", new ApproximateHistogramFoldingSerde()); + ComplexMetrics.registerSerde(FixedBucketsHistogramAggregator.TYPE_NAME, new FixedBucketsHistogramSerde()); } } diff --git a/extensions-core/stats/src/main/java/org/apache/druid/query/aggregation/stats/DruidStatsModule.java b/extensions-core/stats/src/main/java/org/apache/druid/query/aggregation/stats/DruidStatsModule.java index ea6cf6624b6..1c0fa35503b 100644 --- a/extensions-core/stats/src/main/java/org/apache/druid/query/aggregation/stats/DruidStatsModule.java +++ b/extensions-core/stats/src/main/java/org/apache/druid/query/aggregation/stats/DruidStatsModule.java @@ -65,6 +65,6 @@ public class DruidStatsModule implements DruidModule SqlBindings.addAggregator(binder, BaseVarianceSqlAggregator.StdDevSampSqlAggregator.class); SqlBindings.addAggregator(binder, BaseVarianceSqlAggregator.StdDevSqlAggregator.class); } - ComplexMetrics.registerSerde("variance", VarianceSerde::new); + ComplexMetrics.registerSerde("variance", new VarianceSerde()); } } diff --git a/processing/src/main/java/org/apache/druid/jackson/AggregatorsModule.java b/processing/src/main/java/org/apache/druid/jackson/AggregatorsModule.java index 4914107b121..6689d27aa03 100644 --- a/processing/src/main/java/org/apache/druid/jackson/AggregatorsModule.java +++ b/processing/src/main/java/org/apache/druid/jackson/AggregatorsModule.java @@ -22,7 +22,6 @@ package org.apache.druid.jackson; import com.fasterxml.jackson.annotation.JsonSubTypes; import com.fasterxml.jackson.annotation.JsonTypeInfo; import com.fasterxml.jackson.databind.module.SimpleModule; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.query.aggregation.AggregatorFactory; import org.apache.druid.query.aggregation.CountAggregatorFactory; import org.apache.druid.query.aggregation.DoubleMaxAggregatorFactory; @@ -74,12 +73,9 @@ public class AggregatorsModule extends SimpleModule { super("AggregatorFactories"); - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); - ComplexMetrics.registerSerde( - "preComputedHyperUnique", - () -> new PreComputedHyperUniquesSerde(HyperLogLogHash.getDefault()) - ); - ComplexMetrics.registerSerde("serializablePairLongString", SerializablePairLongStringSerde::new); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); + ComplexMetrics.registerSerde("preComputedHyperUnique", new PreComputedHyperUniquesSerde()); + ComplexMetrics.registerSerde("serializablePairLongString", new SerializablePairLongStringSerde()); setMixInAnnotation(AggregatorFactory.class, AggregatorFactoryMixin.class); setMixInAnnotation(PostAggregator.class, PostAggregatorMixin.class); diff --git a/processing/src/main/java/org/apache/druid/query/aggregation/hyperloglog/HyperUniquesSerde.java b/processing/src/main/java/org/apache/druid/query/aggregation/hyperloglog/HyperUniquesSerde.java index 33c5492f99d..61e80d1a869 100644 --- a/processing/src/main/java/org/apache/druid/query/aggregation/hyperloglog/HyperUniquesSerde.java +++ b/processing/src/main/java/org/apache/druid/query/aggregation/hyperloglog/HyperUniquesSerde.java @@ -43,6 +43,11 @@ public class HyperUniquesSerde extends ComplexMetricSerde private final HyperLogLogHash hyperLogLogHash; + public HyperUniquesSerde() + { + this(HyperLogLogHash.getDefault()); + } + public HyperUniquesSerde(HyperLogLogHash hyperLogLogHash) { this.hyperLogLogHash = hyperLogLogHash; diff --git a/processing/src/main/java/org/apache/druid/query/aggregation/hyperloglog/PreComputedHyperUniquesSerde.java b/processing/src/main/java/org/apache/druid/query/aggregation/hyperloglog/PreComputedHyperUniquesSerde.java index 54117240e2e..c4a49bce683 100644 --- a/processing/src/main/java/org/apache/druid/query/aggregation/hyperloglog/PreComputedHyperUniquesSerde.java +++ b/processing/src/main/java/org/apache/druid/query/aggregation/hyperloglog/PreComputedHyperUniquesSerde.java @@ -21,7 +21,6 @@ package org.apache.druid.query.aggregation.hyperloglog; import org.apache.druid.data.input.InputRow; import org.apache.druid.hll.HyperLogLogCollector; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.java.util.common.ISE; import org.apache.druid.java.util.common.StringUtils; import org.apache.druid.segment.serde.ComplexMetricExtractor; @@ -30,9 +29,9 @@ import java.nio.ByteBuffer; public class PreComputedHyperUniquesSerde extends HyperUniquesSerde { - public PreComputedHyperUniquesSerde(HyperLogLogHash hyperLogLogHash) + public PreComputedHyperUniquesSerde() { - super(hyperLogLogHash); + super(); } @Override diff --git a/processing/src/main/java/org/apache/druid/segment/serde/ComplexMetrics.java b/processing/src/main/java/org/apache/druid/segment/serde/ComplexMetrics.java index f72d3eedb23..4d1331af848 100644 --- a/processing/src/main/java/org/apache/druid/segment/serde/ComplexMetrics.java +++ b/processing/src/main/java/org/apache/druid/segment/serde/ComplexMetrics.java @@ -24,7 +24,6 @@ import org.apache.druid.java.util.common.ISE; import javax.annotation.Nullable; import java.util.HashMap; import java.util.Map; -import java.util.function.Supplier; /** */ @@ -38,13 +37,19 @@ public class ComplexMetrics return complexSerializers.get(type); } - public static void registerSerde(String type, Supplier serdeSupplier) + public static void registerSerde(String type, ComplexMetricSerde serde) { - if (ComplexMetrics.getSerdeForType(type) == null) { - if (complexSerializers.containsKey(type)) { - throw new ISE("Serializer for type[%s] already exists.", type); + if (complexSerializers.containsKey(type)) { + if (!complexSerializers.get(type).getClass().getName().equals(serde.getClass().getName())) { + throw new ISE( + "Incompatible serializer for type[%s] already exists. Expected [%s], found [%s].", + type, + serde.getClass().getName(), + complexSerializers.get(type).getClass().getName() + ); } - complexSerializers.put(type, serdeSupplier.get()); + } else { + complexSerializers.put(type, serde); } } } diff --git a/processing/src/test/java/org/apache/druid/segment/SchemalessIndexTest.java b/processing/src/test/java/org/apache/druid/segment/SchemalessIndexTest.java index 018c6bbaaed..277367a0254 100644 --- a/processing/src/test/java/org/apache/druid/segment/SchemalessIndexTest.java +++ b/processing/src/test/java/org/apache/druid/segment/SchemalessIndexTest.java @@ -24,7 +24,6 @@ import com.google.common.base.Function; import com.google.common.collect.Iterables; import com.google.common.collect.Lists; import org.apache.druid.data.input.MapBasedInputRow; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.jackson.DefaultObjectMapper; import org.apache.druid.java.util.common.DateTimes; import org.apache.druid.java.util.common.Intervals; @@ -94,7 +93,7 @@ public class SchemalessIndexTest private static QueryableIndex mergedIndex = null; static { - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); } private final IndexMerger indexMerger; diff --git a/processing/src/test/java/org/apache/druid/segment/TestIndex.java b/processing/src/test/java/org/apache/druid/segment/TestIndex.java index 689fe7ead5c..556ea2b4f2a 100644 --- a/processing/src/test/java/org/apache/druid/segment/TestIndex.java +++ b/processing/src/test/java/org/apache/druid/segment/TestIndex.java @@ -33,7 +33,6 @@ import org.apache.druid.data.input.impl.LongDimensionSchema; import org.apache.druid.data.input.impl.StringDimensionSchema; import org.apache.druid.data.input.impl.StringInputRowParser; import org.apache.druid.data.input.impl.TimestampSpec; -import org.apache.druid.hll.HyperLogLogHash; import org.apache.druid.java.util.common.DateTimes; import org.apache.druid.java.util.common.Intervals; import org.apache.druid.java.util.common.logger.Logger; @@ -161,7 +160,7 @@ public class TestIndex private static final IndexIO INDEX_IO = TestHelper.getTestIndexIO(); static { - ComplexMetrics.registerSerde("hyperUnique", () -> new HyperUniquesSerde(HyperLogLogHash.getDefault())); + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); } private static Supplier realtimeIndex = Suppliers.memoize( diff --git a/processing/src/test/java/org/apache/druid/segment/serde/ComplexMetricsTest.java b/processing/src/test/java/org/apache/druid/segment/serde/ComplexMetricsTest.java new file mode 100644 index 00000000000..df580a5c3ab --- /dev/null +++ b/processing/src/test/java/org/apache/druid/segment/serde/ComplexMetricsTest.java @@ -0,0 +1,78 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +package org.apache.druid.segment.serde; + +import org.apache.druid.query.aggregation.SerializablePairLongStringSerde; +import org.apache.druid.query.aggregation.hyperloglog.HyperUniquesSerde; +import org.junit.Assert; +import org.junit.Rule; +import org.junit.Test; +import org.junit.rules.ExpectedException; + +public class ComplexMetricsTest +{ + @Rule + public ExpectedException expectedException = ExpectedException.none(); + + @Test + public void testRegister() + { + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); + + ComplexMetricSerde serde = ComplexMetrics.getSerdeForType("hyperUnique"); + Assert.assertNotNull(serde); + Assert.assertTrue(serde instanceof HyperUniquesSerde); + } + + @Test + public void testRegisterDuplicate() + { + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); + + ComplexMetricSerde serde = ComplexMetrics.getSerdeForType("hyperUnique"); + Assert.assertNotNull(serde); + Assert.assertTrue(serde instanceof HyperUniquesSerde); + + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); + + serde = ComplexMetrics.getSerdeForType("hyperUnique"); + Assert.assertNotNull(serde); + Assert.assertTrue(serde instanceof HyperUniquesSerde); + } + + @Test + public void testConflicting() + { + ComplexMetrics.registerSerde("hyperUnique", new HyperUniquesSerde()); + + ComplexMetricSerde serde = ComplexMetrics.getSerdeForType("hyperUnique"); + Assert.assertNotNull(serde); + Assert.assertTrue(serde instanceof HyperUniquesSerde); + + expectedException.expect(IllegalStateException.class); + expectedException.expectMessage("Incompatible serializer for type[hyperUnique] already exists. Expected [org.apache.druid.query.aggregation.SerializablePairLongStringSerde], found [org.apache.druid.query.aggregation.hyperloglog.HyperUniquesSerde"); + + ComplexMetrics.registerSerde("hyperUnique", new SerializablePairLongStringSerde()); + + serde = ComplexMetrics.getSerdeForType("hyperUnique"); + Assert.assertNotNull(serde); + Assert.assertTrue(serde instanceof HyperUniquesSerde); + } +}