remove workaround for highlighter bug with geo queries (#20418)

This has been fixed in Lucene
https://issues.apache.org/jira/browse/LUCENE-7293
This commit also adds the tests from #20412
This commit is contained in:
Britta Weber 2016-09-13 14:59:56 +02:00 committed by GitHub
parent 6090c51fc5
commit 444c4f1af8
3 changed files with 46 additions and 7 deletions

View File

@ -87,11 +87,7 @@ public final class CustomQueryScorer extends QueryScorer {
} }
protected void extract(Query query, float boost, Map<String, WeightedSpanTerm> terms) throws IOException { protected void extract(Query query, float boost, Map<String, WeightedSpanTerm> terms) throws IOException {
if (query instanceof GeoPointInBBoxQuery) { if (query instanceof HasChildQueryBuilder.LateParsingQuery) {
// skip all geo queries, see https://issues.apache.org/jira/browse/LUCENE-7293 and
// https://github.com/elastic/elasticsearch/issues/17537
return;
} else if (query instanceof HasChildQueryBuilder.LateParsingQuery) {
// skip has_child or has_parent queries, see: https://github.com/elastic/elasticsearch/issues/14999 // skip has_child or has_parent queries, see: https://github.com/elastic/elasticsearch/issues/14999
return; return;
} else if (query instanceof FunctionScoreQuery) { } else if (query instanceof FunctionScoreQuery) {

View File

@ -26,6 +26,7 @@ import org.elasticsearch.action.search.SearchRequestBuilder;
import org.elasticsearch.action.search.SearchResponse; import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.action.support.WriteRequest; import org.elasticsearch.action.support.WriteRequest;
import org.elasticsearch.cluster.metadata.IndexMetaData; import org.elasticsearch.cluster.metadata.IndexMetaData;
import org.elasticsearch.common.geo.GeoPoint;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.settings.Settings.Builder; import org.elasticsearch.common.settings.Settings.Builder;
import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentBuilder;
@ -2756,6 +2757,45 @@ public class HighlighterSearchIT extends ESIntegTestCase {
assertThat(search.getHits().getAt(0).highlightFields().get("text").fragments().length, equalTo(1)); assertThat(search.getHits().getAt(0).highlightFields().get("text").fragments().length, equalTo(1));
} }
public void testGeoFieldHighlightingWhenQueryGetsRewritten() throws IOException {
// same as above but in this example the query gets rewritten during highlighting
// see https://github.com/elastic/elasticsearch/issues/17537#issuecomment-244939633
XContentBuilder mappings = jsonBuilder();
mappings.startObject();
mappings.startObject("jobs")
.startObject("_all")
.field("enabled", false)
.endObject()
.startObject("properties")
.startObject("loc")
.field("type", "geo_point")
.endObject()
.startObject("jd")
.field("type", "string")
.endObject()
.endObject()
.endObject();
mappings.endObject();
assertAcked(prepareCreate("test")
.addMapping("jobs", mappings));
ensureYellow();
client().prepareIndex("test", "jobs", "1")
.setSource(jsonBuilder().startObject().field("jd", "some आवश्यकता है- आर्य समाज अनाथालय, 68 सिविल लाइन्स, बरेली को एक पुरूष" +
" रस text")
.field("loc", "12.934059,77.610741").endObject())
.get();
refresh();
QueryBuilder query = QueryBuilders.functionScoreQuery(QueryBuilders.boolQuery().filter(QueryBuilders.geoBoundingBoxQuery("loc")
.setCorners(new GeoPoint(48.934059, 41.610741), new GeoPoint(-23.065941, 113.610741))));
SearchResponse search = client().prepareSearch().setSource(
new SearchSourceBuilder().query(query).highlighter(new HighlightBuilder().highlighterType("plain").field("jd"))).get();
assertNoFailures(search);
assertThat(search.getHits().totalHits(), equalTo(1L));
}
public void testKeywordFieldHighlighting() throws IOException { public void testKeywordFieldHighlighting() throws IOException {
// check that keyword highlighting works // check that keyword highlighting works
XContentBuilder mappings = jsonBuilder(); XContentBuilder mappings = jsonBuilder();

View File

@ -68,8 +68,11 @@ public class PlainHighlighterTests extends LuceneTestCase {
String fragment = highlighter.getBestFragment(fieldNameAnalyzer.tokenStream("text", "Arbitrary text field which should not cause " + String fragment = highlighter.getBestFragment(fieldNameAnalyzer.tokenStream("text", "Arbitrary text field which should not cause " +
"a failure"), "Arbitrary text field which should not cause a failure"); "a failure"), "Arbitrary text field which should not cause a failure");
assertThat(fragment, equalTo("Arbitrary text field which should not cause a <B>failure</B>")); assertThat(fragment, equalTo("Arbitrary text field which should not cause a <B>failure</B>"));
// TODO: This test will fail if we pass in an instance of GeoPointInBBoxQueryImpl too. Should we also find a way to work around that Query rewritten = boolQuery.rewrite(null);
// or can the query not be rewritten before it is passed into the highlighter? highlighter = new org.apache.lucene.search.highlight.Highlighter(new CustomQueryScorer(rewritten));
fragment = highlighter.getBestFragment(fieldNameAnalyzer.tokenStream("text", "Arbitrary text field which should not cause " +
"a failure"), "Arbitrary text field which should not cause a failure");
assertThat(fragment, equalTo("Arbitrary text field which should not cause a <B>failure</B>"));
} }
public void testGeoPointInBBoxQueryHighlighting() throws IOException, InvalidTokenOffsetsException { public void testGeoPointInBBoxQueryHighlighting() throws IOException, InvalidTokenOffsetsException {