Add back hashed BytesValues optimization that got lost in a previous commit.
Some FieldData consumers require hash values per byte. We provide an optimization that allows to cache the hashes internally if the consumer knows that they are needed this optimization got lost in a previous commit. This commit adds them back and folds the dedicated method into AtomicFieldData#getBytesValues(true|false)
This commit is contained in:
parent
542f021d6f
commit
454dc53483
|
@ -42,7 +42,7 @@ public abstract class AbstractAtomicNumericFieldData implements AtomicNumericFie
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues getBytesValues() {
|
public BytesValues getBytesValues(boolean needsHashes) {
|
||||||
if (isFloat) {
|
if (isFloat) {
|
||||||
final DoubleValues values = getDoubleValues();
|
final DoubleValues values = getDoubleValues();
|
||||||
return new BytesValues(values.isMultiValued()) {
|
return new BytesValues(values.isMultiValued()) {
|
||||||
|
@ -106,9 +106,4 @@ public abstract class AbstractAtomicNumericFieldData implements AtomicNumericFie
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public BytesValues getHashedBytesValues() {
|
|
||||||
return getBytesValues();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,11 +53,13 @@ public interface AtomicFieldData<Script extends ScriptDocValues> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Use a non thread safe (lightweight) view of the values as bytes.
|
* Use a non thread safe (lightweight) view of the values as bytes.
|
||||||
|
*
|
||||||
|
* @param needsHashes if <code>true</code> the implementation will use pre-build hashes if
|
||||||
|
* {@link org.elasticsearch.index.fielddata.BytesValues#currentValueHash()} is used. if no hashes
|
||||||
|
* are used <code>false</code> should be passed instead.
|
||||||
|
*
|
||||||
*/
|
*/
|
||||||
BytesValues getBytesValues();
|
BytesValues getBytesValues(boolean needsHashes);
|
||||||
|
|
||||||
|
|
||||||
BytesValues getHashedBytesValues();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a "scripting" based values.
|
* Returns a "scripting" based values.
|
||||||
|
@ -73,10 +75,8 @@ public interface AtomicFieldData<Script extends ScriptDocValues> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Use a non thread safe (lightweight) view of the values as bytes.
|
* Use a non thread safe (lightweight) view of the values as bytes.
|
||||||
|
* @param needsHashes
|
||||||
*/
|
*/
|
||||||
BytesValues.WithOrdinals getBytesValues();
|
BytesValues.WithOrdinals getBytesValues(boolean needsHashes);
|
||||||
|
|
||||||
|
|
||||||
BytesValues.WithOrdinals getHashedBytesValues();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,7 +30,7 @@ public abstract class AtomicGeoPointFieldData<Script extends ScriptDocValues> im
|
||||||
public abstract GeoPointValues getGeoPointValues();
|
public abstract GeoPointValues getGeoPointValues();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues getBytesValues() {
|
public BytesValues getBytesValues(boolean needsHashes) {
|
||||||
final GeoPointValues values = getGeoPointValues();
|
final GeoPointValues values = getGeoPointValues();
|
||||||
return new BytesValues(values.isMultiValued()) {
|
return new BytesValues(values.isMultiValued()) {
|
||||||
|
|
||||||
|
@ -67,9 +67,4 @@ public abstract class AtomicGeoPointFieldData<Script extends ScriptDocValues> im
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public BytesValues getHashedBytesValues() {
|
|
||||||
return getBytesValues();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -271,7 +271,7 @@ public final class BytesRefOrdValComparator extends NestedWrappableComparator<By
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public FieldComparator<BytesRef> setNextReader(AtomicReaderContext context) throws IOException {
|
public FieldComparator<BytesRef> setNextReader(AtomicReaderContext context) throws IOException {
|
||||||
termsIndex = indexFieldData.load(context).getBytesValues();
|
termsIndex = indexFieldData.load(context).getBytesValues(false);
|
||||||
assert termsIndex.ordinals() != null && termsIndex.ordinals().ordinals() != null;
|
assert termsIndex.ordinals() != null && termsIndex.ordinals().ordinals() != null;
|
||||||
if (missingValue == null) {
|
if (missingValue == null) {
|
||||||
missingOrd = Ordinals.MISSING_ORDINAL;
|
missingOrd = Ordinals.MISSING_ORDINAL;
|
||||||
|
|
|
@ -82,7 +82,7 @@ public final class BytesRefValComparator extends NestedWrappableComparator<Bytes
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public FieldComparator<BytesRef> setNextReader(AtomicReaderContext context) throws IOException {
|
public FieldComparator<BytesRef> setNextReader(AtomicReaderContext context) throws IOException {
|
||||||
docTerms = indexFieldData.load(context).getBytesValues();
|
docTerms = indexFieldData.load(context).getBytesValues(false);
|
||||||
if (docTerms.isMultiValued()) {
|
if (docTerms.isMultiValued()) {
|
||||||
docTerms = new MultiValuedBytesWrapper(docTerms, sortMode);
|
docTerms = new MultiValuedBytesWrapper(docTerms, sortMode);
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,7 +70,9 @@ public class BinaryDVAtomicFieldData implements AtomicFieldData<ScriptDocValues.
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues getBytesValues() {
|
public BytesValues getBytesValues(boolean needsHashes) {
|
||||||
|
// if you want hashes to be cached, you should rather store them on disk alongside the values rather than loading them into memory
|
||||||
|
// here - not supported for now, and probably not useful since this field data only applies to _id and _uid?
|
||||||
final BinaryDocValues values;
|
final BinaryDocValues values;
|
||||||
final Bits docsWithField;
|
final Bits docsWithField;
|
||||||
try {
|
try {
|
||||||
|
@ -108,16 +110,9 @@ public class BinaryDVAtomicFieldData implements AtomicFieldData<ScriptDocValues.
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public BytesValues getHashedBytesValues() {
|
|
||||||
// if you want hashes to be cached, you should rather store them on disk alongside the values rather than loading them into memory
|
|
||||||
// here - not supported for now, and probably not useful since this field data only applies to _id and _uid?
|
|
||||||
return getBytesValues();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Strings getScriptValues() {
|
public Strings getScriptValues() {
|
||||||
return new ScriptDocValues.Strings(getBytesValues());
|
return new ScriptDocValues.Strings(getBytesValues(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -88,7 +88,7 @@ public abstract class DoubleArrayAtomicFieldData extends AbstractAtomicNumericFi
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues getBytesValues() {
|
public BytesValues getBytesValues(boolean needsHashes) {
|
||||||
return BytesValues.EMPTY;
|
return BytesValues.EMPTY;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -90,21 +90,9 @@ public class FSTBytesAtomicFieldData implements AtomicFieldData.WithOrdinals<Scr
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues.WithOrdinals getBytesValues() {
|
public BytesValues.WithOrdinals getBytesValues(boolean needsHashes) {
|
||||||
assert fst != null;
|
|
||||||
return new BytesValues(fst, ordinals.ordinals());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public ScriptDocValues.Strings getScriptValues() {
|
|
||||||
assert fst != null;
|
|
||||||
return new ScriptDocValues.Strings(getBytesValues());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public org.elasticsearch.index.fielddata.BytesValues.WithOrdinals getHashedBytesValues() {
|
|
||||||
assert fst != null;
|
assert fst != null;
|
||||||
|
if (needsHashes) {
|
||||||
if (hashes == null) {
|
if (hashes == null) {
|
||||||
BytesRefFSTEnum<Long> fstEnum = new BytesRefFSTEnum<Long>(fst);
|
BytesRefFSTEnum<Long> fstEnum = new BytesRefFSTEnum<Long>(fst);
|
||||||
BigIntArray hashes = new BigIntArray(ordinals.getMaxOrd());
|
BigIntArray hashes = new BigIntArray(ordinals.getMaxOrd());
|
||||||
|
@ -125,7 +113,19 @@ public class FSTBytesAtomicFieldData implements AtomicFieldData.WithOrdinals<Scr
|
||||||
this.hashes = hashes;
|
this.hashes = hashes;
|
||||||
}
|
}
|
||||||
return new HashedBytesValues(fst, ordinals.ordinals(), hashes);
|
return new HashedBytesValues(fst, ordinals.ordinals(), hashes);
|
||||||
|
} else {
|
||||||
|
return new BytesValues(fst, ordinals.ordinals());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ScriptDocValues.Strings getScriptValues() {
|
||||||
|
assert fst != null;
|
||||||
|
return new ScriptDocValues.Strings(getBytesValues(false));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static class BytesValues extends org.elasticsearch.index.fielddata.BytesValues.WithOrdinals {
|
static class BytesValues extends org.elasticsearch.index.fielddata.BytesValues.WithOrdinals {
|
||||||
|
|
||||||
|
@ -201,7 +201,7 @@ public class FSTBytesAtomicFieldData implements AtomicFieldData.WithOrdinals<Scr
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues.WithOrdinals getBytesValues() {
|
public BytesValues.WithOrdinals getBytesValues(boolean needsHashes) {
|
||||||
return new EmptyByteValuesWithOrdinals(ordinals.ordinals());
|
return new EmptyByteValuesWithOrdinals(ordinals.ordinals());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -209,11 +209,6 @@ public class FSTBytesAtomicFieldData implements AtomicFieldData.WithOrdinals<Scr
|
||||||
public ScriptDocValues.Strings getScriptValues() {
|
public ScriptDocValues.Strings getScriptValues() {
|
||||||
return ScriptDocValues.EMPTY_STRINGS;
|
return ScriptDocValues.EMPTY_STRINGS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public org.elasticsearch.index.fielddata.BytesValues.WithOrdinals getHashedBytesValues() {
|
|
||||||
return getBytesValues();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -88,7 +88,7 @@ public abstract class FloatArrayAtomicFieldData extends AbstractAtomicNumericFie
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues getBytesValues() {
|
public BytesValues getBytesValues(boolean needsHashes) {
|
||||||
return BytesValues.EMPTY;
|
return BytesValues.EMPTY;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -86,7 +86,7 @@ public abstract class GeoPointDoubleArrayAtomicFieldData extends AtomicGeoPointF
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues getBytesValues() {
|
public BytesValues getBytesValues(boolean needsHashes) {
|
||||||
return BytesValues.EMPTY;
|
return BytesValues.EMPTY;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -89,7 +89,7 @@ public abstract class PackedArrayAtomicFieldData extends AbstractAtomicNumericFi
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues getBytesValues() {
|
public BytesValues getBytesValues(boolean needsHashes) {
|
||||||
return BytesValues.EMPTY;
|
return BytesValues.EMPTY;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -106,19 +106,18 @@ public class PagedBytesAtomicFieldData implements AtomicFieldData.WithOrdinals<S
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues.WithOrdinals getBytesValues() {
|
public BytesValues.WithOrdinals getBytesValues(boolean needsHashes) {
|
||||||
return new BytesValues(bytes, termOrdToBytesOffset, ordinals.ordinals());
|
if (needsHashes) {
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public org.elasticsearch.index.fielddata.BytesValues.WithOrdinals getHashedBytesValues() {
|
|
||||||
final BigIntArray hashes = getHashes();
|
final BigIntArray hashes = getHashes();
|
||||||
return new BytesValues.HashedBytesValues(hashes, bytes, termOrdToBytesOffset, ordinals.ordinals());
|
return new BytesValues.HashedBytesValues(hashes, bytes, termOrdToBytesOffset, ordinals.ordinals());
|
||||||
|
} else {
|
||||||
|
return new BytesValues(bytes, termOrdToBytesOffset, ordinals.ordinals());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ScriptDocValues.Strings getScriptValues() {
|
public ScriptDocValues.Strings getScriptValues() {
|
||||||
return new ScriptDocValues.Strings(getBytesValues());
|
return new ScriptDocValues.Strings(getBytesValues(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
static class BytesValues extends org.elasticsearch.index.fielddata.BytesValues.WithOrdinals {
|
static class BytesValues extends org.elasticsearch.index.fielddata.BytesValues.WithOrdinals {
|
||||||
|
@ -221,7 +220,7 @@ public class PagedBytesAtomicFieldData implements AtomicFieldData.WithOrdinals<S
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues.WithOrdinals getBytesValues() {
|
public BytesValues.WithOrdinals getBytesValues(boolean needsHashes) {
|
||||||
return new EmptyByteValuesWithOrdinals(ordinals.ordinals());
|
return new EmptyByteValuesWithOrdinals(ordinals.ordinals());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -74,7 +74,7 @@ abstract class SortedSetDVAtomicFieldData {
|
||||||
// no-op
|
// no-op
|
||||||
}
|
}
|
||||||
|
|
||||||
public org.elasticsearch.index.fielddata.BytesValues.WithOrdinals getBytesValues() {
|
public org.elasticsearch.index.fielddata.BytesValues.WithOrdinals getBytesValues(boolean needsHashes) {
|
||||||
final SortedSetDocValues values = getValuesNoException(reader, field);
|
final SortedSetDocValues values = getValuesNoException(reader, field);
|
||||||
return new SortedSetValues(reader, field, values);
|
return new SortedSetValues(reader, field, values);
|
||||||
}
|
}
|
||||||
|
|
|
@ -44,6 +44,6 @@ public final class SortedSetDVBytesAtomicFieldData extends SortedSetDVAtomicFiel
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Strings getScriptValues() {
|
public Strings getScriptValues() {
|
||||||
return new ScriptDocValues.Strings(getBytesValues());
|
return new ScriptDocValues.Strings(getBytesValues(false));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,7 +50,7 @@ public class SortedSetDVNumericAtomicFieldData extends SortedSetDVAtomicFieldDat
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public LongValues getLongValues() {
|
public LongValues getLongValues() {
|
||||||
final BytesValues.WithOrdinals values = super.getBytesValues();
|
final BytesValues.WithOrdinals values = super.getBytesValues(false);
|
||||||
return new LongValues.WithOrdinals(values.ordinals()) {
|
return new LongValues.WithOrdinals(values.ordinals()) {
|
||||||
@Override
|
@Override
|
||||||
public long getValueByOrd(long ord) {
|
public long getValueByOrd(long ord) {
|
||||||
|
@ -62,7 +62,7 @@ public class SortedSetDVNumericAtomicFieldData extends SortedSetDVAtomicFieldDat
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public DoubleValues getDoubleValues() {
|
public DoubleValues getDoubleValues() {
|
||||||
final BytesValues.WithOrdinals values = super.getBytesValues();
|
final BytesValues.WithOrdinals values = super.getBytesValues(false);
|
||||||
return new DoubleValues.WithOrdinals(values.ordinals()) {
|
return new DoubleValues.WithOrdinals(values.ordinals()) {
|
||||||
@Override
|
@Override
|
||||||
public double getValueByOrd(long ord) {
|
public double getValueByOrd(long ord) {
|
||||||
|
@ -73,8 +73,8 @@ public class SortedSetDVNumericAtomicFieldData extends SortedSetDVAtomicFieldDat
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BytesValues.WithOrdinals getBytesValues() {
|
public BytesValues.WithOrdinals getBytesValues(boolean needsHashes) {
|
||||||
final BytesValues.WithOrdinals values = super.getBytesValues();
|
final BytesValues.WithOrdinals values = super.getBytesValues(needsHashes);
|
||||||
return new BytesValues.WithOrdinals(values.ordinals()) {
|
return new BytesValues.WithOrdinals(values.ordinals()) {
|
||||||
final BytesRef spare = new BytesRef(16);
|
final BytesRef spare = new BytesRef(16);
|
||||||
private BytesRef convert(BytesRef input, BytesRef output) {
|
private BytesRef convert(BytesRef input, BytesRef output) {
|
||||||
|
@ -95,10 +95,4 @@ public class SortedSetDVNumericAtomicFieldData extends SortedSetDVAtomicFieldDat
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public BytesValues.WithOrdinals getHashedBytesValues() {
|
|
||||||
return getBytesValues();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,7 +61,7 @@ final class QueriesLoaderCollector extends Collector {
|
||||||
// id is only used for logging, if we fail we log the id in the catch statement
|
// id is only used for logging, if we fail we log the id in the catch statement
|
||||||
final Query parseQuery = percolator.parsePercolatorDocument(null, fieldsVisitor.source());
|
final Query parseQuery = percolator.parsePercolatorDocument(null, fieldsVisitor.source());
|
||||||
if (parseQuery != null) {
|
if (parseQuery != null) {
|
||||||
queries.put(new HashedBytesRef(idValues.copyShared()), parseQuery);
|
queries.put(new HashedBytesRef(idValues.copyShared(), idValues.currentValueHash()), parseQuery);
|
||||||
} else {
|
} else {
|
||||||
logger.warn("failed to add query [{}] - parser returned null", id);
|
logger.warn("failed to add query [{}] - parser returned null", id);
|
||||||
}
|
}
|
||||||
|
@ -75,7 +75,7 @@ final class QueriesLoaderCollector extends Collector {
|
||||||
@Override
|
@Override
|
||||||
public void setNextReader(AtomicReaderContext context) throws IOException {
|
public void setNextReader(AtomicReaderContext context) throws IOException {
|
||||||
reader = context.reader();
|
reader = context.reader();
|
||||||
idValues = idFieldData.load(context).getBytesValues();
|
idValues = idFieldData.load(context).getBytesValues(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -714,7 +714,7 @@ public class PercolatorService extends AbstractComponent {
|
||||||
for (ScoreDoc scoreDoc : topDocs.scoreDocs) {
|
for (ScoreDoc scoreDoc : topDocs.scoreDocs) {
|
||||||
int segmentIdx = ReaderUtil.subIndex(scoreDoc.doc, percolatorSearcher.reader().leaves());
|
int segmentIdx = ReaderUtil.subIndex(scoreDoc.doc, percolatorSearcher.reader().leaves());
|
||||||
AtomicReaderContext atomicReaderContext = percolatorSearcher.reader().leaves().get(segmentIdx);
|
AtomicReaderContext atomicReaderContext = percolatorSearcher.reader().leaves().get(segmentIdx);
|
||||||
BytesValues values = idFieldData.load(atomicReaderContext).getBytesValues();
|
BytesValues values = idFieldData.load(atomicReaderContext).getBytesValues(true);
|
||||||
final int localDocId = scoreDoc.doc - atomicReaderContext.docBase;
|
final int localDocId = scoreDoc.doc - atomicReaderContext.docBase;
|
||||||
assert values.hasValue(localDocId);
|
assert values.hasValue(localDocId);
|
||||||
spare.bytes = values.getValue(localDocId);
|
spare.bytes = values.getValue(localDocId);
|
||||||
|
|
|
@ -103,7 +103,7 @@ abstract class QueryCollector extends Collector {
|
||||||
@Override
|
@Override
|
||||||
public void setNextReader(AtomicReaderContext context) throws IOException {
|
public void setNextReader(AtomicReaderContext context) throws IOException {
|
||||||
// we use the UID because id might not be indexed
|
// we use the UID because id might not be indexed
|
||||||
values = idFieldData.load(context).getBytesValues();
|
values = idFieldData.load(context).getBytesValues(true);
|
||||||
if (facetCollector != null) {
|
if (facetCollector != null) {
|
||||||
facetCollector.setNextReader(context);
|
facetCollector.setNextReader(context);
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,7 +107,7 @@ public class FieldsTermsStringFacetExecutor extends FacetExecutor {
|
||||||
@Override
|
@Override
|
||||||
public void setNextReader(AtomicReaderContext context) throws IOException {
|
public void setNextReader(AtomicReaderContext context) throws IOException {
|
||||||
for (int i = 0; i < indexFieldDatas.length; i++) {
|
for (int i = 0; i < indexFieldDatas.length; i++) {
|
||||||
values[i] = indexFieldDatas[i].load(context).getBytesValues();
|
values[i] = indexFieldDatas[i].load(context).getBytesValues(true);
|
||||||
}
|
}
|
||||||
if (script != null) {
|
if (script != null) {
|
||||||
script.setNextReader(context);
|
script.setNextReader(context);
|
||||||
|
|
|
@ -107,7 +107,7 @@ public class TermsStringFacetExecutor extends FacetExecutor {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setNextReader(AtomicReaderContext context) throws IOException {
|
public void setNextReader(AtomicReaderContext context) throws IOException {
|
||||||
values = indexFieldData.load(context).getBytesValues();
|
values = indexFieldData.load(context).getBytesValues(true);
|
||||||
if (script != null) {
|
if (script != null) {
|
||||||
script.setNextReader(context);
|
script.setNextReader(context);
|
||||||
}
|
}
|
||||||
|
@ -130,7 +130,7 @@ public class TermsStringFacetExecutor extends FacetExecutor {
|
||||||
for (AtomicReaderContext readerContext : context.searcher().getTopReaderContext().leaves()) {
|
for (AtomicReaderContext readerContext : context.searcher().getTopReaderContext().leaves()) {
|
||||||
int maxDoc = readerContext.reader().maxDoc();
|
int maxDoc = readerContext.reader().maxDoc();
|
||||||
if (indexFieldData instanceof IndexFieldData.WithOrdinals) {
|
if (indexFieldData instanceof IndexFieldData.WithOrdinals) {
|
||||||
BytesValues.WithOrdinals values = ((IndexFieldData.WithOrdinals) indexFieldData).load(readerContext).getBytesValues();
|
BytesValues.WithOrdinals values = ((IndexFieldData.WithOrdinals) indexFieldData).load(readerContext).getBytesValues(false);
|
||||||
Ordinals.Docs ordinals = values.ordinals();
|
Ordinals.Docs ordinals = values.ordinals();
|
||||||
// 0 = docs with no value for field, so start from 1 instead
|
// 0 = docs with no value for field, so start from 1 instead
|
||||||
for (long ord = Ordinals.MIN_ORDINAL; ord < ordinals.getMaxOrd(); ord++) {
|
for (long ord = Ordinals.MIN_ORDINAL; ord < ordinals.getMaxOrd(); ord++) {
|
||||||
|
@ -138,7 +138,7 @@ public class TermsStringFacetExecutor extends FacetExecutor {
|
||||||
aggregator.addValue(value, value.hashCode(), values);
|
aggregator.addValue(value, value.hashCode(), values);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
BytesValues values = indexFieldData.load(readerContext).getBytesValues();
|
BytesValues values = indexFieldData.load(readerContext).getBytesValues(true);
|
||||||
for (int docId = 0; docId < maxDoc; docId++) {
|
for (int docId = 0; docId < maxDoc; docId++) {
|
||||||
final int size = values.setDocument(docId);
|
final int size = values.setDocument(docId);
|
||||||
for (int i = 0; i < size; i++) {
|
for (int i = 0; i < size; i++) {
|
||||||
|
|
|
@ -203,7 +203,7 @@ public class TermsStringOrdinalsFacetExecutor extends FacetExecutor {
|
||||||
aggregators.add(current);
|
aggregators.add(current);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
values = indexFieldData.load(context).getBytesValues();
|
values = indexFieldData.load(context).getBytesValues(false);
|
||||||
current = new ReaderAggregator(values, ordinalsCacheAbove, cacheRecycler);
|
current = new ReaderAggregator(values, ordinalsCacheAbove, cacheRecycler);
|
||||||
ordinals = values.ordinals();
|
ordinals = values.ordinals();
|
||||||
}
|
}
|
||||||
|
|
|
@ -131,7 +131,7 @@ public class TermsStatsStringFacetExecutor extends FacetExecutor {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setNextReader(AtomicReaderContext context) throws IOException {
|
public void setNextReader(AtomicReaderContext context) throws IOException {
|
||||||
keyValues = keyIndexFieldData.load(context).getBytesValues();
|
keyValues = keyIndexFieldData.load(context).getBytesValues(true);
|
||||||
if (script != null) {
|
if (script != null) {
|
||||||
script.setNextReader(context);
|
script.setNextReader(context);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -66,7 +66,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
IndexFieldData indexFieldData = getForField("value");
|
IndexFieldData indexFieldData = getForField("value");
|
||||||
AtomicReaderContext readerContext = refreshReader();
|
AtomicReaderContext readerContext = refreshReader();
|
||||||
AtomicFieldData fieldData = indexFieldData.load(readerContext);
|
AtomicFieldData fieldData = indexFieldData.load(readerContext);
|
||||||
BytesValues values = fieldData.getBytesValues();
|
BytesValues values = fieldData.getBytesValues(randomBoolean());
|
||||||
for (int i = 0; i < fieldData.getNumDocs(); ++i) {
|
for (int i = 0; i < fieldData.getNumDocs(); ++i) {
|
||||||
assertThat(values.hasValue(i), equalTo(true));
|
assertThat(values.hasValue(i), equalTo(true));
|
||||||
}
|
}
|
||||||
|
@ -82,7 +82,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
|
|
||||||
assertThat(fieldData.getNumDocs(), equalTo(3));
|
assertThat(fieldData.getNumDocs(), equalTo(3));
|
||||||
|
|
||||||
BytesValues bytesValues = fieldData.getBytesValues();
|
BytesValues bytesValues = fieldData.getBytesValues(randomBoolean());
|
||||||
|
|
||||||
assertThat(bytesValues.isMultiValued(), equalTo(false));
|
assertThat(bytesValues.isMultiValued(), equalTo(false));
|
||||||
|
|
||||||
|
@ -98,7 +98,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
assertValues(bytesValues, 1, one());
|
assertValues(bytesValues, 1, one());
|
||||||
assertValues(bytesValues, 2, three());
|
assertValues(bytesValues, 2, three());
|
||||||
|
|
||||||
BytesValues hashedBytesValues = fieldData.getBytesValues();
|
BytesValues hashedBytesValues = fieldData.getBytesValues(randomBoolean());
|
||||||
|
|
||||||
assertThat(hashedBytesValues.hasValue(0), equalTo(true));
|
assertThat(hashedBytesValues.hasValue(0), equalTo(true));
|
||||||
assertThat(hashedBytesValues.hasValue(1), equalTo(true));
|
assertThat(hashedBytesValues.hasValue(1), equalTo(true));
|
||||||
|
@ -185,7 +185,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
assertThat(fieldData.getNumDocs(), equalTo(3));
|
assertThat(fieldData.getNumDocs(), equalTo(3));
|
||||||
|
|
||||||
BytesValues bytesValues = fieldData
|
BytesValues bytesValues = fieldData
|
||||||
.getBytesValues();
|
.getBytesValues(randomBoolean());
|
||||||
|
|
||||||
assertThat(bytesValues.isMultiValued(), equalTo(false));
|
assertThat(bytesValues.isMultiValued(), equalTo(false));
|
||||||
|
|
||||||
|
@ -201,7 +201,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
assertValues(bytesValues, 1, Strings.EMPTY_ARRAY);
|
assertValues(bytesValues, 1, Strings.EMPTY_ARRAY);
|
||||||
|
|
||||||
|
|
||||||
BytesValues hashedBytesValues = fieldData.getBytesValues();
|
BytesValues hashedBytesValues = fieldData.getBytesValues(randomBoolean());
|
||||||
|
|
||||||
assertThat(hashedBytesValues.hasValue(0), equalTo(true));
|
assertThat(hashedBytesValues.hasValue(0), equalTo(true));
|
||||||
assertThat(hashedBytesValues.hasValue(1), equalTo(false));
|
assertThat(hashedBytesValues.hasValue(1), equalTo(false));
|
||||||
|
@ -227,7 +227,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
|
|
||||||
assertThat(fieldData.getNumDocs(), equalTo(3));
|
assertThat(fieldData.getNumDocs(), equalTo(3));
|
||||||
|
|
||||||
BytesValues bytesValues = fieldData.getBytesValues();
|
BytesValues bytesValues = fieldData.getBytesValues(randomBoolean());
|
||||||
|
|
||||||
assertThat(bytesValues.isMultiValued(), equalTo(true));
|
assertThat(bytesValues.isMultiValued(), equalTo(true));
|
||||||
|
|
||||||
|
@ -241,7 +241,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
|
|
||||||
assertValues(bytesValues, 0, two(), four());
|
assertValues(bytesValues, 0, two(), four());
|
||||||
|
|
||||||
BytesValues hashedBytesValues = fieldData.getBytesValues();
|
BytesValues hashedBytesValues = fieldData.getBytesValues(randomBoolean());
|
||||||
|
|
||||||
assertThat(hashedBytesValues.hasValue(0), equalTo(true));
|
assertThat(hashedBytesValues.hasValue(0), equalTo(true));
|
||||||
assertThat(hashedBytesValues.hasValue(1), equalTo(true));
|
assertThat(hashedBytesValues.hasValue(1), equalTo(true));
|
||||||
|
@ -280,7 +280,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
|
|
||||||
assertThat(fieldData.getNumDocs(), equalTo(3));
|
assertThat(fieldData.getNumDocs(), equalTo(3));
|
||||||
|
|
||||||
BytesValues bytesValues = fieldData.getBytesValues();
|
BytesValues bytesValues = fieldData.getBytesValues(randomBoolean());
|
||||||
|
|
||||||
assertThat(bytesValues.isMultiValued(), equalTo(true));
|
assertThat(bytesValues.isMultiValued(), equalTo(true));
|
||||||
|
|
||||||
|
@ -295,7 +295,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
assertValues(bytesValues, 0, two(), four());
|
assertValues(bytesValues, 0, two(), four());
|
||||||
assertValues(bytesValues, 1, Strings.EMPTY_ARRAY);
|
assertValues(bytesValues, 1, Strings.EMPTY_ARRAY);
|
||||||
|
|
||||||
BytesValues hashedBytesValues = fieldData.getBytesValues();
|
BytesValues hashedBytesValues = fieldData.getBytesValues(randomBoolean());
|
||||||
|
|
||||||
assertThat(hashedBytesValues.hasValue(0), equalTo(true));
|
assertThat(hashedBytesValues.hasValue(0), equalTo(true));
|
||||||
assertThat(hashedBytesValues.hasValue(1), equalTo(false));
|
assertThat(hashedBytesValues.hasValue(1), equalTo(false));
|
||||||
|
@ -320,7 +320,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
|
|
||||||
assertThat(fieldData.getNumDocs(), equalTo(3));
|
assertThat(fieldData.getNumDocs(), equalTo(3));
|
||||||
|
|
||||||
BytesValues bytesValues = fieldData.getBytesValues();
|
BytesValues bytesValues = fieldData.getBytesValues(randomBoolean());
|
||||||
|
|
||||||
assertThat(bytesValues.isMultiValued(), equalTo(false));
|
assertThat(bytesValues.isMultiValued(), equalTo(false));
|
||||||
|
|
||||||
|
@ -335,7 +335,7 @@ public abstract class AbstractFieldDataImplTests extends AbstractFieldDataTests
|
||||||
assertValues(bytesValues, 0, Strings.EMPTY_ARRAY);
|
assertValues(bytesValues, 0, Strings.EMPTY_ARRAY);
|
||||||
assertValues(bytesValues, 1, Strings.EMPTY_ARRAY);
|
assertValues(bytesValues, 1, Strings.EMPTY_ARRAY);
|
||||||
assertValues(bytesValues, 2, Strings.EMPTY_ARRAY);
|
assertValues(bytesValues, 2, Strings.EMPTY_ARRAY);
|
||||||
BytesValues hashedBytesValues = fieldData.getBytesValues();
|
BytesValues hashedBytesValues = fieldData.getBytesValues(randomBoolean());
|
||||||
|
|
||||||
assertThat(hashedBytesValues.hasValue(0), equalTo(false));
|
assertThat(hashedBytesValues.hasValue(0), equalTo(false));
|
||||||
assertThat(hashedBytesValues.hasValue(1), equalTo(false));
|
assertThat(hashedBytesValues.hasValue(1), equalTo(false));
|
||||||
|
|
|
@ -354,8 +354,8 @@ public class DuelFieldDataTests extends AbstractFieldDataTests {
|
||||||
assertThat(leftData.getNumDocs(), equalTo(rightData.getNumDocs()));
|
assertThat(leftData.getNumDocs(), equalTo(rightData.getNumDocs()));
|
||||||
|
|
||||||
int numDocs = leftData.getNumDocs();
|
int numDocs = leftData.getNumDocs();
|
||||||
BytesValues leftBytesValues = random.nextBoolean() ? leftData.getBytesValues() : leftData.getHashedBytesValues();
|
BytesValues leftBytesValues = leftData.getBytesValues(random.nextBoolean());
|
||||||
BytesValues rightBytesValues = random.nextBoolean() ? rightData.getBytesValues() : rightData.getHashedBytesValues();
|
BytesValues rightBytesValues = rightData.getBytesValues(random.nextBoolean());
|
||||||
BytesRef leftSpare = new BytesRef();
|
BytesRef leftSpare = new BytesRef();
|
||||||
BytesRef rightSpare = new BytesRef();
|
BytesRef rightSpare = new BytesRef();
|
||||||
for (int i = 0; i < numDocs; i++) {
|
for (int i = 0; i < numDocs; i++) {
|
||||||
|
|
|
@ -33,11 +33,6 @@ import java.util.Random;
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
import java.util.Random;
|
|
||||||
|
|
||||||
import static org.hamcrest.MatcherAssert.assertThat;
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
|
||||||
|
|
||||||
public class FilterFieldDataTest extends AbstractFieldDataTests {
|
public class FilterFieldDataTest extends AbstractFieldDataTests {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -77,7 +72,7 @@ public class FilterFieldDataTest extends AbstractFieldDataTests {
|
||||||
.put("filter.frequency.min_segment_size", 100).put("filter.frequency.min", 0.0d).put("filter.frequency.max", random.nextBoolean() ? 100 : 0.5d));
|
.put("filter.frequency.min_segment_size", 100).put("filter.frequency.min", 0.0d).put("filter.frequency.max", random.nextBoolean() ? 100 : 0.5d));
|
||||||
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("high_freq"), fieldDataType, false);
|
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("high_freq"), fieldDataType, false);
|
||||||
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
||||||
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues();
|
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues(randomBoolean());
|
||||||
Docs ordinals = bytesValues.ordinals();
|
Docs ordinals = bytesValues.ordinals();
|
||||||
assertThat(2L, equalTo(ordinals.getNumOrds()));
|
assertThat(2L, equalTo(ordinals.getNumOrds()));
|
||||||
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
||||||
|
@ -90,7 +85,7 @@ public class FilterFieldDataTest extends AbstractFieldDataTests {
|
||||||
.put("filter.frequency.min_segment_size", 100).put("filter.frequency.min", random.nextBoolean() ? 101 : 101d/200.0d).put("filter.frequency.max", 201));
|
.put("filter.frequency.min_segment_size", 100).put("filter.frequency.min", random.nextBoolean() ? 101 : 101d/200.0d).put("filter.frequency.max", 201));
|
||||||
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("high_freq"), fieldDataType, false);
|
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("high_freq"), fieldDataType, false);
|
||||||
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
||||||
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues();
|
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues(randomBoolean());
|
||||||
Docs ordinals = bytesValues.ordinals();
|
Docs ordinals = bytesValues.ordinals();
|
||||||
assertThat(1L, equalTo(ordinals.getNumOrds()));
|
assertThat(1L, equalTo(ordinals.getNumOrds()));
|
||||||
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
||||||
|
@ -103,7 +98,7 @@ public class FilterFieldDataTest extends AbstractFieldDataTests {
|
||||||
.put("filter.frequency.min_segment_size", 101).put("filter.frequency.min", random.nextBoolean() ? 101 : 101d/200.0d));
|
.put("filter.frequency.min_segment_size", 101).put("filter.frequency.min", random.nextBoolean() ? 101 : 101d/200.0d));
|
||||||
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("med_freq"), fieldDataType, false);
|
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("med_freq"), fieldDataType, false);
|
||||||
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
||||||
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues();
|
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues(randomBoolean());
|
||||||
Docs ordinals = bytesValues.ordinals();
|
Docs ordinals = bytesValues.ordinals();
|
||||||
assertThat(2L, equalTo(ordinals.getNumOrds()));
|
assertThat(2L, equalTo(ordinals.getNumOrds()));
|
||||||
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
||||||
|
@ -117,7 +112,7 @@ public class FilterFieldDataTest extends AbstractFieldDataTests {
|
||||||
.put("filter.frequency.min_segment_size", 101).put("filter.frequency.min", random.nextBoolean() ? 101 : 101d/200.0d));
|
.put("filter.frequency.min_segment_size", 101).put("filter.frequency.min", random.nextBoolean() ? 101 : 101d/200.0d));
|
||||||
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("med_freq"), fieldDataType, false);
|
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("med_freq"), fieldDataType, false);
|
||||||
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
||||||
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues();
|
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues(randomBoolean());
|
||||||
Docs ordinals = bytesValues.ordinals();
|
Docs ordinals = bytesValues.ordinals();
|
||||||
assertThat(2L, equalTo(ordinals.getNumOrds()));
|
assertThat(2L, equalTo(ordinals.getNumOrds()));
|
||||||
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
||||||
|
@ -134,7 +129,7 @@ public class FilterFieldDataTest extends AbstractFieldDataTests {
|
||||||
.put("filter.frequency.max", random.nextBoolean() ? 99 : 99d/200.0d)); // 100
|
.put("filter.frequency.max", random.nextBoolean() ? 99 : 99d/200.0d)); // 100
|
||||||
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("high_freq"), fieldDataType, false);
|
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("high_freq"), fieldDataType, false);
|
||||||
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
||||||
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues();
|
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues(randomBoolean());
|
||||||
Docs ordinals = bytesValues.ordinals();
|
Docs ordinals = bytesValues.ordinals();
|
||||||
assertThat(1L, equalTo(ordinals.getNumOrds()));
|
assertThat(1L, equalTo(ordinals.getNumOrds()));
|
||||||
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
||||||
|
@ -179,7 +174,7 @@ public class FilterFieldDataTest extends AbstractFieldDataTests {
|
||||||
.put("filter.regex.pattern", "\\d"));
|
.put("filter.regex.pattern", "\\d"));
|
||||||
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("high_freq"), fieldDataType, false);
|
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("high_freq"), fieldDataType, false);
|
||||||
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
||||||
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues();
|
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues(randomBoolean());
|
||||||
Docs ordinals = bytesValues.ordinals();
|
Docs ordinals = bytesValues.ordinals();
|
||||||
assertThat(1L, equalTo(ordinals.getNumOrds()));
|
assertThat(1L, equalTo(ordinals.getNumOrds()));
|
||||||
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
||||||
|
@ -191,7 +186,7 @@ public class FilterFieldDataTest extends AbstractFieldDataTests {
|
||||||
.put("filter.regex.pattern", "\\d{1,2}"));
|
.put("filter.regex.pattern", "\\d{1,2}"));
|
||||||
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("high_freq"), fieldDataType, false);
|
IndexFieldData fieldData = ifdService.getForField(new FieldMapper.Names("high_freq"), fieldDataType, false);
|
||||||
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
AtomicFieldData.WithOrdinals<ScriptDocValues.Strings> loadDirect = (WithOrdinals<Strings>) fieldData.loadDirect(context);
|
||||||
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues();
|
BytesValues.WithOrdinals bytesValues = loadDirect.getBytesValues(randomBoolean());
|
||||||
Docs ordinals = bytesValues.ordinals();
|
Docs ordinals = bytesValues.ordinals();
|
||||||
assertThat(2L, equalTo(ordinals.getNumOrds()));
|
assertThat(2L, equalTo(ordinals.getNumOrds()));
|
||||||
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
assertThat(1000, equalTo(ordinals.getNumDocs()));
|
||||||
|
|
Loading…
Reference in New Issue