fix off by one error in FrontCodedIndexedWriter and FrontCodedIntArrayIndexedWriter getCardinality method (#14047)

* fix off by one error in FrontCodedIndexedWriter and FrontCodedIntArrayIndexedWriter getCardinality method
This commit is contained in:
Clint Wylie 2023-04-07 03:11:15 -07:00 committed by GitHub
parent f47b05a98c
commit f41468fd46
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 105 additions and 26 deletions

View File

@ -227,7 +227,7 @@ public class FrontCodedIndexedWriter implements DictionaryWriter<byte[]>
@Override @Override
public int getCardinality() public int getCardinality()
{ {
return numWritten; return numWritten + (hasNulls ? 1 : 0);
} }
private long getBucketOffset(int index) throws IOException private long getBucketOffset(int index) throws IOException

View File

@ -227,7 +227,7 @@ public class FrontCodedIntArrayIndexedWriter implements DictionaryWriter<int[]>
@Override @Override
public int getCardinality() public int getCardinality()
{ {
return numWritten; return numWritten + (hasNulls ? 1 : 0);
} }
private long getBucketOffset(int index) throws IOException private long getBucketOffset(int index) throws IOException

View File

@ -43,9 +43,11 @@ import org.apache.druid.query.expression.TestExprMacroTable;
import org.apache.druid.segment.AutoTypeColumnSchema; import org.apache.druid.segment.AutoTypeColumnSchema;
import org.apache.druid.segment.IncrementalIndexSegment; import org.apache.druid.segment.IncrementalIndexSegment;
import org.apache.druid.segment.IndexBuilder; import org.apache.druid.segment.IndexBuilder;
import org.apache.druid.segment.IndexSpec;
import org.apache.druid.segment.QueryableIndexSegment; import org.apache.druid.segment.QueryableIndexSegment;
import org.apache.druid.segment.Segment; import org.apache.druid.segment.Segment;
import org.apache.druid.segment.TestHelper; import org.apache.druid.segment.TestHelper;
import org.apache.druid.segment.column.StringEncodingStrategy;
import org.apache.druid.segment.incremental.IncrementalIndexSchema; import org.apache.druid.segment.incremental.IncrementalIndexSchema;
import org.apache.druid.segment.transform.ExpressionTransform; import org.apache.druid.segment.transform.ExpressionTransform;
import org.apache.druid.segment.transform.TransformSpec; import org.apache.druid.segment.transform.TransformSpec;
@ -180,7 +182,8 @@ public class NestedDataTestUtils
SIMPLE_DATA_TSV_TRANSFORM, SIMPLE_DATA_TSV_TRANSFORM,
COUNT, COUNT,
granularity, granularity,
rollup rollup,
new IndexSpec()
); );
} }
@ -205,7 +208,8 @@ public class NestedDataTestUtils
closer, closer,
SIMPLE_DATA_FILE, SIMPLE_DATA_FILE,
Granularities.NONE, Granularities.NONE,
true true,
new IndexSpec()
); );
} }
@ -246,7 +250,8 @@ public class NestedDataTestUtils
Closer closer, Closer closer,
String inputFile, String inputFile,
Granularity granularity, Granularity granularity,
boolean rollup boolean rollup,
IndexSpec indexSpec
) throws Exception ) throws Exception
{ {
return createSegments( return createSegments(
@ -259,7 +264,8 @@ public class NestedDataTestUtils
TransformSpec.NONE, TransformSpec.NONE,
COUNT, COUNT,
granularity, granularity,
rollup rollup,
indexSpec
); );
} }
@ -288,14 +294,16 @@ public class NestedDataTestUtils
TransformSpec.NONE, TransformSpec.NONE,
COUNT, COUNT,
granularity, granularity,
rollup rollup,
new IndexSpec()
); );
} }
public static List<Segment> createSegmentsForJsonInput( public static List<Segment> createSegmentsForJsonInput(
TemporaryFolder tempFolder, TemporaryFolder tempFolder,
Closer closer, Closer closer,
String inputFile String inputFile,
IndexSpec indexSpec
) )
throws Exception throws Exception
{ {
@ -304,7 +312,8 @@ public class NestedDataTestUtils
closer, closer,
inputFile, inputFile,
Granularities.NONE, Granularities.NONE,
true true,
indexSpec
); );
} }
@ -355,7 +364,8 @@ public class NestedDataTestUtils
TransformSpec transformSpec, TransformSpec transformSpec,
AggregatorFactory[] aggregators, AggregatorFactory[] aggregators,
Granularity queryGranularity, Granularity queryGranularity,
boolean rollup boolean rollup,
IndexSpec indexSpec
) throws Exception ) throws Exception
{ {
return createSegments( return createSegments(
@ -368,7 +378,8 @@ public class NestedDataTestUtils
transformSpec, transformSpec,
aggregators, aggregators,
queryGranularity, queryGranularity,
rollup rollup,
indexSpec
); );
} }
@ -382,7 +393,8 @@ public class NestedDataTestUtils
TransformSpec transformSpec, TransformSpec transformSpec,
AggregatorFactory[] aggregators, AggregatorFactory[] aggregators,
Granularity queryGranularity, Granularity queryGranularity,
boolean rollup boolean rollup,
IndexSpec indexSpec
) throws Exception ) throws Exception
{ {
final List<Segment> segments = Lists.newArrayListWithCapacity(inputs.size()); final List<Segment> segments = Lists.newArrayListWithCapacity(inputs.size());
@ -400,6 +412,7 @@ public class NestedDataTestUtils
.withMinTimestamp(0) .withMinTimestamp(0)
.build() .build()
) )
.indexSpec(indexSpec)
.inputSource(inputSource) .inputSource(inputSource)
.inputFormat(inputFormat) .inputFormat(inputFormat)
.transform(transformSpec) .transform(transformSpec)
@ -464,7 +477,8 @@ public class NestedDataTestUtils
NestedDataTestUtils.createSegmentsForJsonInput( NestedDataTestUtils.createSegmentsForJsonInput(
tempFolder, tempFolder,
closer, closer,
jsonInputFile jsonInputFile,
new IndexSpec()
) )
) )
.add(NestedDataTestUtils.createIncrementalIndexForJsonInput(tempFolder, jsonInputFile)) .add(NestedDataTestUtils.createIncrementalIndexForJsonInput(tempFolder, jsonInputFile))
@ -514,14 +528,17 @@ public class NestedDataTestUtils
NestedDataTestUtils.createSegmentsForJsonInput( NestedDataTestUtils.createSegmentsForJsonInput(
tempFolder, tempFolder,
closer, closer,
jsonInputFile jsonInputFile,
new IndexSpec()
) )
) )
.addAll(NestedDataTestUtils.createSegmentsForJsonInput( .addAll(
tempFolder, NestedDataTestUtils.createSegmentsForJsonInput(
closer, tempFolder,
jsonInputFile closer,
) jsonInputFile,
new IndexSpec()
)
) )
.build(); .build();
} }
@ -536,6 +553,58 @@ public class NestedDataTestUtils
return "segments"; return "segments";
} }
}); });
segmentsGenerators.add(new BiFunction<TemporaryFolder, Closer, List<Segment>>()
{
@Override
public List<Segment> apply(TemporaryFolder tempFolder, Closer closer)
{
try {
return ImmutableList.<Segment>builder()
.addAll(
NestedDataTestUtils.createSegmentsForJsonInput(
tempFolder,
closer,
jsonInputFile,
new IndexSpec(
null,
null,
new StringEncodingStrategy.FrontCoded(4, (byte) 0x01),
null,
null,
null,
null
)
)
)
.addAll(
NestedDataTestUtils.createSegmentsForJsonInput(
tempFolder,
closer,
jsonInputFile,
new IndexSpec(
null,
null,
new StringEncodingStrategy.FrontCoded(4, (byte) 0x00),
null,
null,
null,
null
)
)
)
.build();
}
catch (Exception e) {
throw new RuntimeException(e);
}
}
@Override
public String toString()
{
return "segments-frontcoded";
}
});
return segmentsGenerators; return segmentsGenerators;
} }
} }

View File

@ -569,7 +569,7 @@ public class NestedDataGroupByQueryTest extends InitializedNullHandlingTest
return; return;
} }
} }
if (!"segments".equals(segmentsName)) { if (!"segments".equals(segmentsName) && !"segments-frontcoded".equals(segmentsName)) {
if (GroupByStrategySelector.STRATEGY_V1.equals(config.getDefaultStrategy())) { if (GroupByStrategySelector.STRATEGY_V1.equals(config.getDefaultStrategy())) {
Throwable t = Assert.assertThrows(RuntimeException.class, runner::get); Throwable t = Assert.assertThrows(RuntimeException.class, runner::get);
Assert.assertEquals( Assert.assertEquals(

View File

@ -39,6 +39,7 @@ import org.apache.druid.query.filter.BoundDimFilter;
import org.apache.druid.query.filter.SelectorDimFilter; import org.apache.druid.query.filter.SelectorDimFilter;
import org.apache.druid.query.ordering.StringComparators; import org.apache.druid.query.ordering.StringComparators;
import org.apache.druid.query.spec.MultipleIntervalSegmentSpec; import org.apache.druid.query.spec.MultipleIntervalSegmentSpec;
import org.apache.druid.segment.IndexSpec;
import org.apache.druid.segment.Segment; import org.apache.druid.segment.Segment;
import org.apache.druid.segment.column.ColumnType; import org.apache.druid.segment.column.ColumnType;
import org.apache.druid.segment.transform.TransformSpec; import org.apache.druid.segment.transform.TransformSpec;
@ -135,7 +136,8 @@ public class NestedDataScanQueryTest extends InitializedNullHandlingTest
TransformSpec.NONE, TransformSpec.NONE,
NestedDataTestUtils.COUNT, NestedDataTestUtils.COUNT,
Granularities.YEAR, Granularities.YEAR,
true true,
new IndexSpec()
) )
).build(); ).build();
@ -308,7 +310,8 @@ public class NestedDataScanQueryTest extends InitializedNullHandlingTest
closer, closer,
NestedDataTestUtils.SIMPLE_DATA_FILE, NestedDataTestUtils.SIMPLE_DATA_FILE,
Granularities.HOUR, Granularities.HOUR,
true true,
new IndexSpec()
); );
final Sequence<ScanResultValue> seq = helper.runQueryOnSegmentsObjs(segs, scanQuery); final Sequence<ScanResultValue> seq = helper.runQueryOnSegmentsObjs(segs, scanQuery);
@ -491,7 +494,8 @@ public class NestedDataScanQueryTest extends InitializedNullHandlingTest
TransformSpec.NONE, TransformSpec.NONE,
NestedDataTestUtils.COUNT, NestedDataTestUtils.COUNT,
Granularities.DAY, Granularities.DAY,
true true,
new IndexSpec()
); );
@ -550,7 +554,8 @@ public class NestedDataScanQueryTest extends InitializedNullHandlingTest
TransformSpec.NONE, TransformSpec.NONE,
aggs, aggs,
Granularities.NONE, Granularities.NONE,
true true,
new IndexSpec()
); );

View File

@ -444,6 +444,7 @@ public class FrontCodedIndexedTest extends InitializedNullHandlingTest
} }
index++; index++;
} }
Assert.assertEquals(index, writer.getCardinality());
// check 'get' again so that we aren't always reading from current page // check 'get' again so that we aren't always reading from current page
index = 0; index = 0;

View File

@ -414,6 +414,7 @@ public class FrontCodedIntArrayIndexedTest
assertSame(index, next, writer.get(index)); assertSame(index, next, writer.get(index));
index++; index++;
} }
Assert.assertEquals(index, writer.getCardinality());
// check 'get' again so that we aren't always reading from current page // check 'get' again so that we aren't always reading from current page
index = 0; index = 0;

View File

@ -36,6 +36,7 @@ import org.apache.druid.segment.ColumnSelectorFactory;
import org.apache.druid.segment.ColumnValueSelector; import org.apache.druid.segment.ColumnValueSelector;
import org.apache.druid.segment.Cursor; import org.apache.druid.segment.Cursor;
import org.apache.druid.segment.DoubleColumnSelector; import org.apache.druid.segment.DoubleColumnSelector;
import org.apache.druid.segment.IndexSpec;
import org.apache.druid.segment.LongColumnSelector; import org.apache.druid.segment.LongColumnSelector;
import org.apache.druid.segment.Segment; import org.apache.druid.segment.Segment;
import org.apache.druid.segment.StorageAdapter; import org.apache.druid.segment.StorageAdapter;
@ -336,7 +337,8 @@ public class NestedFieldColumnSelectorsTest
TransformSpec.NONE, TransformSpec.NONE,
NestedDataTestUtils.COUNT, NestedDataTestUtils.COUNT,
Granularities.NONE, Granularities.NONE,
true true,
new IndexSpec()
); );
Assert.assertEquals(1, segments.size()); Assert.assertEquals(1, segments.size());
StorageAdapter storageAdapter = segments.get(0).asStorageAdapter(); StorageAdapter storageAdapter = segments.get(0).asStorageAdapter();
@ -366,7 +368,8 @@ public class NestedFieldColumnSelectorsTest
TransformSpec.NONE, TransformSpec.NONE,
NestedDataTestUtils.COUNT, NestedDataTestUtils.COUNT,
Granularities.NONE, Granularities.NONE,
true true,
new IndexSpec()
); );
Assert.assertEquals(1, segments.size()); Assert.assertEquals(1, segments.size());
StorageAdapter storageAdapter = segments.get(0).asStorageAdapter(); StorageAdapter storageAdapter = segments.get(0).asStorageAdapter();