Upgrade to a snapshot of Lucene 7. (elastic/x-pack-elasticsearch#1102)

Original commit: elastic/x-pack-elasticsearch@2c145e4160
This commit is contained in:
Adrien Grand 2017-04-18 15:35:55 +02:00 committed by GitHub
parent 51de15dcf1
commit 98c4dc6a92
8 changed files with 88 additions and 204 deletions

View File

@ -72,8 +72,8 @@ public final class DocumentSubsetReader extends FilterLeafReader {
} }
@Override @Override
public Object getCoreCacheKey() { public CacheHelper getReaderCacheHelper() {
return in.getCoreCacheKey(); return in.getReaderCacheHelper();
} }
} }
@ -155,8 +155,13 @@ public final class DocumentSubsetReader extends FilterLeafReader {
// Don't delegate getCombinedCoreAndDeletesKey(), because we change the live docs here. // Don't delegate getCombinedCoreAndDeletesKey(), because we change the live docs here.
@Override @Override
public Object getCoreCacheKey() { public CacheHelper getCoreCacheHelper() {
return in.getCoreCacheKey(); return in.getCoreCacheHelper();
}
@Override
public CacheHelper getReaderCacheHelper() {
return in.getReaderCacheHelper();
} }
BitSet getRoleQueryBits() { BitSet getRoleQueryBits() {

View File

@ -9,7 +9,6 @@ import org.apache.lucene.search.BooleanClause;
import org.apache.lucene.search.BooleanQuery; import org.apache.lucene.search.BooleanQuery;
import org.apache.lucene.search.DisjunctionMaxQuery; import org.apache.lucene.search.DisjunctionMaxQuery;
import org.apache.lucene.search.DocValuesNumbersQuery; import org.apache.lucene.search.DocValuesNumbersQuery;
import org.apache.lucene.search.DocValuesRangeQuery;
import org.apache.lucene.search.FieldValueQuery; import org.apache.lucene.search.FieldValueQuery;
import org.apache.lucene.search.IndexOrDocValuesQuery; import org.apache.lucene.search.IndexOrDocValuesQuery;
import org.apache.lucene.search.MatchAllDocsQuery; import org.apache.lucene.search.MatchAllDocsQuery;
@ -24,6 +23,9 @@ import org.apache.lucene.search.TermQuery;
import org.apache.lucene.search.Weight; import org.apache.lucene.search.Weight;
import org.apache.lucene.search.spans.SpanTermQuery; import org.apache.lucene.search.spans.SpanTermQuery;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set; import java.util.Set;
/** /**
@ -80,10 +82,14 @@ class FieldExtractor {
} else if (query instanceof DocValuesNumbersQuery) { } else if (query instanceof DocValuesNumbersQuery) {
fields.add(((DocValuesNumbersQuery)query).getField()); fields.add(((DocValuesNumbersQuery)query).getField());
} else if (query instanceof IndexOrDocValuesQuery) { } else if (query instanceof IndexOrDocValuesQuery) {
// Both queries are supposed to be equivalent, so if any of them can be extracted, we are good
try {
Set<String> dvQueryFields = new HashSet<>(1);
extractFields(((IndexOrDocValuesQuery) query).getRandomAccessQuery(), dvQueryFields);
fields.addAll(dvQueryFields);
} catch (UnsupportedOperationException e) {
extractFields(((IndexOrDocValuesQuery) query).getIndexQuery(), fields); extractFields(((IndexOrDocValuesQuery) query).getIndexQuery(), fields);
extractFields(((IndexOrDocValuesQuery) query).getRandomAccessQuery(), fields); }
} else if (query instanceof DocValuesRangeQuery) {
fields.add(((DocValuesRangeQuery)query).getField());
} else if (query instanceof MatchAllDocsQuery) { } else if (query instanceof MatchAllDocsQuery) {
// no field // no field
} else if (query instanceof MatchNoDocsQuery) { } else if (query instanceof MatchNoDocsQuery) {

View File

@ -21,7 +21,6 @@ import org.apache.lucene.index.SortedSetDocValues;
import org.apache.lucene.index.StoredFieldVisitor; import org.apache.lucene.index.StoredFieldVisitor;
import org.apache.lucene.index.Terms; import org.apache.lucene.index.Terms;
import org.apache.lucene.index.TermsEnum; import org.apache.lucene.index.TermsEnum;
import org.apache.lucene.util.Bits;
import org.apache.lucene.util.BytesRef; import org.apache.lucene.util.BytesRef;
import org.apache.lucene.util.FilterIterator; import org.apache.lucene.util.FilterIterator;
import org.apache.lucene.util.automaton.CharacterRunAutomaton; import org.apache.lucene.util.automaton.CharacterRunAutomaton;
@ -101,8 +100,8 @@ public final class FieldSubsetReader extends FilterLeafReader {
} }
@Override @Override
public Object getCoreCacheKey() { public CacheHelper getReaderCacheHelper() {
return in.getCoreCacheKey(); return in.getReaderCacheHelper();
} }
} }
@ -302,16 +301,16 @@ public final class FieldSubsetReader extends FilterLeafReader {
return hasField(field) ? super.getNormValues(field) : null; return hasField(field) ? super.getNormValues(field) : null;
} }
@Override
public Bits getDocsWithField(String field) throws IOException {
return hasField(field) ? super.getDocsWithField(field) : null;
}
// we share core cache keys (for e.g. fielddata) // we share core cache keys (for e.g. fielddata)
@Override @Override
public Object getCoreCacheKey() { public CacheHelper getCoreCacheHelper() {
return in.getCoreCacheKey(); return in.getCoreCacheHelper();
}
@Override
public CacheHelper getReaderCacheHelper() {
return in.getReaderCacheHelper();
} }
/** /**
@ -458,100 +457,12 @@ public final class FieldSubsetReader extends FilterLeafReader {
} }
} }
/**
* Filters the PointValues instance.
* <p>
* Like other parts of the index, fields without access will not exist.
*/
// TODO: push up a similar class into lucene
// TODO: fix the FieldFilterReader we use in lucene tests!
final class FieldFilterPointValues extends PointValues {
private final PointValues in;
FieldFilterPointValues(PointValues in) {
this.in = in;
}
@Override @Override
public void intersect(String fieldName, IntersectVisitor visitor) throws IOException { public PointValues getPointValues(String fieldName) throws IOException {
if (hasField(fieldName)) { if (hasField(fieldName)) {
in.intersect(fieldName, visitor); return super.getPointValues(fieldName);
} else { } else {
return; // behave as field does not exist
}
}
@Override
public long estimatePointCount(String fieldName, IntersectVisitor visitor) {
if (hasField(fieldName)) {
return in.estimatePointCount(fieldName, visitor);
} else {
return 0L; // behave as field does not exist
}
}
@Override
public byte[] getMinPackedValue(String fieldName) throws IOException {
if (hasField(fieldName)) {
return in.getMinPackedValue(fieldName);
} else {
return null; // behave as field does not exist
}
}
@Override
public byte[] getMaxPackedValue(String fieldName) throws IOException {
if (hasField(fieldName)) {
return in.getMaxPackedValue(fieldName);
} else {
return null; // behave as field does not exist
}
}
@Override
public int getNumDimensions(String fieldName) throws IOException {
if (hasField(fieldName)) {
return in.getNumDimensions(fieldName);
} else {
return 0; // behave as field does not exist
}
}
@Override
public int getBytesPerDimension(String fieldName) throws IOException {
if (hasField(fieldName)) {
return in.getBytesPerDimension(fieldName);
} else {
return 0; // behave as field does not exist
}
}
@Override
public long size(String fieldName) {
if (hasField(fieldName)) {
return in.size(fieldName);
} else {
return 0; // behave as field does not exist
}
}
@Override
public int getDocCount(String fieldName) {
if (hasField(fieldName)) {
return in.getDocCount(fieldName);
} else {
return 0; // behave as field does not exist
}
}
}
@Override
public PointValues getPointValues() {
PointValues points = super.getPointValues();
if (points == null) {
return null; return null;
} else {
return new FieldFilterPointValues(points);
} }
} }
} }

View File

@ -218,7 +218,8 @@ public class DocumentSubsetReaderTests extends ESTestCase {
// we should have the same cache key as before // we should have the same cache key as before
assertEquals(1, ir2.numDocs()); assertEquals(1, ir2.numDocs());
assertEquals(1, ir2.leaves().size()); assertEquals(1, ir2.leaves().size());
assertSame(ir.leaves().get(0).reader().getCoreCacheKey(), ir2.leaves().get(0).reader().getCoreCacheKey()); assertSame(ir.leaves().get(0).reader().getCoreCacheHelper().getKey(),
ir2.leaves().get(0).reader().getCoreCacheHelper().getKey());
TestUtil.checkReader(ir); TestUtil.checkReader(ir);
IOUtils.close(ir, ir2, iw, dir); IOUtils.close(ir, ir2, iw, dir);

View File

@ -6,19 +6,20 @@
package org.elasticsearch.xpack.security.authz.accesscontrol; package org.elasticsearch.xpack.security.authz.accesscontrol;
import org.apache.lucene.document.IntPoint; import org.apache.lucene.document.IntPoint;
import org.apache.lucene.document.NumericDocValuesField;
import org.apache.lucene.index.Term; import org.apache.lucene.index.Term;
import org.apache.lucene.search.AssertingQuery; import org.apache.lucene.search.AssertingQuery;
import org.apache.lucene.search.BooleanClause; import org.apache.lucene.search.BooleanClause;
import org.apache.lucene.search.BooleanQuery; import org.apache.lucene.search.BooleanQuery;
import org.apache.lucene.search.DisjunctionMaxQuery; import org.apache.lucene.search.DisjunctionMaxQuery;
import org.apache.lucene.search.DocValuesNumbersQuery; import org.apache.lucene.search.DocValuesNumbersQuery;
import org.apache.lucene.search.DocValuesRangeQuery;
import org.apache.lucene.search.FieldValueQuery; import org.apache.lucene.search.FieldValueQuery;
import org.apache.lucene.search.IndexOrDocValuesQuery; import org.apache.lucene.search.IndexOrDocValuesQuery;
import org.apache.lucene.search.MatchAllDocsQuery; import org.apache.lucene.search.MatchAllDocsQuery;
import org.apache.lucene.search.MatchNoDocsQuery; import org.apache.lucene.search.MatchNoDocsQuery;
import org.apache.lucene.search.MultiPhraseQuery; import org.apache.lucene.search.MultiPhraseQuery;
import org.apache.lucene.search.PhraseQuery; import org.apache.lucene.search.PhraseQuery;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.SynonymQuery; import org.apache.lucene.search.SynonymQuery;
import org.apache.lucene.search.TermQuery; import org.apache.lucene.search.TermQuery;
import org.apache.lucene.search.spans.SpanTermQuery; import org.apache.lucene.search.spans.SpanTermQuery;
@ -112,12 +113,6 @@ public class FieldExtractorTests extends ESTestCase {
assertEquals(asSet("foo"), fields); assertEquals(asSet("foo"), fields);
} }
public void testDocValuesRange() {
Set<String> fields = new HashSet<>();
FieldExtractor.extractFields(DocValuesRangeQuery.newLongRange("foo", 1L, 2L, true, true), fields);
assertEquals(asSet("foo"), fields);
}
public void testMatchAllDocs() { public void testMatchAllDocs() {
Set<String> fields = new HashSet<>(); Set<String> fields = new HashSet<>();
FieldExtractor.extractFields(new MatchAllDocsQuery(), fields); FieldExtractor.extractFields(new MatchAllDocsQuery(), fields);
@ -139,16 +134,24 @@ public class FieldExtractorTests extends ESTestCase {
public void testIndexOrDocValuesQuery() { public void testIndexOrDocValuesQuery() {
Set<String> fields = new HashSet<>(); Set<String> fields = new HashSet<>();
IndexOrDocValuesQuery query = new IndexOrDocValuesQuery(new FieldValueQuery("foo"), Query supported = IntPoint.newExactQuery("foo", 42);
new DocValuesNumbersQuery("foo", 5L)); Query unsupported = NumericDocValuesField.newExactQuery("bar", 3);
IndexOrDocValuesQuery query = new IndexOrDocValuesQuery(supported, supported);
FieldExtractor.extractFields(query, fields); FieldExtractor.extractFields(query, fields);
assertEquals(asSet("foo"), fields); assertEquals(asSet("foo"), fields);
// what if they have different fields - some programming error IndexOrDocValuesQuery query2 = new IndexOrDocValuesQuery(unsupported, unsupported);
fields.clear(); expectThrows(UnsupportedOperationException.class, () -> FieldExtractor.extractFields(query2, new HashSet<>()));
query = new IndexOrDocValuesQuery(new FieldValueQuery("foo1"),
new DocValuesNumbersQuery("bar", 5L)); fields = new HashSet<>();
FieldExtractor.extractFields(query, fields); IndexOrDocValuesQuery query3 = new IndexOrDocValuesQuery(supported, unsupported);
assertEquals(asSet("foo1", "bar"), fields); FieldExtractor.extractFields(query3, fields);
assertEquals(asSet("foo"), fields);
fields = new HashSet<>();
IndexOrDocValuesQuery query4 = new IndexOrDocValuesQuery(unsupported, supported);
FieldExtractor.extractFields(query4, fields);
assertEquals(asSet("foo"), fields);
} }
} }

View File

@ -18,6 +18,7 @@ import org.apache.lucene.document.SortedSetDocValuesField;
import org.apache.lucene.document.StoredField; import org.apache.lucene.document.StoredField;
import org.apache.lucene.document.StringField; import org.apache.lucene.document.StringField;
import org.apache.lucene.document.TextField; import org.apache.lucene.document.TextField;
import org.apache.lucene.index.BinaryDocValues;
import org.apache.lucene.index.DirectoryReader; import org.apache.lucene.index.DirectoryReader;
import org.apache.lucene.index.FieldInfos; import org.apache.lucene.index.FieldInfos;
import org.apache.lucene.index.Fields; import org.apache.lucene.index.Fields;
@ -25,9 +26,11 @@ import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.IndexWriterConfig; import org.apache.lucene.index.IndexWriterConfig;
import org.apache.lucene.index.LeafReader; import org.apache.lucene.index.LeafReader;
import org.apache.lucene.index.NoMergePolicy; import org.apache.lucene.index.NoMergePolicy;
import org.apache.lucene.index.NumericDocValues;
import org.apache.lucene.index.PointValues; import org.apache.lucene.index.PointValues;
import org.apache.lucene.index.PointValues.IntersectVisitor; import org.apache.lucene.index.PointValues.IntersectVisitor;
import org.apache.lucene.index.PointValues.Relation; import org.apache.lucene.index.PointValues.Relation;
import org.apache.lucene.index.SortedDocValues;
import org.apache.lucene.index.SortedNumericDocValues; import org.apache.lucene.index.SortedNumericDocValues;
import org.apache.lucene.index.SortedSetDocValues; import org.apache.lucene.index.SortedSetDocValues;
import org.apache.lucene.index.Term; import org.apache.lucene.index.Term;
@ -114,35 +117,30 @@ public class FieldSubsetReaderTests extends ESTestCase {
// see only one field // see only one field
LeafReader segmentReader = ir.leaves().get(0).reader(); LeafReader segmentReader = ir.leaves().get(0).reader();
PointValues points = segmentReader.getPointValues(); PointValues points = segmentReader.getPointValues("fieldA");
assertNull(segmentReader.getPointValues("fieldB"));
// size statistic // size statistic
assertEquals(1, points.size("fieldA")); assertEquals(1, points.size());
assertEquals(0, points.size("fieldB"));
// doccount statistic // doccount statistic
assertEquals(1, points.getDocCount("fieldA")); assertEquals(1, points.getDocCount());
assertEquals(0, points.getDocCount("fieldB"));
// min statistic // min statistic
assertNotNull(points.getMinPackedValue("fieldA")); assertNotNull(points.getMinPackedValue());
assertNull(points.getMinPackedValue("fieldB"));
// max statistic // max statistic
assertNotNull(points.getMaxPackedValue("fieldA")); assertNotNull(points.getMaxPackedValue());
assertNull(points.getMaxPackedValue("fieldB"));
// bytes per dimension // bytes per dimension
assertEquals(Integer.BYTES, points.getBytesPerDimension("fieldA")); assertEquals(Integer.BYTES, points.getBytesPerDimension());
assertEquals(0, points.getBytesPerDimension("fieldB"));
// number of dimensions // number of dimensions
assertEquals(1, points.getNumDimensions("fieldA")); assertEquals(1, points.getNumDimensions());
assertEquals(0, points.getNumDimensions("fieldB"));
// walk the trees: we should see stuff in fieldA // walk the trees: we should see stuff in fieldA
AtomicBoolean sawDoc = new AtomicBoolean(false); AtomicBoolean sawDoc = new AtomicBoolean(false);
points.intersect("fieldA", new IntersectVisitor() { points.intersect(new IntersectVisitor() {
@Override @Override
public void visit(int docID) throws IOException { public void visit(int docID) throws IOException {
throw new IllegalStateException("should not get here"); throw new IllegalStateException("should not get here");
@ -159,23 +157,6 @@ public class FieldSubsetReaderTests extends ESTestCase {
} }
}); });
assertTrue(sawDoc.get()); assertTrue(sawDoc.get());
// not in fieldB
points.intersect("fieldB", new IntersectVisitor() {
@Override
public void visit(int docID) throws IOException {
throw new IllegalStateException("should not get here");
}
@Override
public void visit(int docID, byte[] packedValue) throws IOException {
throw new IllegalStateException("should not get here");
}
@Override
public Relation compare(byte[] minPackedValue, byte[] maxPackedValue) {
throw new IllegalStateException("should not get here");
}
});
TestUtil.checkReader(ir); TestUtil.checkReader(ir);
IOUtils.close(ir, iw, dir); IOUtils.close(ir, iw, dir);
@ -413,14 +394,12 @@ public class FieldSubsetReaderTests extends ESTestCase {
// see only one field // see only one field
LeafReader segmentReader = ir.leaves().get(0).reader(); LeafReader segmentReader = ir.leaves().get(0).reader();
assertNotNull(segmentReader.getNumericDocValues("fieldA")); NumericDocValues values = segmentReader.getNumericDocValues("fieldA");
assertEquals(1, segmentReader.getNumericDocValues("fieldA").get(0)); assertNotNull(values);
assertTrue(values.advanceExact(0));
assertEquals(1, values.longValue());
assertNull(segmentReader.getNumericDocValues("fieldB")); assertNull(segmentReader.getNumericDocValues("fieldB"));
// check docs with field
assertNotNull(segmentReader.getDocsWithField("fieldA"));
assertNull(segmentReader.getDocsWithField("fieldB"));
TestUtil.checkReader(ir); TestUtil.checkReader(ir);
IOUtils.close(ir, iw, dir); IOUtils.close(ir, iw, dir);
} }
@ -444,14 +423,12 @@ public class FieldSubsetReaderTests extends ESTestCase {
// see only one field // see only one field
LeafReader segmentReader = ir.leaves().get(0).reader(); LeafReader segmentReader = ir.leaves().get(0).reader();
assertNotNull(segmentReader.getBinaryDocValues("fieldA")); BinaryDocValues values = segmentReader.getBinaryDocValues("fieldA");
assertEquals(new BytesRef("testA"), segmentReader.getBinaryDocValues("fieldA").get(0)); assertNotNull(values);
assertTrue(values.advanceExact(0));
assertEquals(new BytesRef("testA"), values.binaryValue());
assertNull(segmentReader.getBinaryDocValues("fieldB")); assertNull(segmentReader.getBinaryDocValues("fieldB"));
// check docs with field
assertNotNull(segmentReader.getDocsWithField("fieldA"));
assertNull(segmentReader.getDocsWithField("fieldB"));
TestUtil.checkReader(ir); TestUtil.checkReader(ir);
IOUtils.close(ir, iw, dir); IOUtils.close(ir, iw, dir);
} }
@ -475,14 +452,12 @@ public class FieldSubsetReaderTests extends ESTestCase {
// see only one field // see only one field
LeafReader segmentReader = ir.leaves().get(0).reader(); LeafReader segmentReader = ir.leaves().get(0).reader();
assertNotNull(segmentReader.getSortedDocValues("fieldA")); SortedDocValues values = segmentReader.getSortedDocValues("fieldA");
assertEquals(new BytesRef("testA"), segmentReader.getSortedDocValues("fieldA").get(0)); assertNotNull(values);
assertTrue(values.advanceExact(0));
assertEquals(new BytesRef("testA"), values.binaryValue());
assertNull(segmentReader.getSortedDocValues("fieldB")); assertNull(segmentReader.getSortedDocValues("fieldB"));
// check docs with field
assertNotNull(segmentReader.getDocsWithField("fieldA"));
assertNull(segmentReader.getDocsWithField("fieldB"));
TestUtil.checkReader(ir); TestUtil.checkReader(ir);
IOUtils.close(ir, iw, dir); IOUtils.close(ir, iw, dir);
} }
@ -508,16 +483,12 @@ public class FieldSubsetReaderTests extends ESTestCase {
LeafReader segmentReader = ir.leaves().get(0).reader(); LeafReader segmentReader = ir.leaves().get(0).reader();
SortedSetDocValues dv = segmentReader.getSortedSetDocValues("fieldA"); SortedSetDocValues dv = segmentReader.getSortedSetDocValues("fieldA");
assertNotNull(dv); assertNotNull(dv);
dv.setDocument(0); assertTrue(dv.advanceExact(0));
assertEquals(0, dv.nextOrd()); assertEquals(0, dv.nextOrd());
assertEquals(SortedSetDocValues.NO_MORE_ORDS, dv.nextOrd()); assertEquals(SortedSetDocValues.NO_MORE_ORDS, dv.nextOrd());
assertEquals(new BytesRef("testA"), dv.lookupOrd(0)); assertEquals(new BytesRef("testA"), dv.lookupOrd(0));
assertNull(segmentReader.getSortedSetDocValues("fieldB")); assertNull(segmentReader.getSortedSetDocValues("fieldB"));
// check docs with field
assertNotNull(segmentReader.getDocsWithField("fieldA"));
assertNull(segmentReader.getDocsWithField("fieldB"));
TestUtil.checkReader(ir); TestUtil.checkReader(ir);
IOUtils.close(ir, iw, dir); IOUtils.close(ir, iw, dir);
} }
@ -543,15 +514,11 @@ public class FieldSubsetReaderTests extends ESTestCase {
LeafReader segmentReader = ir.leaves().get(0).reader(); LeafReader segmentReader = ir.leaves().get(0).reader();
SortedNumericDocValues dv = segmentReader.getSortedNumericDocValues("fieldA"); SortedNumericDocValues dv = segmentReader.getSortedNumericDocValues("fieldA");
assertNotNull(dv); assertNotNull(dv);
dv.setDocument(0); assertTrue(dv.advanceExact(0));
assertEquals(1, dv.count()); assertEquals(1, dv.docValueCount());
assertEquals(1, dv.valueAt(0)); assertEquals(1, dv.nextValue());
assertNull(segmentReader.getSortedNumericDocValues("fieldB")); assertNull(segmentReader.getSortedNumericDocValues("fieldB"));
// check docs with field
assertNotNull(segmentReader.getDocsWithField("fieldA"));
assertNull(segmentReader.getDocsWithField("fieldB"));
TestUtil.checkReader(ir); TestUtil.checkReader(ir);
IOUtils.close(ir, iw, dir); IOUtils.close(ir, iw, dir);
} }
@ -923,7 +890,8 @@ public class FieldSubsetReaderTests extends ESTestCase {
// we should have the same cache key as before // we should have the same cache key as before
assertEquals(1, ir2.numDocs()); assertEquals(1, ir2.numDocs());
assertEquals(1, ir2.leaves().size()); assertEquals(1, ir2.leaves().size());
assertSame(ir.leaves().get(0).reader().getCoreCacheKey(), ir2.leaves().get(0).reader().getCoreCacheKey()); assertSame(ir.leaves().get(0).reader().getCoreCacheHelper().getKey(),
ir2.leaves().get(0).reader().getCoreCacheHelper().getKey());
TestUtil.checkReader(ir); TestUtil.checkReader(ir);
IOUtils.close(ir, ir2, iw, dir); IOUtils.close(ir, ir2, iw, dir);

View File

@ -49,7 +49,7 @@ public class OptOutQueryCacheTests extends ESTestCase {
BooleanQuery.Builder builder = new BooleanQuery.Builder(); BooleanQuery.Builder builder = new BooleanQuery.Builder();
builder.add(new TermQuery(new Term("foo", "bar")), BooleanClause.Occur.MUST); builder.add(new TermQuery(new Term("foo", "bar")), BooleanClause.Occur.MUST);
builder.add(new TermQuery(new Term("no", "baz")), BooleanClause.Occur.MUST_NOT); builder.add(new TermQuery(new Term("no", "baz")), BooleanClause.Occur.MUST_NOT);
Weight weight = builder.build().createWeight(searcher, false); Weight weight = builder.build().createWeight(searcher, false, 1f);
// whenever the allowed fields match the fields in the query and we do not deny access to any fields we allow caching. // whenever the allowed fields match the fields in the query and we do not deny access to any fields we allow caching.
IndicesAccessControl.IndexAccessControl permissions = new IndicesAccessControl.IndexAccessControl(true, IndicesAccessControl.IndexAccessControl permissions = new IndicesAccessControl.IndexAccessControl(true,

View File

@ -518,26 +518,16 @@ public class SecurityIndexSearcherWrapperUnitTests extends ESTestCase {
return weight.explain(context, doc); return weight.explain(context, doc);
} }
@Override
public float getValueForNormalization() throws IOException {
return weight.getValueForNormalization();
}
@Override
public void normalize(float norm, float boost) {
weight.normalize(norm, boost);
}
@Override @Override
public Scorer scorer(LeafReaderContext context) throws IOException { public Scorer scorer(LeafReaderContext context) throws IOException {
assertTrue(seenLeaves.add(context.reader().getCoreCacheKey())); assertTrue(seenLeaves.add(context.reader().getCoreCacheHelper().getKey()));
return weight.scorer(context); return weight.scorer(context);
} }
@Override @Override
public BulkScorer bulkScorer(LeafReaderContext context) public BulkScorer bulkScorer(LeafReaderContext context)
throws IOException { throws IOException {
assertTrue(seenLeaves.add(context.reader().getCoreCacheKey())); assertTrue(seenLeaves.add(context.reader().getCoreCacheHelper().getKey()));
return weight.bulkScorer(context); return weight.bulkScorer(context);
} }
} }
@ -565,8 +555,8 @@ public class SecurityIndexSearcherWrapperUnitTests extends ESTestCase {
} }
@Override @Override
public Weight createWeight(IndexSearcher searcher, boolean needsScores) throws IOException { public Weight createWeight(IndexSearcher searcher, boolean needsScores, float boost) throws IOException {
return new CreateScorerOnceWeight(query.createWeight(searcher, needsScores)); return new CreateScorerOnceWeight(query.createWeight(searcher, needsScores, boost));
} }
@Override @Override