Skip to content

Commit

Permalink
Make Document a top-level class (#74472)
Browse files Browse the repository at this point in the history
There is no reason for Document to be an inner class of ParseContext, especially as it is public and accessed directly from many different places.

This commit takes it out to its own top-level class file, which has the advantage of simplifying ParseContext which could use some love too.
  • Loading branch information
javanna authored Jun 24, 2021
1 parent 7493250 commit 7cedc3e
Show file tree
Hide file tree
Showing 47 changed files with 358 additions and 343 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ protected void registerParameters(ParameterChecker checker) throws IOException {
}

@Override
protected void assertExistsQuery(MappedFieldType fieldType, Query query, ParseContext.Document fields) {
protected void assertExistsQuery(MappedFieldType fieldType, Query query, LuceneDocument fields) {
assertThat(query, instanceOf(TermQuery.class));
TermQuery termQuery = (TermQuery) query;
assertEquals("_feature", termQuery.getTerm().field());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -133,19 +133,19 @@ public TokenStreamComponents createComponents(String fieldName) {

public void testParseNullValue() throws Exception {
DocumentMapper mapper = createIndexWithTokenCountField();
ParseContext.Document doc = parseDocument(mapper, createDocument(null));
LuceneDocument doc = parseDocument(mapper, createDocument(null));
assertNull(doc.getField("test.tc"));
}

public void testParseEmptyValue() throws Exception {
DocumentMapper mapper = createIndexWithTokenCountField();
ParseContext.Document doc = parseDocument(mapper, createDocument(""));
LuceneDocument doc = parseDocument(mapper, createDocument(""));
assertEquals(0, doc.getField("test.tc").numericValue());
}

public void testParseNotNullValue() throws Exception {
DocumentMapper mapper = createIndexWithTokenCountField();
ParseContext.Document doc = parseDocument(mapper, createDocument("three tokens string"));
LuceneDocument doc = parseDocument(mapper, createDocument("three tokens string"));
assertEquals(3, doc.getField("test.tc").numericValue());
}

Expand Down Expand Up @@ -173,7 +173,7 @@ private SourceToParse createDocument(String fieldValue) throws Exception {
return source(b -> b.field("test", fieldValue));
}

private ParseContext.Document parseDocument(DocumentMapper mapper, SourceToParse request) {
private LuceneDocument parseDocument(DocumentMapper mapper, SourceToParse request) {
return mapper.parse(request)
.docs().stream().findFirst().orElseThrow(() -> new IllegalStateException("Test object not parsed"));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,6 @@
import org.elasticsearch.Version;
import org.elasticsearch.action.ActionListener;
import org.elasticsearch.action.get.GetRequest;
import org.elasticsearch.common.xcontent.ParseField;
import org.elasticsearch.common.bytes.BytesReference;
import org.elasticsearch.common.io.stream.InputStreamStreamInput;
import org.elasticsearch.common.io.stream.NamedWriteableAwareStreamInput;
Expand All @@ -46,23 +45,24 @@
import org.elasticsearch.common.xcontent.ConstructingObjectParser;
import org.elasticsearch.common.xcontent.LoggingDeprecationHandler;
import org.elasticsearch.common.xcontent.NamedXContentRegistry;
import org.elasticsearch.common.xcontent.ParseField;
import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentHelper;
import org.elasticsearch.common.xcontent.XContentParser;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.fielddata.IndexFieldData;
import org.elasticsearch.index.fielddata.IndexFieldDataCache;
import org.elasticsearch.index.mapper.LuceneDocument;
import org.elasticsearch.index.mapper.MappedFieldType;
import org.elasticsearch.index.mapper.ParseContext;
import org.elasticsearch.index.mapper.ParsedDocument;
import org.elasticsearch.index.mapper.SourceToParse;
import org.elasticsearch.index.query.AbstractQueryBuilder;
import org.elasticsearch.index.query.QueryBuilder;
import org.elasticsearch.index.query.QueryRewriteContext;
import org.elasticsearch.index.query.SearchExecutionContext;
import org.elasticsearch.index.query.QueryShardException;
import org.elasticsearch.index.query.Rewriteable;
import org.elasticsearch.index.query.SearchExecutionContext;
import org.elasticsearch.indices.breaker.CircuitBreakerService;
import org.elasticsearch.indices.breaker.NoneCircuitBreakerService;

Expand Down Expand Up @@ -509,7 +509,7 @@ static IndexSearcher createMultiDocumentSearcher(Analyzer analyzer, Collection<P
Directory directory = new ByteBuffersDirectory();
try (IndexWriter indexWriter = new IndexWriter(directory, new IndexWriterConfig(analyzer))) {
// Indexing in order here, so that the user provided order matches with the docid sequencing:
Iterable<ParseContext.Document> iterable = () -> docs.stream()
Iterable<LuceneDocument> iterable = () -> docs.stream()
.map(ParsedDocument::docs)
.flatMap(Collection::stream)
.iterator();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@
import org.elasticsearch.index.mapper.ContentPath;
import org.elasticsearch.index.mapper.FieldMapper;
import org.elasticsearch.index.mapper.KeywordFieldMapper;
import org.elasticsearch.index.mapper.LuceneDocument;
import org.elasticsearch.index.mapper.MappedFieldType;
import org.elasticsearch.index.mapper.Mapper;
import org.elasticsearch.index.mapper.MapperParsingException;
Expand Down Expand Up @@ -381,7 +382,7 @@ static void createQueryBuilderField(Version indexVersion, BinaryFieldMapper qbFi
}

void processQuery(Query query, ParseContext context) {
ParseContext.Document doc = context.doc();
LuceneDocument doc = context.doc();
PercolatorFieldType pft = (PercolatorFieldType) this.fieldType();
QueryAnalyzer.Result result;
result = QueryAnalyzer.analyze(query);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,6 @@
import org.apache.lucene.store.Directory;
import org.apache.lucene.util.BytesRef;
import org.elasticsearch.Version;
import org.elasticsearch.core.CheckedFunction;
import org.elasticsearch.common.Strings;
import org.elasticsearch.common.bytes.BytesArray;
import org.elasticsearch.common.bytes.BytesReference;
Expand All @@ -75,8 +74,10 @@
import org.elasticsearch.common.lucene.search.function.FunctionScoreQuery;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.core.CheckedFunction;
import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.LuceneDocument;
import org.elasticsearch.index.mapper.MappedFieldType;
import org.elasticsearch.index.mapper.MapperService;
import org.elasticsearch.index.mapper.NumberFieldMapper;
Expand Down Expand Up @@ -230,7 +231,7 @@ public void testDuel() throws Exception {
return new FunctionScoreQuery(innerQuery, minScore, 1f);
});

List<ParseContext.Document> documents = new ArrayList<>();
List<LuceneDocument> documents = new ArrayList<>();
for (Supplier<Query> queryFunction : queryFunctions) {
Query query = queryFunction.get();
addQuery(query, documents);
Expand Down Expand Up @@ -326,7 +327,7 @@ public void testDuel2() throws Exception {
ranges.add(new int[]{15, 50});

SearchExecutionContext context = createSearchContext(indexService).getSearchExecutionContext();
List<ParseContext.Document> documents = new ArrayList<>();
List<LuceneDocument> documents = new ArrayList<>();
{
addQuery(new TermQuery(new Term("string_field", randomFrom(stringValues))), documents);
}
Expand Down Expand Up @@ -490,7 +491,7 @@ public void testDuelIdBased() throws Exception {
queryFunctions.add((id) -> new MatchNoDocsQuery("no reason at all"));

int numDocs = randomIntBetween(queryFunctions.size(), queryFunctions.size() * 3);
List<ParseContext.Document> documents = new ArrayList<>();
List<LuceneDocument> documents = new ArrayList<>();
for (int i = 0; i < numDocs; i++) {
String id = Integer.toString(i);
Query query = queryFunctions.get(i % queryFunctions.size()).apply(id);
Expand Down Expand Up @@ -520,7 +521,7 @@ public void testDuelIdBased() throws Exception {
}

public void testDuelSpecificQueries() throws Exception {
List<ParseContext.Document> documents = new ArrayList<>();
List<LuceneDocument> documents = new ArrayList<>();

BlendedTermQuery blendedTermQuery = BlendedTermQuery.dismaxBlendedQuery(new Term[]{new Term("field", "quick"),
new Term("field", "brown"), new Term("field", "fox")}, 1.0f);
Expand Down Expand Up @@ -567,7 +568,7 @@ public void testDuelSpecificQueries() throws Exception {
}

public void testRangeQueries() throws Exception {
List<ParseContext.Document> docs = new ArrayList<>();
List<LuceneDocument> docs = new ArrayList<>();
addQuery(IntPoint.newRangeQuery("int_field", 0, 5), docs);
addQuery(LongPoint.newRangeQuery("long_field", 5L, 10L), docs);
addQuery(HalfFloatPoint.newRangeQuery("half_float_field", 10, 15), docs);
Expand Down Expand Up @@ -634,7 +635,7 @@ public void testRangeQueries() throws Exception {
}

public void testDuelRangeQueries() throws Exception {
List<ParseContext.Document> documents = new ArrayList<>();
List<LuceneDocument> documents = new ArrayList<>();

int lowerInt = randomIntBetween(0, 256);
int upperInt = lowerInt + randomIntBetween(0, 32);
Expand Down Expand Up @@ -737,7 +738,7 @@ public void testDuelRangeQueries() throws Exception {
}

public void testPercolateMatchAll() throws Exception {
List<ParseContext.Document> docs = new ArrayList<>();
List<LuceneDocument> docs = new ArrayList<>();
addQuery(new MatchAllDocsQuery(), docs);
BooleanQuery.Builder builder = new BooleanQuery.Builder();
builder.add(new TermQuery(new Term("field", "value1")), Occur.MUST);
Expand Down Expand Up @@ -783,7 +784,7 @@ public void testPercolateMatchAll() throws Exception {
}

public void testFunctionScoreQuery() throws Exception {
List<ParseContext.Document> docs = new ArrayList<>();
List<LuceneDocument> docs = new ArrayList<>();
addQuery(new FunctionScoreQuery(new TermQuery(new Term("field", "value")), null, 1f), docs);
addQuery(new FunctionScoreQuery(new TermQuery(new Term("field", "value")), 10f, 1f), docs);
addQuery(new FunctionScoreQuery(new MatchAllDocsQuery(), null, 1f), docs);
Expand All @@ -808,7 +809,7 @@ public void testFunctionScoreQuery() throws Exception {
}

public void testPercolateSmallAndLargeDocument() throws Exception {
List<ParseContext.Document> docs = new ArrayList<>();
List<LuceneDocument> docs = new ArrayList<>();
BooleanQuery.Builder builder = new BooleanQuery.Builder();
builder.add(new TermQuery(new Term("field", "value1")), Occur.MUST);
builder.add(new TermQuery(new Term("field", "value2")), Occur.MUST);
Expand Down Expand Up @@ -901,7 +902,7 @@ public void testPercolateSmallAndLargeDocument() throws Exception {
}

public void testDuplicatedClauses() throws Exception {
List<ParseContext.Document> docs = new ArrayList<>();
List<LuceneDocument> docs = new ArrayList<>();

BooleanQuery.Builder builder = new BooleanQuery.Builder();
BooleanQuery.Builder builder1 = new BooleanQuery.Builder();
Expand Down Expand Up @@ -950,7 +951,7 @@ public void testDuplicatedClauses() throws Exception {
}

public void testDuplicatedClauses2() throws Exception {
List<ParseContext.Document> docs = new ArrayList<>();
List<LuceneDocument> docs = new ArrayList<>();

BooleanQuery.Builder builder = new BooleanQuery.Builder();
builder.setMinimumNumberShouldMatch(3);
Expand Down Expand Up @@ -1001,7 +1002,7 @@ public void testDuplicatedClauses2() throws Exception {
public void testMsmAndRanges_disjunction() throws Exception {
// Recreates a similar scenario that made testDuel() fail randomly:
// https://github.com/elastic/elasticsearch/issues/29393
List<ParseContext.Document> docs = new ArrayList<>();
List<LuceneDocument> docs = new ArrayList<>();
BooleanQuery.Builder builder = new BooleanQuery.Builder();
builder.setMinimumNumberShouldMatch(2);

Expand Down Expand Up @@ -1101,11 +1102,11 @@ private void duelRun(PercolateQuery.QueryStore queryStore, MemoryIndex memoryInd
}
}

private void addQuery(Query query, List<ParseContext.Document> docs) {
private void addQuery(Query query, List<LuceneDocument> docs) {
ParseContext.InternalParseContext parseContext = new ParseContext.InternalParseContext(
documentMapper.mappers(), indexService.getIndexSettings(), indexService.getIndexAnalyzers(), null, null, null);
fieldMapper.processQuery(query, parseContext);
ParseContext.Document queryDocument = parseContext.doc();
LuceneDocument queryDocument = parseContext.doc();
// Add to string representation of the query to make debugging easier:
queryDocument.add(new StoredField("query_to_string", query.toString()));
docs.add(queryDocument);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,6 @@
import org.elasticsearch.common.Strings;
import org.elasticsearch.common.bytes.BytesArray;
import org.elasticsearch.common.bytes.BytesReference;
import org.elasticsearch.core.Tuple;
import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.hash.MurmurHash3;
import org.elasticsearch.common.io.stream.InputStreamStreamInput;
Expand All @@ -46,8 +45,10 @@
import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.core.Tuple;
import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.LuceneDocument;
import org.elasticsearch.index.mapper.MapperParsingException;
import org.elasticsearch.index.mapper.MapperService;
import org.elasticsearch.index.mapper.ParseContext;
Expand Down Expand Up @@ -173,7 +174,7 @@ public void testExtractTerms() throws Exception {
ParseContext.InternalParseContext parseContext = new ParseContext.InternalParseContext(documentMapper.mappers(),
mapperService.getIndexSettings(), null, null, null, null);
fieldMapper.processQuery(bq.build(), parseContext);
ParseContext.Document document = parseContext.doc();
LuceneDocument document = parseContext.doc();

PercolatorFieldMapper.PercolatorFieldType fieldType = (PercolatorFieldMapper.PercolatorFieldType) fieldMapper.fieldType();
assertThat(document.getField(fieldType.extractionResultField.name()).stringValue(), equalTo(EXTRACTION_COMPLETE));
Expand Down Expand Up @@ -225,7 +226,7 @@ public void testExtractRanges() throws Exception {
ParseContext.InternalParseContext parseContext = new ParseContext.InternalParseContext(documentMapper.mappers(),
mapperService.getIndexSettings(), null, null, null, null);
fieldMapper.processQuery(bq.build(), parseContext);
ParseContext.Document document = parseContext.doc();
LuceneDocument document = parseContext.doc();

PercolatorFieldMapper.PercolatorFieldType fieldType = (PercolatorFieldMapper.PercolatorFieldType) fieldMapper.fieldType();
assertThat(document.getField(fieldType.extractionResultField.name()).stringValue(), equalTo(EXTRACTION_PARTIAL));
Expand Down Expand Up @@ -275,7 +276,7 @@ public void testExtractTermsAndRanges_failed() throws Exception {
ParseContext.InternalParseContext parseContext = new ParseContext.InternalParseContext(documentMapper.mappers(),
mapperService.getIndexSettings(), null, null, null, null);
fieldMapper.processQuery(query, parseContext);
ParseContext.Document document = parseContext.doc();
LuceneDocument document = parseContext.doc();

PercolatorFieldMapper.PercolatorFieldType fieldType = (PercolatorFieldMapper.PercolatorFieldType) fieldMapper.fieldType();
assertThat(document.getFields().size(), equalTo(1));
Expand All @@ -290,7 +291,7 @@ public void testExtractTermsAndRanges_partial() throws Exception {
ParseContext.InternalParseContext parseContext = new ParseContext.InternalParseContext(documentMapper.mappers(),
mapperService.getIndexSettings(), null, null, null, null);
fieldMapper.processQuery(phraseQuery, parseContext);
ParseContext.Document document = parseContext.doc();
LuceneDocument document = parseContext.doc();

PercolatorFieldMapper.PercolatorFieldType fieldType = (PercolatorFieldMapper.PercolatorFieldType) fieldMapper.fieldType();
assertThat(document.getFields().size(), equalTo(3));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,14 +19,15 @@
import org.apache.lucene.store.Directory;
import org.elasticsearch.Version;
import org.elasticsearch.cluster.metadata.IndexMetadata;
import org.elasticsearch.core.CheckedFunction;
import org.elasticsearch.common.io.stream.NamedWriteableRegistry;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.NamedXContentRegistry;
import org.elasticsearch.core.CheckedFunction;
import org.elasticsearch.index.fielddata.plain.BytesBinaryIndexFieldData;
import org.elasticsearch.index.mapper.BinaryFieldMapper;
import org.elasticsearch.index.mapper.ContentPath;
import org.elasticsearch.index.mapper.KeywordFieldMapper;
import org.elasticsearch.index.mapper.LuceneDocument;
import org.elasticsearch.index.mapper.ParseContext;
import org.elasticsearch.index.query.SearchExecutionContext;
import org.elasticsearch.index.query.TermQueryBuilder;
Expand Down Expand Up @@ -68,7 +69,7 @@ public void testStoringQueryBuilders() throws IOException {
for (int i = 0; i < queryBuilders.length; i++) {
queryBuilders[i] = new TermQueryBuilder(randomAlphaOfLength(4), randomAlphaOfLength(8));
ParseContext parseContext = mock(ParseContext.class);
ParseContext.Document document = new ParseContext.Document();
LuceneDocument document = new LuceneDocument();
when(parseContext.doc()).thenReturn(document);
PercolatorFieldMapper.createQueryBuilderField(version,
fieldMapper, queryBuilders[i], parseContext);
Expand Down
14 changes: 7 additions & 7 deletions server/src/main/java/org/elasticsearch/index/engine/Engine.java
Original file line number Diff line number Diff line change
Expand Up @@ -30,27 +30,27 @@
import org.apache.lucene.util.SetOnce;
import org.elasticsearch.ExceptionsHelper;
import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.core.CheckedRunnable;
import org.elasticsearch.core.Nullable;
import org.elasticsearch.common.bytes.BytesReference;
import org.elasticsearch.common.collect.ImmutableOpenMap;
import org.elasticsearch.core.Releasable;
import org.elasticsearch.core.Releasables;
import org.elasticsearch.common.logging.Loggers;
import org.elasticsearch.common.lucene.Lucene;
import org.elasticsearch.common.lucene.index.ElasticsearchDirectoryReader;
import org.elasticsearch.common.lucene.uid.Versions;
import org.elasticsearch.common.lucene.uid.VersionsAndSeqNoResolver;
import org.elasticsearch.common.lucene.uid.VersionsAndSeqNoResolver.DocIdAndVersion;
import org.elasticsearch.common.metrics.CounterMetric;
import org.elasticsearch.core.TimeValue;
import org.elasticsearch.common.util.concurrent.ReleasableLock;
import org.elasticsearch.core.CheckedRunnable;
import org.elasticsearch.core.Nullable;
import org.elasticsearch.core.Releasable;
import org.elasticsearch.core.Releasables;
import org.elasticsearch.core.TimeValue;
import org.elasticsearch.index.VersionType;
import org.elasticsearch.index.mapper.DocumentParser;
import org.elasticsearch.index.mapper.IdFieldMapper;
import org.elasticsearch.index.mapper.LuceneDocument;
import org.elasticsearch.index.mapper.Mapping;
import org.elasticsearch.index.mapper.MappingLookup;
import org.elasticsearch.index.mapper.ParseContext.Document;
import org.elasticsearch.index.mapper.ParsedDocument;
import org.elasticsearch.index.mapper.Uid;
import org.elasticsearch.index.merge.MergeStats;
Expand Down Expand Up @@ -1346,7 +1346,7 @@ public String routing() {
return this.doc.routing();
}

public List<Document> docs() {
public List<LuceneDocument> docs() {
return this.doc.docs();
}

Expand Down
Loading

0 comments on commit 7cedc3e

Please sign in to comment.