more checkindex

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/branches/lucene4547@1411436 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Robert Muir 2012-11-19 21:38:45 +00:00
parent e7dc29859f
commit 7c7898fc12
1 changed files with 10 additions and 1 deletions

View File

@ -1394,13 +1394,22 @@ public class CheckIndex {
private void checkSortedDocValues(FieldInfo fi, SegmentReader reader, SortedDocValues dv) { private void checkSortedDocValues(FieldInfo fi, SegmentReader reader, SortedDocValues dv) {
checkBinaryDocValues(fi, reader, dv); checkBinaryDocValues(fi, reader, dv);
final int maxOrd = dv.getValueCount()-1; final int maxOrd = dv.getValueCount()-1;
FixedBitSet seenOrds = new FixedBitSet(dv.getValueCount());
int maxOrd2 = -1; int maxOrd2 = -1;
for (int i = 0; i < reader.maxDoc(); i++) { for (int i = 0; i < reader.maxDoc(); i++) {
maxOrd2 = Math.max(maxOrd2, dv.getOrd(i)); int ord = dv.getOrd(i);
if (ord < 0 || ord > maxOrd) {
throw new RuntimeException("ord out of bounds: " + ord);
}
maxOrd2 = Math.max(maxOrd2, ord);
seenOrds.set(ord);
} }
if (maxOrd != maxOrd2) { if (maxOrd != maxOrd2) {
throw new RuntimeException("dv for field: " + fi.name + " reports wrong maxOrd=" + maxOrd + " but this is not the case: " + maxOrd2); throw new RuntimeException("dv for field: " + fi.name + " reports wrong maxOrd=" + maxOrd + " but this is not the case: " + maxOrd2);
} }
if (seenOrds.cardinality() != dv.getValueCount()) {
throw new RuntimeException("dv for field: " + fi.name + " has holes in its ords, valueCount=" + dv.getValueCount() + " but only used: " + seenOrds.cardinality());
}
BytesRef lastValue = null; BytesRef lastValue = null;
BytesRef scratch = new BytesRef(); BytesRef scratch = new BytesRef();
for (int i = 0; i <= maxOrd; i++) { for (int i = 0; i <= maxOrd; i++) {