mirror of https://github.com/apache/lucene.git
Fix OneDimensionBKDWriter valueCount validation
Signed-off-by: Adrien Grand <jpountz@gmail.com>
This commit is contained in:
parent
0d95f92fac
commit
c1b71e6cb6
|
@ -70,6 +70,9 @@ Bug fixes
|
||||||
* LUCENE-8754: Fix ConcurrentModificationException in SegmentInfo if
|
* LUCENE-8754: Fix ConcurrentModificationException in SegmentInfo if
|
||||||
attributes are accessed in MergePolicy while the merge is running (Simon Willnauer)
|
attributes are accessed in MergePolicy while the merge is running (Simon Willnauer)
|
||||||
|
|
||||||
|
* LUCENE-8765: Fixed validation of the number of added points in KD trees.
|
||||||
|
(Zhao Yang via Adrien Grand)
|
||||||
|
|
||||||
Improvements
|
Improvements
|
||||||
|
|
||||||
* LUCENE-8673: Use radix partitioning when merging dimensional points instead
|
* LUCENE-8673: Use radix partitioning when merging dimensional points instead
|
||||||
|
|
|
@ -553,8 +553,8 @@ public class BKDWriter implements Closeable {
|
||||||
docsSeen.set(docID);
|
docsSeen.set(docID);
|
||||||
leafCount++;
|
leafCount++;
|
||||||
|
|
||||||
if (valueCount > totalPointCount) {
|
if (valueCount + leafCount > totalPointCount) {
|
||||||
throw new IllegalStateException("totalPointCount=" + totalPointCount + " was passed when we were created, but we just hit " + pointCount + " values");
|
throw new IllegalStateException("totalPointCount=" + totalPointCount + " was passed when we were created, but we just hit " + pointCount + leafCount + " values");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (leafCount == maxPointsInLeafNode) {
|
if (leafCount == maxPointsInLeafNode) {
|
||||||
|
|
|
@ -24,6 +24,7 @@ import java.util.Arrays;
|
||||||
import java.util.BitSet;
|
import java.util.BitSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.lucene.codecs.MutablePointValues;
|
||||||
import org.apache.lucene.index.CorruptIndexException;
|
import org.apache.lucene.index.CorruptIndexException;
|
||||||
import org.apache.lucene.index.MergeState;
|
import org.apache.lucene.index.MergeState;
|
||||||
import org.apache.lucene.index.PointValues.IntersectVisitor;
|
import org.apache.lucene.index.PointValues.IntersectVisitor;
|
||||||
|
@ -1245,4 +1246,94 @@ public class TestBKD extends LuceneTestCase {
|
||||||
pointsIn.close();
|
pointsIn.close();
|
||||||
dir.close();
|
dir.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testTotalPointCountValidation() throws IOException {
|
||||||
|
Directory dir = newDirectory();
|
||||||
|
final int numValues = 10;
|
||||||
|
final int numPointsAdded = 50; // exceeds totalPointCount
|
||||||
|
final int numBytesPerDim = TestUtil.nextInt(random(), 1, 4);
|
||||||
|
final byte[] pointValue = new byte[numBytesPerDim];
|
||||||
|
random().nextBytes(pointValue);
|
||||||
|
|
||||||
|
MutablePointValues reader = new MutablePointValues() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void intersect(IntersectVisitor visitor) throws IOException {
|
||||||
|
for(int i=0;i<numPointsAdded;i++) {
|
||||||
|
visitor.visit(0, pointValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public long estimatePointCount(IntersectVisitor visitor) {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public byte[] getMinPackedValue() {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public byte[] getMaxPackedValue() {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getNumDataDimensions() {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getNumIndexDimensions() {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getBytesPerDimension() {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public long size() {
|
||||||
|
return numPointsAdded;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getDocCount() {
|
||||||
|
return numPointsAdded;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void swap(int i, int j) {
|
||||||
|
// do nothing
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getDocID(int i) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void getValue(int i, BytesRef packedValue) {
|
||||||
|
packedValue.bytes = pointValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public byte getByteAt(int i, int k) {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
BKDWriter w = new BKDWriter(numValues, dir, "_temp", 1, 1, numBytesPerDim, BKDWriter.DEFAULT_MAX_POINTS_IN_LEAF_NODE,
|
||||||
|
BKDWriter.DEFAULT_MAX_MB_SORT_IN_HEAP, numValues);
|
||||||
|
expectThrows(IllegalStateException.class, () -> {
|
||||||
|
try (IndexOutput out = dir.createOutput("bkd", IOContext.DEFAULT)) {
|
||||||
|
w.writeField(out, "test_field_name", reader);
|
||||||
|
} finally {
|
||||||
|
w.close();
|
||||||
|
dir.close();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue