Github user cbismuth commented on a diff in the pull request:
https://github.com/apache/lucene-solr/pull/495#discussion_r234132506
--- Diff:
lucene/core/src/test/org/apache/lucene/search/TestConstantScoreScorer.java ---
@@ -0,0 +1,215 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.lucene.search;
+
+import java.io.IOException;
+
+import org.apache.lucene.document.Document;
+import org.apache.lucene.document.Field;
+import org.apache.lucene.index.IndexReader;
+import org.apache.lucene.index.LeafReaderContext;
+import org.apache.lucene.index.RandomIndexWriter;
+import org.apache.lucene.index.Term;
+import org.apache.lucene.store.Directory;
+import org.apache.lucene.util.LuceneTestCase;
+
+import static org.apache.lucene.search.BooleanClause.Occur;
+import static org.apache.lucene.search.DocIdSetIterator.NO_MORE_DOCS;
+import static org.hamcrest.CoreMatchers.equalTo;
+
+public class TestConstantScoreScorer extends LuceneTestCase {
+ private static final String FIELD = "f";
+ private static final String[] VALUES = new String[]{
+ "foo",
+ "bar",
+ "foo bar",
+ "bar foo",
+ "foo not bar",
+ "bar foo bar",
+ "azerty"
+ };
+
+ private static final Query TERM_QUERY = new BooleanQuery.Builder()
+ .add(new TermQuery(new Term(FIELD, "foo")), Occur.MUST)
+ .add(new TermQuery(new Term(FIELD, "bar")), Occur.MUST)
+ .build();
+ private static final Query PHRASE_QUERY = new PhraseQuery(FIELD, "foo",
"bar");
+
+ public void testMatching_ScoreMode_COMPLETE() throws Exception {
+ testMatching(ScoreMode.COMPLETE);
+ }
+
+ public void testMatching_ScoreMode_COMPLETE_NO_SCORES() throws Exception
{
+ testMatching(ScoreMode.COMPLETE_NO_SCORES);
+ }
+
+ private void testMatching(ScoreMode scoreMode) throws Exception {
+
+ try (TestConstantScoreScorerIndex index = new
TestConstantScoreScorerIndex()) {
+ int doc;
+ ConstantScoreScorer scorer = index.constantScoreScorer(TERM_QUERY,
1f, scoreMode);
+
+ // "foo bar" match
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(2));
+ assertThat(scorer.score(), equalTo(1f));
+
+ // should not reset iterator
+ scorer.setMinCompetitiveScore(2f);
+ assertThat(scorer.docID(), equalTo(doc));
+ assertThat(scorer.iterator().docID(), equalTo(doc));
+ assertThat(scorer.score(), equalTo(1f));
+
+ // "bar foo" match
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(3));
+ assertThat(scorer.score(), equalTo(1f));
+
+ // "foo not bar" match
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(4));
+ assertThat(scorer.score(), equalTo(1f));
+
+ // "foo bar foo" match
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(5));
+ assertThat(scorer.score(), equalTo(1f));
+
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(NO_MORE_DOCS));
+ }
+ }
+
+ public void testMatching_ScoreMode_TOP_SCORES() throws Exception {
+ try (TestConstantScoreScorerIndex index = new
TestConstantScoreScorerIndex()) {
+ int doc;
+ ConstantScoreScorer scorer = index.constantScoreScorer(TERM_QUERY,
1f, ScoreMode.TOP_SCORES);
+
+ // "foo bar" match
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(2));
+ assertThat(scorer.score(), equalTo(1f));
+
+ scorer.setMinCompetitiveScore(2f);
+ assertThat(scorer.docID(), equalTo(doc));
+ assertThat(scorer.iterator().docID(), equalTo(doc));
+ assertThat(scorer.score(), equalTo(1f));
+
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(NO_MORE_DOCS));
+ }
+ }
+
+ public void testTwoPhaseMatching_ScoreMode_COMPLETE() throws Exception {
+ testTwoPhaseMatching(ScoreMode.COMPLETE);
+ }
+
+ public void testTwoPhaseMatching_ScoreMode_COMPLETE_NO_SCORES() throws
Exception {
+ testTwoPhaseMatching(ScoreMode.COMPLETE_NO_SCORES);
+ }
+
+ private void testTwoPhaseMatching(ScoreMode scoreMode) throws Exception {
+ try (TestConstantScoreScorerIndex index = new
TestConstantScoreScorerIndex()) {
+ int doc;
+ ConstantScoreScorer scorer = index.constantScoreScorer(PHRASE_QUERY,
1f, scoreMode);
+
+ // "foo bar" match
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(2));
+ assertThat(scorer.score(), equalTo(1f));
+
+ // should not reset iterator
+ scorer.setMinCompetitiveScore(2f);
+ assertThat(scorer.docID(), equalTo(doc));
+ assertThat(scorer.iterator().docID(), equalTo(doc));
+ assertThat(scorer.score(), equalTo(1f));
+
+ // "foo not bar" will match the approximation but not the two phase
iterator
+
+ // "foo bar foo" match
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(5));
+ assertThat(scorer.score(), equalTo(1f));
+
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(NO_MORE_DOCS));
+ }
+ }
+
+ public void testTwoPhaseMatching_ScoreMode_TOP_SCORES() throws Exception
{
+ try (TestConstantScoreScorerIndex index = new
TestConstantScoreScorerIndex()) {
+ int doc;
+ ConstantScoreScorer scorer = index.constantScoreScorer(PHRASE_QUERY,
1f, ScoreMode.TOP_SCORES);
+
+ // "foo bar" match
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(2));
+ assertThat(scorer.score(), equalTo(1f));
+
+ scorer.setMinCompetitiveScore(2f);
+ assertThat(scorer.docID(), equalTo(doc));
+ assertThat(scorer.iterator().docID(), equalTo(doc));
+ assertThat(scorer.score(), equalTo(1f));
+
+ doc = scorer.iterator().nextDoc();
+ assertThat(doc, equalTo(NO_MORE_DOCS));
+ }
+ }
+
+ static class TestConstantScoreScorerIndex implements AutoCloseable {
+ private final Directory directory;
+ private final RandomIndexWriter writer;
+ private final IndexReader reader;
+
+ TestConstantScoreScorerIndex() throws IOException {
+ directory = newDirectory();
+
+ writer = new RandomIndexWriter(random(), directory,
+
newIndexWriterConfig().setMergePolicy(newLogMergePolicy(random().nextBoolean())));
+
+ for (String VALUE : VALUES) {
+ Document doc = new Document();
+ doc.add(newTextField(FIELD, VALUE, Field.Store.YES));
+ writer.addDocument(doc);
+ }
+ writer.forceMerge(1);
+
+ reader = writer.getReader();
+ writer.close();
+ }
+
+ ConstantScoreScorer constantScoreScorer(Query query, float score,
ScoreMode scoreMode) throws IOException {
+ IndexSearcher searcher = newSearcher(reader);
+ Weight weight = searcher.createWeight(new ConstantScoreQuery(query),
scoreMode, 1);
+ LeafReaderContext context =
searcher.getIndexReader().leaves().get(0);
--- End diff --
Sure, fixed in c5a83179ebd4a2775e24bd6518ea445cc2cb700e, thanks :+1:
---
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]