Skip to content

Commit

Permalink
tests for elastic#17537
Browse files Browse the repository at this point in the history
  • Loading branch information
brwe committed May 4, 2016
1 parent 52eb6f3 commit 0c1d367
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@
package org.elasticsearch.search.highlight;

import com.carrotsearch.randomizedtesting.generators.RandomPicks;

import org.elasticsearch.action.index.IndexRequestBuilder;
import org.elasticsearch.action.search.SearchRequestBuilder;
import org.elasticsearch.action.search.SearchResponse;
Expand Down Expand Up @@ -2542,4 +2541,33 @@ private void phraseBoostTestCase(String highlighterType) {
response = search.setQuery(boostingQuery(phrase, terms).boost(1).negativeBoost(1/boost)).get();
assertHighlight(response, 0, "field1", 0, 1, highlightedMatcher);
}

public void testGeoFieldHighlighting() throws IOException {

XContentBuilder mappings = jsonBuilder();
mappings.startObject();
mappings.startObject("type")
.startObject("properties")
.startObject("geo_point")
.field("type", "geo_point")
.endObject()
.endObject()
.endObject();
mappings.endObject();
assertAcked(prepareCreate("test")
.addMapping("type", mappings));
ensureYellow();

client().prepareIndex("test", "type", "1")
.setSource(jsonBuilder().startObject().field("geo_point", "60.12,100.34").endObject())
.get();
refresh();
SearchResponse search = client().prepareSearch().setSource(
new SearchSourceBuilder().query(QueryBuilders.geoBoundingBoxQuery("geo_point").setCorners(61.10078883158897, -170.15625,
-64.92354174306496, 118.47656249999999)).highlighter(new HighlightBuilder().field("*"))).get();

assertNoFailures(search);
assertThat(search.getHits().totalHits(), equalTo(1L));
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,19 @@
package org.elasticsearch.search.highlight;

import org.apache.lucene.analysis.MockAnalyzer;
import org.apache.lucene.analysis.core.KeywordAnalyzer;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.PhraseQuery;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.highlight.InvalidTokenOffsetsException;
import org.apache.lucene.search.highlight.QueryScorer;
import org.apache.lucene.spatial.geopoint.search.GeoPointInBBoxQuery;
import org.apache.lucene.util.LuceneTestCase;
import org.elasticsearch.index.analysis.FieldNameAnalyzer;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

public class PlainHighlighterTests extends LuceneTestCase {

Expand All @@ -39,4 +47,14 @@ public void testHighlightPhrase() throws Exception {
assertArrayEquals(new String[] {"bar <B>foo</B> <B>bar</B> foo"}, frags);
}

public void testGeoFieldHighlightingUnit() throws IOException, InvalidTokenOffsetsException {
Map analyzsers = new HashMap<>();
analyzsers.put("geo_point", new KeywordAnalyzer());
FieldNameAnalyzer fieldNameAnalyzer = new FieldNameAnalyzer(analyzsers);
org.apache.lucene.search.highlight.Highlighter highlighter = new org.apache.lucene.search.highlight.Highlighter(
new CustomQueryScorer(new GeoPointInBBoxQuery("geo_point", -64.92354174306496, 61.10078883158897, -170.15625, 118.47656249999999),
null, "geo_point", "geo_point"));
highlighter.getBestFragment(fieldNameAnalyzer.tokenStream("geo_point", "60.12,100.34"), "60.12,100.34");
}

}

0 comments on commit 0c1d367

Please sign in to comment.