use the now publicly available getDisjuncts
This commit is contained in:
parent
b1ac8e9027
commit
103059d9ef
|
@ -19,10 +19,12 @@
|
|||
|
||||
package org.elasticsearch.common.lucene.search;
|
||||
|
||||
import org.apache.lucene.search.*;
|
||||
import org.apache.lucene.search.BooleanClause;
|
||||
import org.apache.lucene.search.BooleanQuery;
|
||||
import org.apache.lucene.search.Filter;
|
||||
import org.apache.lucene.search.Query;
|
||||
import org.elasticsearch.common.Nullable;
|
||||
|
||||
import java.lang.reflect.Field;
|
||||
import java.util.List;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
|
@ -43,28 +45,6 @@ public class Queries {
|
|||
public final static Filter MATCH_ALL_FILTER = new MatchAllDocsFilter();
|
||||
public final static Filter MATCH_NO_FILTER = new MatchNoDocsFilter();
|
||||
|
||||
private final static Field disjuncts;
|
||||
|
||||
static {
|
||||
Field disjunctsX;
|
||||
try {
|
||||
disjunctsX = DisjunctionMaxQuery.class.getDeclaredField("disjuncts");
|
||||
disjunctsX.setAccessible(true);
|
||||
} catch (Exception e) {
|
||||
disjunctsX = null;
|
||||
}
|
||||
disjuncts = disjunctsX;
|
||||
}
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
public static List<Query> disMaxClauses(DisjunctionMaxQuery query) {
|
||||
try {
|
||||
return (List<Query>) disjuncts.get(query);
|
||||
} catch (IllegalAccessException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
public static Query newMatchAllQuery() {
|
||||
// We don't use MatchAllDocsQuery, its slower than the one below ... (much slower)
|
||||
// NEVER cache this XConstantScore Query it's not immutable and based on #3521
|
||||
|
|
|
@ -20,7 +20,6 @@
|
|||
package org.elasticsearch.test.unit.index.query;
|
||||
|
||||
|
||||
|
||||
import com.google.common.collect.Lists;
|
||||
import org.apache.lucene.index.Term;
|
||||
import org.apache.lucene.queries.BoostingQuery;
|
||||
|
@ -235,7 +234,7 @@ public class SimpleIndexQueryParserTests extends ElasticsearchTestCase {
|
|||
Query parsedQuery = queryParser.parse(queryString("test").field("content").field("name").useDisMax(true)).query();
|
||||
assertThat(parsedQuery, instanceOf(DisjunctionMaxQuery.class));
|
||||
DisjunctionMaxQuery disMaxQuery = (DisjunctionMaxQuery) parsedQuery;
|
||||
List<Query> disjuncts = Queries.disMaxClauses(disMaxQuery);
|
||||
List<Query> disjuncts = disMaxQuery.getDisjuncts();
|
||||
assertThat(((TermQuery) disjuncts.get(0)).getTerm(), equalTo(new Term("content", "test")));
|
||||
assertThat(((TermQuery) disjuncts.get(1)).getTerm(), equalTo(new Term("name", "test")));
|
||||
}
|
||||
|
@ -247,7 +246,7 @@ public class SimpleIndexQueryParserTests extends ElasticsearchTestCase {
|
|||
Query parsedQuery = queryParser.parse(query).query();
|
||||
assertThat(parsedQuery, instanceOf(DisjunctionMaxQuery.class));
|
||||
DisjunctionMaxQuery disMaxQuery = (DisjunctionMaxQuery) parsedQuery;
|
||||
List<Query> disjuncts = Queries.disMaxClauses(disMaxQuery);
|
||||
List<Query> disjuncts = disMaxQuery.getDisjuncts();
|
||||
assertThat(((TermQuery) disjuncts.get(0)).getTerm(), equalTo(new Term("content", "test")));
|
||||
assertThat(((TermQuery) disjuncts.get(1)).getTerm(), equalTo(new Term("name", "test")));
|
||||
}
|
||||
|
@ -258,7 +257,7 @@ public class SimpleIndexQueryParserTests extends ElasticsearchTestCase {
|
|||
Query parsedQuery = queryParser.parse(queryString("test").field("content", 2.2f).field("name").useDisMax(true)).query();
|
||||
assertThat(parsedQuery, instanceOf(DisjunctionMaxQuery.class));
|
||||
DisjunctionMaxQuery disMaxQuery = (DisjunctionMaxQuery) parsedQuery;
|
||||
List<Query> disjuncts = Queries.disMaxClauses(disMaxQuery);
|
||||
List<Query> disjuncts = disMaxQuery.getDisjuncts();
|
||||
assertThat(((TermQuery) disjuncts.get(0)).getTerm(), equalTo(new Term("content", "test")));
|
||||
assertThat((double) disjuncts.get(0).getBoost(), closeTo(2.2, 0.01));
|
||||
assertThat(((TermQuery) disjuncts.get(1)).getTerm(), equalTo(new Term("name", "test")));
|
||||
|
@ -272,7 +271,7 @@ public class SimpleIndexQueryParserTests extends ElasticsearchTestCase {
|
|||
Query parsedQuery = queryParser.parse(query).query();
|
||||
assertThat(parsedQuery, instanceOf(DisjunctionMaxQuery.class));
|
||||
DisjunctionMaxQuery disMaxQuery = (DisjunctionMaxQuery) parsedQuery;
|
||||
List<Query> disjuncts = Queries.disMaxClauses(disMaxQuery);
|
||||
List<Query> disjuncts = disMaxQuery.getDisjuncts();
|
||||
assertThat(((TermQuery) disjuncts.get(0)).getTerm(), equalTo(new Term("content", "test")));
|
||||
assertThat((double) disjuncts.get(0).getBoost(), closeTo(2.2, 0.01));
|
||||
assertThat(((TermQuery) disjuncts.get(1)).getTerm(), equalTo(new Term("name", "test")));
|
||||
|
@ -336,7 +335,7 @@ public class SimpleIndexQueryParserTests extends ElasticsearchTestCase {
|
|||
DisjunctionMaxQuery disjunctionMaxQuery = (DisjunctionMaxQuery) parsedQuery;
|
||||
assertThat((double) disjunctionMaxQuery.getBoost(), closeTo(1.2, 0.01));
|
||||
|
||||
List<Query> disjuncts = Queries.disMaxClauses(disjunctionMaxQuery);
|
||||
List<Query> disjuncts = disjunctionMaxQuery.getDisjuncts();
|
||||
assertThat(disjuncts.size(), equalTo(2));
|
||||
|
||||
Query firstQ = disjuncts.get(0);
|
||||
|
@ -357,7 +356,7 @@ public class SimpleIndexQueryParserTests extends ElasticsearchTestCase {
|
|||
DisjunctionMaxQuery disjunctionMaxQuery = (DisjunctionMaxQuery) parsedQuery;
|
||||
assertThat((double) disjunctionMaxQuery.getBoost(), closeTo(1.2, 0.01));
|
||||
|
||||
List<Query> disjuncts = Queries.disMaxClauses(disjunctionMaxQuery);
|
||||
List<Query> disjuncts = disjunctionMaxQuery.getDisjuncts();
|
||||
assertThat(disjuncts.size(), equalTo(2));
|
||||
|
||||
Query firstQ = disjuncts.get(0);
|
||||
|
@ -377,7 +376,7 @@ public class SimpleIndexQueryParserTests extends ElasticsearchTestCase {
|
|||
assertThat(parsedQuery, instanceOf(DisjunctionMaxQuery.class));
|
||||
DisjunctionMaxQuery disjunctionMaxQuery = (DisjunctionMaxQuery) parsedQuery;
|
||||
|
||||
List<Query> disjuncts = Queries.disMaxClauses(disjunctionMaxQuery);
|
||||
List<Query> disjuncts = disjunctionMaxQuery.getDisjuncts();
|
||||
assertThat(disjuncts.size(), equalTo(1));
|
||||
|
||||
PrefixQuery firstQ = (PrefixQuery) disjuncts.get(0);
|
||||
|
@ -1471,8 +1470,6 @@ public class SimpleIndexQueryParserTests extends ElasticsearchTestCase {
|
|||
}
|
||||
|
||||
|
||||
|
||||
|
||||
@Test
|
||||
public void testCustomBoostFactorQueryBuilder_withFunctionScore() throws IOException {
|
||||
IndexQueryParserService queryParser = queryParser();
|
||||
|
@ -1599,12 +1596,11 @@ public class SimpleIndexQueryParserTests extends ElasticsearchTestCase {
|
|||
assertThat(spanNearQuery.getClauses().length, equalTo(3));
|
||||
assertThat(((SpanTermQuery) spanNearQuery.getClauses()[0]).getTerm(), equalTo(new Term("age", longToPrefixCoded(34, 0))));
|
||||
assertThat(((SpanTermQuery) spanNearQuery.getClauses()[1]).getTerm(), equalTo(new Term("age", longToPrefixCoded(35, 0))));
|
||||
assertThat(((SpanTermQuery)((FieldMaskingSpanQuery) spanNearQuery.getClauses()[2]).getMaskedQuery()).getTerm(), equalTo(new Term("age_1", "36")));
|
||||
assertThat(((SpanTermQuery) ((FieldMaskingSpanQuery) spanNearQuery.getClauses()[2]).getMaskedQuery()).getTerm(), equalTo(new Term("age_1", "36")));
|
||||
assertThat(spanNearQuery.isInOrder(), equalTo(false));
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Test
|
||||
public void testSpanOrQueryBuilder() throws IOException {
|
||||
IndexQueryParserService queryParser = queryParser();
|
||||
|
@ -2263,6 +2259,6 @@ public class SimpleIndexQueryParserTests extends ElasticsearchTestCase {
|
|||
String query;
|
||||
query = copyToStringFromClasspath("/org/elasticsearch/test/unit/index/query/function-filter-score-query.json");
|
||||
Query parsedQuery = queryParser.parse(query).query();
|
||||
assertThat((double)(parsedQuery.getBoost()), Matchers.closeTo(3.0, 1.e-7));
|
||||
assertThat((double) (parsedQuery.getBoost()), Matchers.closeTo(3.0, 1.e-7));
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue