parent
210683d70b
commit
25d28f8afa
|
@ -272,7 +272,27 @@ public class JsonXContentGenerator implements XContentGenerator {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void writeRawField(String fieldName, BytesReference content, OutputStream bos) throws IOException {
|
public final void writeRawField(String fieldName, BytesReference content, OutputStream bos) throws IOException {
|
||||||
|
XContentType contentType = XContentFactory.xContentType(content);
|
||||||
|
if (contentType != null) {
|
||||||
|
writeObjectRaw(fieldName, content, bos);
|
||||||
|
} else {
|
||||||
|
writeFieldName(fieldName);
|
||||||
|
// we could potentially optimize this to not rely on exception logic...
|
||||||
|
String sValue = content.toUtf8();
|
||||||
|
try {
|
||||||
|
writeNumber(Long.parseLong(sValue));
|
||||||
|
} catch (NumberFormatException e) {
|
||||||
|
try {
|
||||||
|
writeNumber(Double.parseDouble(sValue));
|
||||||
|
} catch (NumberFormatException e1) {
|
||||||
|
writeString(sValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void writeObjectRaw(String fieldName, BytesReference content, OutputStream bos) throws IOException {
|
||||||
generator.writeRaw(", \"");
|
generator.writeRaw(", \"");
|
||||||
generator.writeRaw(fieldName);
|
generator.writeRaw(fieldName);
|
||||||
generator.writeRaw("\" : ");
|
generator.writeRaw("\" : ");
|
||||||
|
|
|
@ -68,7 +68,7 @@ public class SmileXContentGenerator extends JsonXContentGenerator {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void writeRawField(String fieldName, BytesReference content, OutputStream bos) throws IOException {
|
protected void writeObjectRaw(String fieldName, BytesReference content, OutputStream bos) throws IOException {
|
||||||
writeFieldName(fieldName);
|
writeFieldName(fieldName);
|
||||||
SmileParser parser;
|
SmileParser parser;
|
||||||
if (content.hasArray()) {
|
if (content.hasArray()) {
|
||||||
|
|
|
@ -68,7 +68,7 @@ public class YamlXContentGenerator extends JsonXContentGenerator {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void writeRawField(String fieldName, BytesReference content, OutputStream bos) throws IOException {
|
protected void writeObjectRaw(String fieldName, BytesReference content, OutputStream bos) throws IOException {
|
||||||
writeFieldName(fieldName);
|
writeFieldName(fieldName);
|
||||||
YAMLParser parser;
|
YAMLParser parser;
|
||||||
if (content.hasArray()) {
|
if (content.hasArray()) {
|
||||||
|
|
|
@ -74,7 +74,7 @@ public class CompletionFieldMapper extends AbstractFieldMapper<String> {
|
||||||
public static final String TYPE = "type";
|
public static final String TYPE = "type";
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Builder extends AbstractFieldMapper.OpenBuilder<Builder, CompletionFieldMapper> {
|
public static class Builder extends AbstractFieldMapper.OpenBuilder<Builder, CompletionFieldMapper> {
|
||||||
|
|
||||||
private NamedAnalyzer searchAnalyzer;
|
private NamedAnalyzer searchAnalyzer;
|
||||||
private NamedAnalyzer indexAnalyzer;
|
private NamedAnalyzer indexAnalyzer;
|
||||||
|
@ -206,8 +206,10 @@ public class CompletionFieldMapper extends AbstractFieldMapper<String> {
|
||||||
XContentBuilder payloadBuilder = XContentFactory.contentBuilder(parser.contentType()).copyCurrentStructure(parser);
|
XContentBuilder payloadBuilder = XContentFactory.contentBuilder(parser.contentType()).copyCurrentStructure(parser);
|
||||||
payload = payloadBuilder.bytes().toBytesRef();
|
payload = payloadBuilder.bytes().toBytesRef();
|
||||||
payloadBuilder.close();
|
payloadBuilder.close();
|
||||||
|
} else if (token.isValue()) {
|
||||||
|
payload = parser.bytesOrNull();
|
||||||
} else {
|
} else {
|
||||||
throw new MapperException("Payload must be an object");
|
throw new MapperException("payload doesn't support type " + token);
|
||||||
}
|
}
|
||||||
} else if (token == XContentParser.Token.VALUE_STRING) {
|
} else if (token == XContentParser.Token.VALUE_STRING) {
|
||||||
if ("output".equals(currentFieldName)) {
|
if ("output".equals(currentFieldName)) {
|
||||||
|
@ -232,7 +234,7 @@ public class CompletionFieldMapper extends AbstractFieldMapper<String> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
payload = payload == null ? EMPTY: payload;
|
payload = payload == null ? EMPTY : payload;
|
||||||
if (surfaceForm == null) { // no surface form use the input
|
if (surfaceForm == null) { // no surface form use the input
|
||||||
for (String input : inputs) {
|
for (String input : inputs) {
|
||||||
BytesRef suggestPayload = analyzingSuggestLookupProvider.buildPayload(new BytesRef(
|
BytesRef suggestPayload = analyzingSuggestLookupProvider.buildPayload(new BytesRef(
|
||||||
|
@ -278,17 +280,17 @@ public class CompletionFieldMapper extends AbstractFieldMapper<String> {
|
||||||
@Override
|
@Override
|
||||||
public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException {
|
public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException {
|
||||||
builder.startObject(name())
|
builder.startObject(name())
|
||||||
.field(Fields.TYPE, CONTENT_TYPE);
|
.field(Fields.TYPE, CONTENT_TYPE);
|
||||||
if (indexAnalyzer.name().equals(searchAnalyzer.name())) {
|
if (indexAnalyzer.name().equals(searchAnalyzer.name())) {
|
||||||
builder.field(Fields.ANALYZER, indexAnalyzer.name());
|
builder.field(Fields.ANALYZER, indexAnalyzer.name());
|
||||||
} else {
|
} else {
|
||||||
builder.field(Fields.INDEX_ANALYZER, indexAnalyzer.name())
|
builder.field(Fields.INDEX_ANALYZER, indexAnalyzer.name())
|
||||||
.field(Fields.SEARCH_ANALYZER, searchAnalyzer.name());
|
.field(Fields.SEARCH_ANALYZER, searchAnalyzer.name());
|
||||||
}
|
}
|
||||||
builder.field(Fields.PAYLOADS, this.payloads)
|
builder.field(Fields.PAYLOADS, this.payloads)
|
||||||
.field(Fields.PRESERVE_SEPARATORS, this.preserveSeparators)
|
.field(Fields.PRESERVE_SEPARATORS, this.preserveSeparators)
|
||||||
.field(Fields.PRESERVE_POSITION_INCREMENTS, this.preservePositionIncrements)
|
.field(Fields.PRESERVE_POSITION_INCREMENTS, this.preservePositionIncrements)
|
||||||
.endObject();
|
.endObject();
|
||||||
|
|
||||||
return builder;
|
return builder;
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,9 +23,11 @@ import org.elasticsearch.common.io.stream.StreamInput;
|
||||||
import org.elasticsearch.common.io.stream.StreamOutput;
|
import org.elasticsearch.common.io.stream.StreamOutput;
|
||||||
import org.elasticsearch.common.text.Text;
|
import org.elasticsearch.common.text.Text;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
|
import org.elasticsearch.common.xcontent.XContentHelper;
|
||||||
import org.elasticsearch.search.suggest.Suggest;
|
import org.elasticsearch.search.suggest.Suggest;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -69,7 +71,7 @@ public class CompletionSuggestion extends Suggest.Suggestion<CompletionSuggestio
|
||||||
public static class Option extends org.elasticsearch.search.suggest.Suggest.Suggestion.Entry.Option {
|
public static class Option extends org.elasticsearch.search.suggest.Suggest.Suggestion.Entry.Option {
|
||||||
private BytesReference payload;
|
private BytesReference payload;
|
||||||
|
|
||||||
public Option(Text text, float score,BytesReference payload) {
|
public Option(Text text, float score, BytesReference payload) {
|
||||||
super(text, score);
|
super(text, score);
|
||||||
this.payload = payload;
|
this.payload = payload;
|
||||||
}
|
}
|
||||||
|
@ -87,6 +89,22 @@ public class CompletionSuggestion extends Suggest.Suggestion<CompletionSuggestio
|
||||||
return payload;
|
return payload;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getPayloadAsString() {
|
||||||
|
return payload.toUtf8();
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getPayloadAsLong() {
|
||||||
|
return Long.parseLong(payload.toUtf8());
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getPayloadAsDouble() {
|
||||||
|
return Double.parseDouble(payload.toUtf8());
|
||||||
|
}
|
||||||
|
|
||||||
|
public Map<String, Object> getPayloadAsMap() {
|
||||||
|
return XContentHelper.convertToMap(payload, false).v2();
|
||||||
|
}
|
||||||
|
|
||||||
public void setScore(float score) {
|
public void setScore(float score) {
|
||||||
super.setScore(score);
|
super.setScore(score);
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,7 +28,6 @@ import org.elasticsearch.action.suggest.SuggestResponse;
|
||||||
import org.elasticsearch.common.settings.ImmutableSettings;
|
import org.elasticsearch.common.settings.ImmutableSettings;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
import org.elasticsearch.common.xcontent.json.JsonXContent;
|
|
||||||
import org.elasticsearch.index.mapper.MapperException;
|
import org.elasticsearch.index.mapper.MapperException;
|
||||||
import org.elasticsearch.search.suggest.Suggest;
|
import org.elasticsearch.search.suggest.Suggest;
|
||||||
import org.elasticsearch.search.suggest.completion.CompletionStats;
|
import org.elasticsearch.search.suggest.completion.CompletionStats;
|
||||||
|
@ -59,12 +58,12 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
private static final String FIELD = "testField";
|
private static final String FIELD = "testField";
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSimple() throws Exception{
|
public void testSimple() throws Exception {
|
||||||
createIndexAndMapping();
|
createIndexAndMapping();
|
||||||
String[][] input = {{"Foo Fighters"}, {"Foo Fighters"}, {"Foo Fighters"}, {"Foo Fighters"},
|
String[][] input = {{"Foo Fighters"}, {"Foo Fighters"}, {"Foo Fighters"}, {"Foo Fighters"},
|
||||||
{"Generator", "Foo Fighters Generator"}, {"Learn to Fly", "Foo Fighters Learn to Fly" },
|
{"Generator", "Foo Fighters Generator"}, {"Learn to Fly", "Foo Fighters Learn to Fly"},
|
||||||
{"The Prodigy"}, {"The Prodigy"}, {"The Prodigy"}, {"Firestarter", "The Prodigy Firestarter"},
|
{"The Prodigy"}, {"The Prodigy"}, {"The Prodigy"}, {"Firestarter", "The Prodigy Firestarter"},
|
||||||
{"Turbonegro"}, {"Turbonegro"}, {"Get it on", "Turbonegro Get it on"}}; // work with frequencies
|
{"Turbonegro"}, {"Turbonegro"}, {"Get it on", "Turbonegro Get it on"}}; // work with frequencies
|
||||||
for (int i = 0; i < input.length; i++) {
|
for (int i = 0; i < input.length; i++) {
|
||||||
client().prepareIndex(INDEX, TYPE, "" + i)
|
client().prepareIndex(INDEX, TYPE, "" + i)
|
||||||
.setSource(jsonBuilder()
|
.setSource(jsonBuilder()
|
||||||
|
@ -86,7 +85,7 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
public void testBasicPrefixSuggestion() throws Exception {
|
public void testBasicPrefixSuggestion() throws Exception {
|
||||||
createIndexAndMapping();
|
createIndexAndMapping();
|
||||||
for (int i = 0; i < 2; i++) {
|
for (int i = 0; i < 2; i++) {
|
||||||
createData(i==0);
|
createData(i == 0);
|
||||||
assertSuggestions("f", "Firestarter - The Prodigy", "Foo Fighters", "Generator - Foo Fighters", "Learn to Fly - Foo Fighters");
|
assertSuggestions("f", "Firestarter - The Prodigy", "Foo Fighters", "Generator - Foo Fighters", "Learn to Fly - Foo Fighters");
|
||||||
assertSuggestions("ge", "Generator - Foo Fighters", "Get it on - Turbonegro");
|
assertSuggestions("ge", "Generator - Foo Fighters", "Get it on - Turbonegro");
|
||||||
assertSuggestions("ge", "Generator - Foo Fighters", "Get it on - Turbonegro");
|
assertSuggestions("ge", "Generator - Foo Fighters", "Get it on - Turbonegro");
|
||||||
|
@ -155,7 +154,7 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
assertThat(prefixOption.getPayload(), is(notNullValue()));
|
assertThat(prefixOption.getPayload(), is(notNullValue()));
|
||||||
|
|
||||||
// parse JSON
|
// parse JSON
|
||||||
Map<String, Object> jsonMap = JsonXContent.jsonXContent.createParser(prefixOption.getPayload()).mapAndClose();
|
Map<String, Object> jsonMap = prefixOption.getPayloadAsMap();
|
||||||
assertThat(jsonMap.size(), is(2));
|
assertThat(jsonMap.size(), is(2));
|
||||||
assertThat(jsonMap.get("foo").toString(), is("bar"));
|
assertThat(jsonMap.get("foo").toString(), is("bar"));
|
||||||
assertThat(jsonMap.get("test"), is(instanceOf(List.class)));
|
assertThat(jsonMap.get("test"), is(instanceOf(List.class)));
|
||||||
|
@ -163,6 +162,60 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
assertThat(listValues, hasItems("spam", "eggs"));
|
assertThat(listValues, hasItems("spam", "eggs"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testPayloadAsNumeric() throws Exception {
|
||||||
|
createIndexAndMapping();
|
||||||
|
|
||||||
|
client().prepareIndex(INDEX, TYPE, "1").setSource(jsonBuilder()
|
||||||
|
.startObject().startObject(FIELD)
|
||||||
|
.startArray("input").value("Foo Fighters").endArray()
|
||||||
|
.field("output", "Boo Fighters")
|
||||||
|
.field("payload", 1)
|
||||||
|
.endObject().endObject()
|
||||||
|
).get();
|
||||||
|
|
||||||
|
refresh();
|
||||||
|
|
||||||
|
SuggestResponse suggestResponse = client().prepareSuggest(INDEX).addSuggestion(
|
||||||
|
new CompletionSuggestionBuilder("testSuggestions").field(FIELD).text("foo").size(10)
|
||||||
|
).execute().actionGet();
|
||||||
|
|
||||||
|
assertSuggestions(suggestResponse, "testSuggestions", "Boo Fighters");
|
||||||
|
Suggest.Suggestion.Entry.Option option = suggestResponse.getSuggest().getSuggestion("testSuggestions").getEntries().get(0).getOptions().get(0);
|
||||||
|
assertThat(option, is(instanceOf(CompletionSuggestion.Entry.Option.class)));
|
||||||
|
CompletionSuggestion.Entry.Option prefixOption = (CompletionSuggestion.Entry.Option) option;
|
||||||
|
assertThat(prefixOption.getPayload(), is(notNullValue()));
|
||||||
|
|
||||||
|
assertThat(prefixOption.getPayloadAsLong(), equalTo(1l));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testPayloadAsString() throws Exception {
|
||||||
|
createIndexAndMapping();
|
||||||
|
|
||||||
|
client().prepareIndex(INDEX, TYPE, "1").setSource(jsonBuilder()
|
||||||
|
.startObject().startObject(FIELD)
|
||||||
|
.startArray("input").value("Foo Fighters").endArray()
|
||||||
|
.field("output", "Boo Fighters")
|
||||||
|
.field("payload", "test")
|
||||||
|
.endObject().endObject()
|
||||||
|
).get();
|
||||||
|
|
||||||
|
refresh();
|
||||||
|
|
||||||
|
SuggestResponse suggestResponse = client().prepareSuggest(INDEX).addSuggestion(
|
||||||
|
new CompletionSuggestionBuilder("testSuggestions").field(FIELD).text("foo").size(10)
|
||||||
|
).execute().actionGet();
|
||||||
|
|
||||||
|
assertSuggestions(suggestResponse, "testSuggestions", "Boo Fighters");
|
||||||
|
Suggest.Suggestion.Entry.Option option = suggestResponse.getSuggest().getSuggestion("testSuggestions").getEntries().get(0).getOptions().get(0);
|
||||||
|
assertThat(option, is(instanceOf(CompletionSuggestion.Entry.Option.class)));
|
||||||
|
CompletionSuggestion.Entry.Option prefixOption = (CompletionSuggestion.Entry.Option) option;
|
||||||
|
assertThat(prefixOption.getPayload(), is(notNullValue()));
|
||||||
|
|
||||||
|
assertThat(prefixOption.getPayloadAsString(), equalTo("test"));
|
||||||
|
}
|
||||||
|
|
||||||
@Test(expected = MapperException.class)
|
@Test(expected = MapperException.class)
|
||||||
public void testThatExceptionIsThrownWhenPayloadsAreDisabledButInIndexRequest() throws Exception {
|
public void testThatExceptionIsThrownWhenPayloadsAreDisabledButInIndexRequest() throws Exception {
|
||||||
createIndexAndMapping("simple", "simple", false, false, true);
|
createIndexAndMapping("simple", "simple", false, false, true);
|
||||||
|
@ -176,19 +229,6 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
).get();
|
).get();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = MapperException.class)
|
|
||||||
public void testThatIndexingNonObjectAsPayloadThrowsException() throws Exception {
|
|
||||||
createIndexAndMapping();
|
|
||||||
|
|
||||||
client().prepareIndex(INDEX, TYPE, "1").setSource(jsonBuilder()
|
|
||||||
.startObject().startObject(FIELD)
|
|
||||||
.startArray("input").value("Foo Fighters").endArray()
|
|
||||||
.field("output", "Boo Fighters")
|
|
||||||
.field("payload", "does not work")
|
|
||||||
.endObject().endObject()
|
|
||||||
).get();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testDisabledPreserveSeperators() throws Exception {
|
public void testDisabledPreserveSeperators() throws Exception {
|
||||||
createIndexAndMapping("simple", "simple", true, false, true);
|
createIndexAndMapping("simple", "simple", true, false, true);
|
||||||
|
@ -251,7 +291,7 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testThatShortSyntaxIsWorking() throws Exception {
|
public void testThatShortSyntaxIsWorking() throws Exception {
|
||||||
createIndexAndMapping();
|
createIndexAndMapping();
|
||||||
|
|
||||||
client().prepareIndex(INDEX, TYPE, "1").setSource(jsonBuilder()
|
client().prepareIndex(INDEX, TYPE, "1").setSource(jsonBuilder()
|
||||||
|
@ -307,16 +347,16 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
@Test
|
@Test
|
||||||
public void testThatUpgradeToMultiFieldWorks() throws Exception {
|
public void testThatUpgradeToMultiFieldWorks() throws Exception {
|
||||||
Settings.Builder settingsBuilder = createDefaultSettings();
|
Settings.Builder settingsBuilder = createDefaultSettings();
|
||||||
final XContentBuilder mapping = jsonBuilder()
|
final XContentBuilder mapping = jsonBuilder()
|
||||||
.startObject()
|
.startObject()
|
||||||
.startObject(TYPE)
|
.startObject(TYPE)
|
||||||
.startObject("properties")
|
.startObject("properties")
|
||||||
.startObject(FIELD)
|
.startObject(FIELD)
|
||||||
.field("type", "string")
|
.field("type", "string")
|
||||||
.endObject()
|
|
||||||
.endObject()
|
|
||||||
.endObject()
|
.endObject()
|
||||||
.endObject();
|
.endObject()
|
||||||
|
.endObject()
|
||||||
|
.endObject();
|
||||||
client().admin().indices().prepareCreate(INDEX).addMapping(TYPE, mapping).setSettings(settingsBuilder).get();
|
client().admin().indices().prepareCreate(INDEX).addMapping(TYPE, mapping).setSettings(settingsBuilder).get();
|
||||||
ensureYellow();
|
ensureYellow();
|
||||||
client().prepareIndex(INDEX, TYPE, "1").setRefresh(true).setSource(jsonBuilder().startObject().field(FIELD, "Foo Fighters").endObject()).get();
|
client().prepareIndex(INDEX, TYPE, "1").setRefresh(true).setSource(jsonBuilder().startObject().field(FIELD, "Foo Fighters").endObject()).get();
|
||||||
|
@ -484,7 +524,7 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
.field("type", "completion").field("analyzer", "simple")
|
.field("type", "completion").field("analyzer", "simple")
|
||||||
.endObject()
|
.endObject()
|
||||||
.endObject().endObject().endObject())
|
.endObject().endObject().endObject())
|
||||||
.get();
|
.get();
|
||||||
assertThat(putMappingResponse.isAcknowledged(), is(true));
|
assertThat(putMappingResponse.isAcknowledged(), is(true));
|
||||||
|
|
||||||
// Index two entities
|
// Index two entities
|
||||||
|
@ -510,7 +550,7 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
assertThat(regexSizeInBytes, is(totalSizeInBytes));
|
assertThat(regexSizeInBytes, is(totalSizeInBytes));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void assertSuggestions(String suggestion, String ... suggestions) {
|
public void assertSuggestions(String suggestion, String... suggestions) {
|
||||||
String suggestionName = RandomStrings.randomAsciiOfLength(new Random(), 10);
|
String suggestionName = RandomStrings.randomAsciiOfLength(new Random(), 10);
|
||||||
SuggestResponse suggestResponse = client().prepareSuggest(INDEX).addSuggestion(
|
SuggestResponse suggestResponse = client().prepareSuggest(INDEX).addSuggestion(
|
||||||
new CompletionSuggestionBuilder(suggestionName).field(FIELD).text(suggestion).size(10)
|
new CompletionSuggestionBuilder(suggestionName).field(FIELD).text(suggestion).size(10)
|
||||||
|
@ -519,7 +559,7 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
assertSuggestions(suggestResponse, suggestionName, suggestions);
|
assertSuggestions(suggestResponse, suggestionName, suggestions);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void assertSuggestionsNotInOrder(String suggestString, String ... suggestions) {
|
public void assertSuggestionsNotInOrder(String suggestString, String... suggestions) {
|
||||||
String suggestionName = RandomStrings.randomAsciiOfLength(new Random(), 10);
|
String suggestionName = RandomStrings.randomAsciiOfLength(new Random(), 10);
|
||||||
SuggestResponse suggestResponse = client().prepareSuggest(INDEX).addSuggestion(
|
SuggestResponse suggestResponse = client().prepareSuggest(INDEX).addSuggestion(
|
||||||
new CompletionSuggestionBuilder(suggestionName).field(FIELD).text(suggestString).size(10)
|
new CompletionSuggestionBuilder(suggestionName).field(FIELD).text(suggestString).size(10)
|
||||||
|
@ -544,7 +584,7 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
assertThat(assertMsg, options.size(), is(suggestions.length));
|
assertThat(assertMsg, options.size(), is(suggestions.length));
|
||||||
if (suggestionOrderStrict) {
|
if (suggestionOrderStrict) {
|
||||||
for (int i = 0; i < suggestions.length; i++) {
|
for (int i = 0; i < suggestions.length; i++) {
|
||||||
String errMsg = String.format(Locale.ROOT, "Expected elem %s in list %s to be [%s] score: %s", i, suggestionList, suggestions[i], options.get(i).getScore());
|
String errMsg = String.format(Locale.ROOT, "Expected elem %s in list %s to be [%s] score: %s", i, suggestionList, suggestions[i], options.get(i).getScore());
|
||||||
assertThat(errMsg, options.get(i).getText().toString(), is(suggestions[i]));
|
assertThat(errMsg, options.get(i).getText().toString(), is(suggestions[i]));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -595,12 +635,12 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
|
|
||||||
private ImmutableSettings.Builder createDefaultSettings() {
|
private ImmutableSettings.Builder createDefaultSettings() {
|
||||||
int randomShardNumber = between(1, 5);
|
int randomShardNumber = between(1, 5);
|
||||||
int randomReplicaNumber = between(0, numberOfNodes()-1);
|
int randomReplicaNumber = between(0, numberOfNodes() - 1);
|
||||||
return settingsBuilder().put(SETTING_NUMBER_OF_SHARDS, randomShardNumber).put(SETTING_NUMBER_OF_REPLICAS, randomReplicaNumber);
|
return settingsBuilder().put(SETTING_NUMBER_OF_SHARDS, randomShardNumber).put(SETTING_NUMBER_OF_REPLICAS, randomReplicaNumber);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void createData(boolean optimize) throws IOException, InterruptedException, ExecutionException {
|
private void createData(boolean optimize) throws IOException, InterruptedException, ExecutionException {
|
||||||
String[][] input = {{"Foo Fighters"}, {"Generator", "Foo Fighters Generator"}, {"Learn to Fly", "Foo Fighters Learn to Fly" }, {"The Prodigy"}, {"Firestarter", "The Prodigy Firestarter"}, {"Turbonegro"}, {"Get it on", "Turbonegro Get it on"}};
|
String[][] input = {{"Foo Fighters"}, {"Generator", "Foo Fighters Generator"}, {"Learn to Fly", "Foo Fighters Learn to Fly"}, {"The Prodigy"}, {"Firestarter", "The Prodigy Firestarter"}, {"Turbonegro"}, {"Get it on", "Turbonegro Get it on"}};
|
||||||
String[] surface = {"Foo Fighters", "Generator - Foo Fighters", "Learn to Fly - Foo Fighters", "The Prodigy", "Firestarter - The Prodigy", "Turbonegro", "Get it on - Turbonegro"};
|
String[] surface = {"Foo Fighters", "Generator - Foo Fighters", "Learn to Fly - Foo Fighters", "The Prodigy", "Firestarter - The Prodigy", "Turbonegro", "Get it on - Turbonegro"};
|
||||||
int[] weight = {10, 9, 8, 12, 11, 6, 7};
|
int[] weight = {10, 9, 8, 12, 11, 6, 7};
|
||||||
IndexRequestBuilder[] builders = new IndexRequestBuilder[input.length];
|
IndexRequestBuilder[] builders = new IndexRequestBuilder[input.length];
|
||||||
|
@ -609,7 +649,7 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
.setSource(jsonBuilder()
|
.setSource(jsonBuilder()
|
||||||
.startObject().startObject(FIELD)
|
.startObject().startObject(FIELD)
|
||||||
.startArray("input").value(input[i]).endArray()
|
.startArray("input").value(input[i]).endArray()
|
||||||
.field("output",surface[i])
|
.field("output", surface[i])
|
||||||
.startObject("payload").field("id", i).endObject()
|
.startObject("payload").field("id", i).endObject()
|
||||||
.field("weight", 1) // WE FORCEFULLY INDEX A BOGUS WEIGHT
|
.field("weight", 1) // WE FORCEFULLY INDEX A BOGUS WEIGHT
|
||||||
.endObject()
|
.endObject()
|
||||||
|
@ -623,7 +663,7 @@ public class CompletionSuggestSearchTests extends AbstractSharedClusterTest {
|
||||||
.setSource(jsonBuilder()
|
.setSource(jsonBuilder()
|
||||||
.startObject().startObject(FIELD)
|
.startObject().startObject(FIELD)
|
||||||
.startArray("input").value(input[i]).endArray()
|
.startArray("input").value(input[i]).endArray()
|
||||||
.field("output",surface[i])
|
.field("output", surface[i])
|
||||||
.startObject("payload").field("id", i).endObject()
|
.startObject("payload").field("id", i).endObject()
|
||||||
.field("weight", weight[i])
|
.field("weight", weight[i])
|
||||||
.endObject()
|
.endObject()
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
package org.elasticsearch.test.unit.common.xcontent.builder;
|
package org.elasticsearch.test.unit.common.xcontent.builder;
|
||||||
|
|
||||||
|
import org.elasticsearch.common.bytes.BytesArray;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
import org.elasticsearch.common.xcontent.XContentFactory;
|
import org.elasticsearch.common.xcontent.XContentFactory;
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
@ -45,12 +46,23 @@ public class BuilderRawFieldTests {
|
||||||
testRawField(XContentType.SMILE);
|
testRawField(XContentType.SMILE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testYamlRawField() throws IOException {
|
||||||
|
testRawField(XContentType.YAML);
|
||||||
|
}
|
||||||
|
|
||||||
private void testRawField(XContentType type) throws IOException {
|
private void testRawField(XContentType type) throws IOException {
|
||||||
XContentBuilder builder = XContentFactory.contentBuilder(type);
|
XContentBuilder builder = XContentFactory.contentBuilder(type);
|
||||||
builder.startObject();
|
builder.startObject();
|
||||||
builder.field("field1", "value1");
|
builder.field("field1", "value1");
|
||||||
builder.rawField("_source", XContentFactory.contentBuilder(type).startObject().field("s_field", "s_value").endObject().bytes());
|
builder.rawField("_source", XContentFactory.contentBuilder(type).startObject().field("s_field", "s_value").endObject().bytes());
|
||||||
builder.field("field2", "value2");
|
builder.field("field2", "value2");
|
||||||
|
builder.rawField("payload_i", new BytesArray(Long.toString(1)));
|
||||||
|
builder.field("field3", "value3");
|
||||||
|
builder.rawField("payload_d", new BytesArray(Double.toString(1.1)));
|
||||||
|
builder.field("field4", "value4");
|
||||||
|
builder.rawField("payload_s", new BytesArray("test"));
|
||||||
|
builder.field("field5", "value5");
|
||||||
builder.endObject();
|
builder.endObject();
|
||||||
|
|
||||||
XContentParser parser = XContentFactory.xContent(type).createParser(builder.bytes());
|
XContentParser parser = XContentFactory.xContent(type).createParser(builder.bytes());
|
||||||
|
@ -73,6 +85,39 @@ public class BuilderRawFieldTests {
|
||||||
assertThat(parser.currentName(), equalTo("field2"));
|
assertThat(parser.currentName(), equalTo("field2"));
|
||||||
assertThat(parser.nextToken(), equalTo(XContentParser.Token.VALUE_STRING));
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.VALUE_STRING));
|
||||||
assertThat(parser.text(), equalTo("value2"));
|
assertThat(parser.text(), equalTo("value2"));
|
||||||
|
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.FIELD_NAME));
|
||||||
|
assertThat(parser.currentName(), equalTo("payload_i"));
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.VALUE_NUMBER));
|
||||||
|
assertThat(parser.numberType(), equalTo(XContentParser.NumberType.INT));
|
||||||
|
assertThat(parser.longValue(), equalTo(1l));
|
||||||
|
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.FIELD_NAME));
|
||||||
|
assertThat(parser.currentName(), equalTo("field3"));
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.VALUE_STRING));
|
||||||
|
assertThat(parser.text(), equalTo("value3"));
|
||||||
|
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.FIELD_NAME));
|
||||||
|
assertThat(parser.currentName(), equalTo("payload_d"));
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.VALUE_NUMBER));
|
||||||
|
assertThat(parser.numberType(), equalTo(XContentParser.NumberType.DOUBLE));
|
||||||
|
assertThat(parser.doubleValue(), equalTo(1.1d));
|
||||||
|
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.FIELD_NAME));
|
||||||
|
assertThat(parser.currentName(), equalTo("field4"));
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.VALUE_STRING));
|
||||||
|
assertThat(parser.text(), equalTo("value4"));
|
||||||
|
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.FIELD_NAME));
|
||||||
|
assertThat(parser.currentName(), equalTo("payload_s"));
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.VALUE_STRING));
|
||||||
|
assertThat(parser.text(), equalTo("test"));
|
||||||
|
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.FIELD_NAME));
|
||||||
|
assertThat(parser.currentName(), equalTo("field5"));
|
||||||
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.VALUE_STRING));
|
||||||
|
assertThat(parser.text(), equalTo("value5"));
|
||||||
|
|
||||||
assertThat(parser.nextToken(), equalTo(XContentParser.Token.END_OBJECT));
|
assertThat(parser.nextToken(), equalTo(XContentParser.Token.END_OBJECT));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue