Remove DocumentMapper#parse(String index, String type, String id, BytesReference source) (#23706)

Removed `parse(String index, String type, String id, BytesReference source)` in DocumentMapper.java and replaced all of its use in Test files with `parse(SourceToParse source)`.

`parse(String index, String type, String id, BytesReference source)` was only used in test files and never in the main code so it was removed. All of the test files that used it was then modified to use `parse(SourceToParse source)` method that existing in DocumentMapper.java
This commit is contained in:
AdityaJNair 2017-03-24 04:01:09 +13:00 committed by Nik Everett
parent 6577503b37
commit 63757efe9c
38 changed files with 667 additions and 431 deletions

View File

@ -257,11 +257,6 @@ public class DocumentMapper implements ToXContent {
return this.objectMappers; return this.objectMappers;
} }
// TODO this method looks like it is only used in tests...
public ParsedDocument parse(String index, String type, String id, BytesReference source) throws MapperParsingException {
return parse(SourceToParse.source(index, type, id, source, XContentType.JSON));
}
public ParsedDocument parse(SourceToParse source) throws MapperParsingException { public ParsedDocument parse(SourceToParse source) throws MapperParsingException {
return documentParser.parseDocument(source); return documentParser.parseDocument(source);
} }

View File

@ -27,8 +27,10 @@ import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.util.CollectionUtils; import org.elasticsearch.common.util.CollectionUtils;
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.XContentType;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.ParsedDocument; import org.elasticsearch.index.mapper.ParsedDocument;
import org.elasticsearch.index.mapper.SourceToParse;
import java.util.List; import java.util.List;
import static org.hamcrest.Matchers.equalTo; import static org.hamcrest.Matchers.equalTo;
@ -56,16 +58,17 @@ public class BinaryDVFieldDataTests extends AbstractFieldDataTestCase {
bytesList1.add(randomBytes()); bytesList1.add(randomBytes());
bytesList1.add(randomBytes()); bytesList1.add(randomBytes());
XContentBuilder doc = XContentFactory.jsonBuilder().startObject().startArray("field").value(bytesList1.get(0)).value(bytesList1.get(1)).endArray().endObject(); XContentBuilder doc = XContentFactory.jsonBuilder().startObject().startArray("field").value(bytesList1.get(0)).value(bytesList1.get(1)).endArray().endObject();
ParsedDocument d = mapper.parse("test", "test", "1", doc.bytes()); ParsedDocument d = mapper.parse(SourceToParse.source("test", "test", "1",
doc.bytes(), XContentType.JSON));
writer.addDocument(d.rootDoc()); writer.addDocument(d.rootDoc());
byte[] bytes1 = randomBytes(); byte[] bytes1 = randomBytes();
doc = XContentFactory.jsonBuilder().startObject().field("field", bytes1).endObject(); doc = XContentFactory.jsonBuilder().startObject().field("field", bytes1).endObject();
d = mapper.parse("test", "test", "2", doc.bytes()); d = mapper.parse(SourceToParse.source("test", "test", "2", doc.bytes(), XContentType.JSON));
writer.addDocument(d.rootDoc()); writer.addDocument(d.rootDoc());
doc = XContentFactory.jsonBuilder().startObject().endObject(); doc = XContentFactory.jsonBuilder().startObject().endObject();
d = mapper.parse("test", "test", "3", doc.bytes()); d = mapper.parse(SourceToParse.source("test", "test", "3", doc.bytes(), XContentType.JSON));
writer.addDocument(d.rootDoc()); writer.addDocument(d.rootDoc());
// test remove duplicate value // test remove duplicate value
@ -73,7 +76,7 @@ public class BinaryDVFieldDataTests extends AbstractFieldDataTestCase {
bytesList2.add(randomBytes()); bytesList2.add(randomBytes());
bytesList2.add(randomBytes()); bytesList2.add(randomBytes());
doc = XContentFactory.jsonBuilder().startObject().startArray("field").value(bytesList2.get(0)).value(bytesList2.get(1)).value(bytesList2.get(0)).endArray().endObject(); doc = XContentFactory.jsonBuilder().startObject().startArray("field").value(bytesList2.get(0)).value(bytesList2.get(1)).value(bytesList2.get(0)).endArray().endObject();
d = mapper.parse("test", "test", "4", doc.bytes()); d = mapper.parse(SourceToParse.source("test", "test", "4", doc.bytes(), XContentType.JSON));
writer.addDocument(d.rootDoc()); writer.addDocument(d.rootDoc());
List<LeafReaderContext> readers = refreshReader(); List<LeafReaderContext> readers = refreshReader();

View File

@ -30,6 +30,7 @@ import org.elasticsearch.common.io.stream.BytesStreamOutput;
import org.elasticsearch.common.io.stream.StreamOutput; import org.elasticsearch.common.io.stream.StreamOutput;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.plugins.Plugin; import org.elasticsearch.plugins.Plugin;
import org.elasticsearch.test.ESSingleNodeTestCase; import org.elasticsearch.test.ESSingleNodeTestCase;
import org.elasticsearch.test.InternalSettingsPlugin; import org.elasticsearch.test.InternalSettingsPlugin;
@ -92,7 +93,9 @@ public class BinaryFieldMapperTests extends ESSingleNodeTestCase {
assertTrue(CompressorFactory.isCompressed(new BytesArray(binaryValue2))); assertTrue(CompressorFactory.isCompressed(new BytesArray(binaryValue2)));
for (byte[] value : Arrays.asList(binaryValue1, binaryValue2)) { for (byte[] value : Arrays.asList(binaryValue1, binaryValue2)) {
ParsedDocument doc = mapper.parse("test", "type", "id", XContentFactory.jsonBuilder().startObject().field("field", value).endObject().bytes()); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "id",
XContentFactory.jsonBuilder().startObject().field("field", value).endObject().bytes(),
XContentType.JSON));
BytesRef indexedValue = doc.rootDoc().getBinaryValue("field"); BytesRef indexedValue = doc.rootDoc().getBinaryValue("field");
assertEquals(new BytesRef(value), indexedValue); assertEquals(new BytesRef(value), indexedValue);
FieldMapper fieldMapper = mapper.mappers().smartNameFieldMapper("field"); FieldMapper fieldMapper = mapper.mappers().smartNameFieldMapper("field");

View File

@ -39,6 +39,7 @@ import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.ToXContent; import org.elasticsearch.common.xcontent.ToXContent;
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.XContentType;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.mapper.ParseContext.Document; import org.elasticsearch.index.mapper.ParseContext.Document;
import org.elasticsearch.plugins.Plugin; import org.elasticsearch.plugins.Plugin;
@ -80,11 +81,12 @@ public class BooleanFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = parser.parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", true) .field("field", true)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
try (Directory dir = new RAMDirectory(); try (Directory dir = new RAMDirectory();
IndexWriter w = new IndexWriter(dir, new IndexWriterConfig(new MockAnalyzer(random())))) { IndexWriter w = new IndexWriter(dir, new IndexWriterConfig(new MockAnalyzer(random())))) {
@ -150,12 +152,13 @@ public class BooleanFieldMapperTests extends ESSingleNodeTestCase {
String falsy = randomFrom("false", "off", "no", "0"); String falsy = randomFrom("false", "off", "no", "0");
String truthy = randomFrom("true", "on", "yes", "1"); String truthy = randomFrom("true", "on", "yes", "1");
ParsedDocument parsedDoc = defaultMapper.parse("legacy", "type", "1", XContentFactory.jsonBuilder() ParsedDocument parsedDoc = defaultMapper.parse(SourceToParse.source("legacy", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field1", falsy) .field("field1", falsy)
.field("field2", truthy) .field("field2", truthy)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
Document doc = parsedDoc.rootDoc(); Document doc = parsedDoc.rootDoc();
assertEquals("F", doc.getField("field1").stringValue()); assertEquals("F", doc.getField("field1").stringValue());
assertEquals("T", doc.getField("field2").stringValue()); assertEquals("T", doc.getField("field2").stringValue());
@ -190,7 +193,8 @@ public class BooleanFieldMapperTests extends ESSingleNodeTestCase {
// omit "false"/"true" here as they should still be parsed correctly // omit "false"/"true" here as they should still be parsed correctly
.field("field", randomFrom("off", "no", "0", "on", "yes", "1")) .field("field", randomFrom("off", "no", "0", "on", "yes", "1"))
.endObject().bytes(); .endObject().bytes();
MapperParsingException ex = expectThrows(MapperParsingException.class, () -> defaultMapper.parse("test", "type", "1", source)); MapperParsingException ex = expectThrows(MapperParsingException.class,
() -> defaultMapper.parse(SourceToParse.source("test", "type", "1", source, XContentType.JSON)));
assertEquals("failed to parse [field]", ex.getMessage()); assertEquals("failed to parse [field]", ex.getMessage());
} }
@ -213,7 +217,7 @@ public class BooleanFieldMapperTests extends ESSingleNodeTestCase {
.startObject() .startObject()
.field("field", false) .field("field", false)
.endObject().bytes(); .endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", source); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", source, XContentType.JSON));
assertNotNull(doc.rootDoc().getField("field.as_string")); assertNotNull(doc.rootDoc().getField("field.as_string"));
} }
@ -236,13 +240,14 @@ public class BooleanFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = indexService.mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = indexService.mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument parsedDoc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument parsedDoc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("bool1", true) .field("bool1", true)
.field("bool2", true) .field("bool2", true)
.field("bool3", true) .field("bool3", true)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
Document doc = parsedDoc.rootDoc(); Document doc = parsedDoc.rootDoc();
IndexableField[] fields = doc.getFields("bool1"); IndexableField[] fields = doc.getFields("bool1");
assertEquals(2, fields.length); assertEquals(2, fields.length);

View File

@ -35,9 +35,10 @@ public class CamelCaseFieldNameTests extends ESSingleNodeTestCase {
client().admin().indices().preparePutMapping("test").setType("type").setSource(mapping, XContentType.JSON).get(); client().admin().indices().preparePutMapping("test").setType("type").setSource(mapping, XContentType.JSON).get();
DocumentMapper documentMapper = index.mapperService().documentMapper("type"); DocumentMapper documentMapper = index.mapperService().documentMapper("type");
ParsedDocument doc = documentMapper.parse("test", "type", "1", XContentFactory.jsonBuilder().startObject() ParsedDocument doc = documentMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder().startObject()
.field("thisIsCamelCase", "value1") .field("thisIsCamelCase", "value1")
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
assertNotNull(doc.dynamicMappingsUpdate()); assertNotNull(doc.dynamicMappingsUpdate());
client().admin().indices().preparePutMapping("test").setType("type") client().admin().indices().preparePutMapping("test").setType("type")

View File

@ -34,6 +34,7 @@ import org.elasticsearch.common.unit.Fuzziness;
import org.elasticsearch.common.xcontent.ToXContent; import org.elasticsearch.common.xcontent.ToXContent;
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.XContentType;
import org.elasticsearch.common.xcontent.json.JsonXContent; import org.elasticsearch.common.xcontent.json.JsonXContent;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.analysis.NamedAnalyzer; import org.elasticsearch.index.analysis.NamedAnalyzer;
@ -152,11 +153,12 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", XContentFactory.jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("completion", "suggestion") .field("completion", "suggestion")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertSuggestFields(fields, 1); assertSuggestFields(fields, 1);
} }
@ -171,11 +173,12 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", XContentFactory.jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.array("completion", "suggestion1", "suggestion2") .array("completion", "suggestion1", "suggestion2")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertSuggestFields(fields, 2); assertSuggestFields(fields, 2);
} }
@ -190,14 +193,15 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", XContentFactory.jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("completion") .startObject("completion")
.field("input", "suggestion") .field("input", "suggestion")
.field("weight", 2) .field("weight", 2)
.endObject() .endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertSuggestFields(fields, 1); assertSuggestFields(fields, 1);
} }
@ -212,14 +216,15 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", XContentFactory.jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("completion") .startObject("completion")
.array("input", "suggestion1", "suggestion2", "suggestion3") .array("input", "suggestion1", "suggestion2", "suggestion3")
.field("weight", 2) .field("weight", 2)
.endObject() .endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertSuggestFields(fields, 3); assertSuggestFields(fields, 3);
} }
@ -234,7 +239,7 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", XContentFactory.jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startArray("completion") .startArray("completion")
.startObject() .startObject()
@ -251,7 +256,8 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
.endObject() .endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertSuggestFields(fields, 3); assertSuggestFields(fields, 3);
} }
@ -266,7 +272,7 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", XContentFactory.jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startArray("completion") .startArray("completion")
.startObject() .startObject()
@ -283,7 +289,8 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
.endObject() .endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertSuggestFields(fields, 6); assertSuggestFields(fields, 6);
} }
@ -297,7 +304,7 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
try { try {
defaultMapper.parse("test", "type1", "1", XContentFactory.jsonBuilder() defaultMapper.parse(SourceToParse.source("test", "type1", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("field1") .startObject("field1")
.field("input", "suggestion1") .field("input", "suggestion1")
@ -307,7 +314,8 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
.field("weight", 3) .field("weight", 3)
.endObject() .endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
fail("Supplying contexts to a non context-enabled field should error"); fail("Supplying contexts to a non context-enabled field should error");
} catch (MapperParsingException e) { } catch (MapperParsingException e) {
assertThat(e.getRootCause().getMessage(), containsString("field1")); assertThat(e.getRootCause().getMessage(), containsString("field1"));
@ -326,11 +334,12 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
charsRefBuilder.append("sugg"); charsRefBuilder.append("sugg");
charsRefBuilder.setCharAt(2, '\u001F'); charsRefBuilder.setCharAt(2, '\u001F');
try { try {
defaultMapper.parse("test", "type1", "1", XContentFactory.jsonBuilder() defaultMapper.parse(SourceToParse.source("test", "type1", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("completion", charsRefBuilder.get().toString()) .field("completion", charsRefBuilder.get().toString())
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
fail("No error indexing value with reserved character [0x1F]"); fail("No error indexing value with reserved character [0x1F]");
} catch (MapperParsingException e) { } catch (MapperParsingException e) {
Throwable cause = e.unwrapCause().getCause(); Throwable cause = e.unwrapCause().getCause();
@ -340,11 +349,12 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
charsRefBuilder.setCharAt(2, '\u0000'); charsRefBuilder.setCharAt(2, '\u0000');
try { try {
defaultMapper.parse("test", "type1", "1", XContentFactory.jsonBuilder() defaultMapper.parse(SourceToParse.source("test", "type1", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("completion", charsRefBuilder.get().toString()) .field("completion", charsRefBuilder.get().toString())
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
fail("No error indexing value with reserved character [0x0]"); fail("No error indexing value with reserved character [0x0]");
} catch (MapperParsingException e) { } catch (MapperParsingException e) {
Throwable cause = e.unwrapCause().getCause(); Throwable cause = e.unwrapCause().getCause();
@ -354,11 +364,12 @@ public class CompletionFieldMapperTests extends ESSingleNodeTestCase {
charsRefBuilder.setCharAt(2, '\u001E'); charsRefBuilder.setCharAt(2, '\u001E');
try { try {
defaultMapper.parse("test", "type1", "1", XContentFactory.jsonBuilder() defaultMapper.parse(SourceToParse.source("test", "type1", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("completion", charsRefBuilder.get().toString()) .field("completion", charsRefBuilder.get().toString())
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
fail("No error indexing value with reserved character [0x1E]"); fail("No error indexing value with reserved character [0x1E]");
} catch (MapperParsingException e) { } catch (MapperParsingException e) {
Throwable cause = e.unwrapCause().getCause(); Throwable cause = e.unwrapCause().getCause();

View File

@ -94,7 +94,7 @@ public class CopyToMapperTests extends ESSingleNodeTestCase {
.field("int_to_str_test", 42) .field("int_to_str_test", 42)
.endObject().bytes(); .endObject().bytes();
ParsedDocument parsedDoc = docMapper.parse("test", "type1", "1", json); ParsedDocument parsedDoc = docMapper.parse(SourceToParse.source("test", "type1", "1", json, XContentType.JSON));
ParseContext.Document doc = parsedDoc.rootDoc(); ParseContext.Document doc = parsedDoc.rootDoc();
assertThat(doc.getFields("copy_test").length, equalTo(2)); assertThat(doc.getFields("copy_test").length, equalTo(2));
assertThat(doc.getFields("copy_test")[0].stringValue(), equalTo("foo")); assertThat(doc.getFields("copy_test")[0].stringValue(), equalTo("foo"));
@ -149,7 +149,8 @@ public class CopyToMapperTests extends ESSingleNodeTestCase {
.startObject("foo").startObject("bar").field("baz", "zoo").endObject().endObject() .startObject("foo").startObject("bar").field("baz", "zoo").endObject().endObject()
.endObject().bytes(); .endObject().bytes();
ParseContext.Document doc = docMapper.parse("test", "type1", "1", json).rootDoc(); ParseContext.Document doc = docMapper.parse(SourceToParse.source("test", "type1", "1", json,
XContentType.JSON)).rootDoc();
assertThat(doc.getFields("copy_test").length, equalTo(1)); assertThat(doc.getFields("copy_test").length, equalTo(1));
assertThat(doc.getFields("copy_test")[0].stringValue(), equalTo("foo")); assertThat(doc.getFields("copy_test")[0].stringValue(), equalTo("foo"));
@ -175,7 +176,8 @@ public class CopyToMapperTests extends ESSingleNodeTestCase {
.field("new_field", "bar") .field("new_field", "bar")
.endObject().bytes(); .endObject().bytes();
ParseContext.Document doc = docMapper.parse("test", "type1", "1", json).rootDoc(); ParseContext.Document doc = docMapper.parse(SourceToParse.source("test", "type1", "1", json,
XContentType.JSON)).rootDoc();
assertThat(doc.getFields("copy_test").length, equalTo(1)); assertThat(doc.getFields("copy_test").length, equalTo(1));
assertThat(doc.getFields("copy_test")[0].stringValue(), equalTo("foo")); assertThat(doc.getFields("copy_test")[0].stringValue(), equalTo("foo"));
@ -211,7 +213,8 @@ public class CopyToMapperTests extends ESSingleNodeTestCase {
.field("new_field", "bar") .field("new_field", "bar")
.endObject().bytes(); .endObject().bytes();
ParseContext.Document doc = docMapper.parse("test", "type1", "1", json).rootDoc(); ParseContext.Document doc = docMapper.parse(SourceToParse.source("test", "type1", "1", json,
XContentType.JSON)).rootDoc();
assertThat(doc.getFields("copy_test").length, equalTo(1)); assertThat(doc.getFields("copy_test").length, equalTo(1));
assertThat(doc.getFields("copy_test")[0].stringValue(), equalTo("foo")); assertThat(doc.getFields("copy_test")[0].stringValue(), equalTo("foo"));
@ -240,7 +243,7 @@ public class CopyToMapperTests extends ESSingleNodeTestCase {
.endObject().bytes(); .endObject().bytes();
try { try {
docMapper.parse("test", "type1", "1", json).rootDoc(); docMapper.parse(SourceToParse.source("test", "type1", "1", json, XContentType.JSON)).rootDoc();
fail(); fail();
} catch (MapperParsingException ex) { } catch (MapperParsingException ex) {
assertThat(ex.getMessage(), startsWith("mapping set to strict, dynamic introduction of [very] within [type1] is not allowed")); assertThat(ex.getMessage(), startsWith("mapping set to strict, dynamic introduction of [very] within [type1] is not allowed"));
@ -274,7 +277,7 @@ public class CopyToMapperTests extends ESSingleNodeTestCase {
.endObject().bytes(); .endObject().bytes();
try { try {
docMapper.parse("test", "type1", "1", json).rootDoc(); docMapper.parse(SourceToParse.source("test", "type1", "1", json, XContentType.JSON)).rootDoc();
fail(); fail();
} catch (MapperParsingException ex) { } catch (MapperParsingException ex) {
assertThat(ex.getMessage(), startsWith("mapping set to strict, dynamic introduction of [field] within [very.far] is not allowed")); assertThat(ex.getMessage(), startsWith("mapping set to strict, dynamic introduction of [field] within [very.far] is not allowed"));
@ -377,7 +380,7 @@ public class CopyToMapperTests extends ESSingleNodeTestCase {
.endArray() .endArray()
.endObject(); .endObject();
ParsedDocument doc = mapper.parse("test", "type", "1", jsonDoc.bytes()); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", jsonDoc.bytes(), XContentType.JSON));
assertEquals(6, doc.docs().size()); assertEquals(6, doc.docs().size());
Document nested = doc.docs().get(0); Document nested = doc.docs().get(0);
@ -439,7 +442,7 @@ public class CopyToMapperTests extends ESSingleNodeTestCase {
.endObject().bytes(); .endObject().bytes();
try { try {
docMapper.parse("test", "type1", "1", json).rootDoc(); docMapper.parse(SourceToParse.source("test", "type1", "1", json, XContentType.JSON)).rootDoc();
fail(); fail();
} catch (MapperParsingException ex) { } catch (MapperParsingException ex) {
assertThat(ex.getMessage(), startsWith("It is forbidden to create dynamic nested objects ([very]) through `copy_to`")); assertThat(ex.getMessage(), startsWith("It is forbidden to create dynamic nested objects ([very]) through `copy_to`"));

View File

@ -23,6 +23,7 @@ import org.apache.lucene.index.DocValuesType;
import org.apache.lucene.index.IndexableField; import org.apache.lucene.index.IndexableField;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.plugins.Plugin; import org.elasticsearch.plugins.Plugin;
import org.elasticsearch.test.ESSingleNodeTestCase; import org.elasticsearch.test.ESSingleNodeTestCase;
@ -62,11 +63,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "2016-03-11") .field("field", "2016-03-11")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -90,11 +92,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "2016-03-11") .field("field", "2016-03-11")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -111,11 +114,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "2016-03-11") .field("field", "2016-03-11")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -132,11 +136,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "2016-03-11") .field("field", "2016-03-11")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(3, fields.length); assertEquals(3, fields.length);
@ -158,11 +163,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ThrowingRunnable runnable = () -> mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ThrowingRunnable runnable = () -> mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "2016-03-99") .field("field", "2016-03-99")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
MapperParsingException e = expectThrows(MapperParsingException.class, runnable); MapperParsingException e = expectThrows(MapperParsingException.class, runnable);
assertThat(e.getCause().getMessage(), containsString("Cannot parse \"2016-03-99\"")); assertThat(e.getCause().getMessage(), containsString("Cannot parse \"2016-03-99\""));
@ -173,11 +179,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper mapper2 = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper2 = parser.parse("type", new CompressedXContent(mapping));
ParsedDocument doc = mapper2.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper2.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", ":1") .field("field", ":1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(0, fields.length); assertEquals(0, fields.length);
@ -193,11 +200,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", 1457654400) .field("field", 1457654400)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -214,11 +222,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", 1457654400) .field("field", 1457654400)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
} }
public void testNullValue() throws IOException { public void testNullValue() throws IOException {
@ -234,11 +243,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping));
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("field") .nullField("field")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertArrayEquals(new IndexableField[0], doc.rootDoc().getFields("field")); assertArrayEquals(new IndexableField[0], doc.rootDoc().getFields("field"));
mapping = XContentFactory.jsonBuilder().startObject() mapping = XContentFactory.jsonBuilder().startObject()
@ -254,11 +264,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
mapper = parser.parse("type", new CompressedXContent(mapping)); mapper = parser.parse("type", new CompressedXContent(mapping));
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("field") .nullField("field")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
IndexableField pointField = fields[0]; IndexableField pointField = fields[0];
@ -322,11 +333,12 @@ public class DateFieldMapperTests extends ESSingleNodeTestCase {
final DateTimeZone randomTimeZone = randomBoolean() ? DateTimeZone.forID(randomFrom("UTC", "CET")) : randomDateTimeZone(); final DateTimeZone randomTimeZone = randomBoolean() ? DateTimeZone.forID(randomFrom("UTC", "CET")) : randomDateTimeZone();
final DateTime randomDate = new DateTime(2016, 03, 11, 0, 0, 0, randomTimeZone); final DateTime randomDate = new DateTime(2016, 03, 11, 0, 0, 0, randomTimeZone);
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", DateTimeFormat.forPattern(timeZonePattern).print(randomDate)) .field("field", DateTimeFormat.forPattern(timeZonePattern).print(randomDate))
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);

View File

@ -23,6 +23,7 @@ import org.elasticsearch.common.bytes.BytesArray;
import org.elasticsearch.common.bytes.BytesReference; import org.elasticsearch.common.bytes.BytesReference;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.analysis.NamedAnalyzer; import org.elasticsearch.index.analysis.NamedAnalyzer;
import org.elasticsearch.index.mapper.DocumentFieldMappers; import org.elasticsearch.index.mapper.DocumentFieldMappers;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
@ -167,7 +168,11 @@ public class DocumentMapperMergeTests extends ESSingleNodeTestCase {
barrier.await(); barrier.await();
for (int i = 0; i < 200 && stopped.get() == false; i++) { for (int i = 0; i < 200 && stopped.get() == false; i++) {
final String fieldName = Integer.toString(i); final String fieldName = Integer.toString(i);
ParsedDocument doc = documentMapper.parse("test", "test", fieldName, new BytesArray("{ \"" + fieldName + "\" : \"test\" }")); ParsedDocument doc = documentMapper.parse(SourceToParse.source("test",
"test",
fieldName,
new BytesArray("{ \"" + fieldName + "\" : \"test\" }"),
XContentType.JSON));
Mapping update = doc.dynamicMappingsUpdate(); Mapping update = doc.dynamicMappingsUpdate();
assert update != null; assert update != null;
lastIntroducedFieldName.set(fieldName); lastIntroducedFieldName.set(fieldName);
@ -186,7 +191,11 @@ public class DocumentMapperMergeTests extends ESSingleNodeTestCase {
while(stopped.get() == false) { while(stopped.get() == false) {
final String fieldName = lastIntroducedFieldName.get(); final String fieldName = lastIntroducedFieldName.get();
final BytesReference source = new BytesArray("{ \"" + fieldName + "\" : \"test\" }"); final BytesReference source = new BytesArray("{ \"" + fieldName + "\" : \"test\" }");
ParsedDocument parsedDoc = documentMapper.parse("test", "test", "random", source); ParsedDocument parsedDoc = documentMapper.parse(SourceToParse.source("test",
"test",
"random",
source,
XContentType.JSON));
if (parsedDoc.dynamicMappingsUpdate() != null) { if (parsedDoc.dynamicMappingsUpdate() != null) {
// not in the mapping yet, try again // not in the mapping yet, try again
continue; continue;

View File

@ -71,7 +71,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject().startObject("foo") .startObject().startObject("foo")
.field("field", "1234") .field("field", "1234")
.endObject().endObject().bytes(); .endObject().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertNull(doc.rootDoc().getField("field")); assertNull(doc.rootDoc().getField("field"));
assertNotNull(doc.rootDoc().getField(UidFieldMapper.NAME)); assertNotNull(doc.rootDoc().getField(UidFieldMapper.NAME));
} }
@ -89,7 +89,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.field("foo", "1234") .field("foo", "1234")
.field("bar", 10) .field("bar", 10)
.endObject().bytes(); .endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertNull(doc.rootDoc().getField("foo")); assertNull(doc.rootDoc().getField("foo"));
assertNotNull(doc.rootDoc().getField("bar")); assertNotNull(doc.rootDoc().getField("bar"));
assertNotNull(doc.rootDoc().getField(UidFieldMapper.NAME)); assertNotNull(doc.rootDoc().getField(UidFieldMapper.NAME));
@ -114,7 +114,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.field("baz", 789) .field("baz", 789)
.endObject() .endObject()
.endObject().bytes(); .endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertNull(doc.dynamicMappingsUpdate()); // no update! assertNull(doc.dynamicMappingsUpdate()); // no update!
String[] values = doc.rootDoc().getValues("foo.bar.baz"); String[] values = doc.rootDoc().getValues("foo.bar.baz");
assertEquals(3, values.length); assertEquals(3, values.length);
@ -136,7 +136,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.field("foo.bar", 123) .field("foo.bar", 123)
.endObject().bytes(); .endObject().bytes();
MapperParsingException e = expectThrows(MapperParsingException.class, MapperParsingException e = expectThrows(MapperParsingException.class,
() -> mapper.parse("test", "type", "1", bytes)); () -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals( assertEquals(
"Cannot add a value for field [foo.bar] since one of the intermediate objects is mapped as a nested object: [foo]", "Cannot add a value for field [foo.bar] since one of the intermediate objects is mapped as a nested object: [foo]",
e.getMessage()); e.getMessage());
@ -162,7 +162,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.field("foo.bar",42) .field("foo.bar",42)
.endObject().bytes(); .endObject().bytes();
MapperParsingException e = expectThrows(MapperParsingException.class, MapperParsingException e = expectThrows(MapperParsingException.class,
() -> mapper.parse("test", "type", "1", bytes)); () -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals( assertEquals(
"It is forbidden to create dynamic nested objects ([foo]) through `copy_to` or dots in field names", "It is forbidden to create dynamic nested objects ([foo]) through `copy_to` or dots in field names",
e.getMessage()); e.getMessage());
@ -183,7 +183,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject().startObject("foo") .startObject().startObject("foo")
.field("bar", "something") .field("bar", "something")
.endObject().endObject().bytes(); .endObject().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertNotNull(doc.dynamicMappingsUpdate()); assertNotNull(doc.dynamicMappingsUpdate());
assertNotNull(doc.rootDoc().getField("foo.bar")); assertNotNull(doc.rootDoc().getField("foo.bar"));
} }
@ -203,7 +203,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject().startObject("foo").startObject("bar") .startObject().startObject("foo").startObject("bar")
.field("baz", "something") .field("baz", "something")
.endObject().endObject().endObject().bytes(); .endObject().endObject().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertNotNull(doc.dynamicMappingsUpdate()); assertNotNull(doc.dynamicMappingsUpdate());
assertNotNull(doc.rootDoc().getField("foo.bar.baz")); assertNotNull(doc.rootDoc().getField("foo.bar.baz"));
} }
@ -222,7 +222,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject().startObject("foo") .startObject().startObject("foo")
.field("bar", "something") .field("bar", "something")
.endObject().endObject().bytes(); .endObject().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertNull(doc.dynamicMappingsUpdate()); assertNull(doc.dynamicMappingsUpdate());
assertNull(doc.rootDoc().getField("foo.bar")); assertNull(doc.rootDoc().getField("foo.bar"));
} }
@ -350,7 +350,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startArray().value(0).value(0).endArray() .startArray().value(0).value(0).endArray()
.startArray().value(1).value(1).endArray() .startArray().value(1).value(1).endArray()
.endArray().endObject().bytes(); .endArray().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(2, doc.rootDoc().getFields("foo").length); assertEquals(2, doc.rootDoc().getFields("foo").length);
} }
@ -368,7 +368,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(0) .value(0)
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(4, doc.rootDoc().getFields("foo").length); assertEquals(4, doc.rootDoc().getFields("foo").length);
} }
@ -383,7 +383,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(0) .value(0)
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(4, doc.rootDoc().getFields("foo").length); assertEquals(4, doc.rootDoc().getFields("foo").length);
} }
@ -398,7 +398,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(0) .value(0)
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(0, doc.rootDoc().getFields("foo").length); assertEquals(0, doc.rootDoc().getFields("foo").length);
} }
@ -414,7 +414,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class, StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class,
() -> mapper.parse("test", "type", "1", bytes)); () -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals("mapping set to strict, dynamic introduction of [foo] within [type] is not allowed", exception.getMessage()); assertEquals("mapping set to strict, dynamic introduction of [foo] within [type] is not allowed", exception.getMessage());
} }
@ -430,7 +430,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startArray().value(0).value(0).endArray() .startArray().value(0).value(0).endArray()
.startArray().value(1).value(1).endArray() .startArray().value(1).value(1).endArray()
.endArray().endObject().bytes(); .endArray().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(2, doc.rootDoc().getFields("foo").length); assertEquals(2, doc.rootDoc().getFields("foo").length);
} }
@ -446,7 +446,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(0) .value(0)
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(4, doc.rootDoc().getFields("foo").length); assertEquals(4, doc.rootDoc().getFields("foo").length);
} }
@ -464,7 +464,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject().startObject("foo") .startObject().startObject("foo")
.field("bar", "baz") .field("bar", "baz")
.endObject().endObject().bytes(); .endObject().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(2, doc.rootDoc().getFields("foo.bar").length); assertEquals(2, doc.rootDoc().getFields("foo.bar").length);
} }
@ -478,7 +478,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject().startObject("foo") .startObject().startObject("foo")
.field("bar", "baz") .field("bar", "baz")
.endObject().endObject().bytes(); .endObject().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(0, doc.rootDoc().getFields("foo.bar").length); assertEquals(0, doc.rootDoc().getFields("foo.bar").length);
} }
@ -493,7 +493,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.field("bar", "baz") .field("bar", "baz")
.endObject().endObject().bytes(); .endObject().endObject().bytes();
StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class, StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class,
() -> mapper.parse("test", "type", "1", bytes)); () -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals("mapping set to strict, dynamic introduction of [foo] within [type] is not allowed", exception.getMessage()); assertEquals("mapping set to strict, dynamic introduction of [foo] within [type] is not allowed", exception.getMessage());
} }
@ -507,7 +507,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject() .startObject()
.field("bar", "baz") .field("bar", "baz")
.endObject().bytes(); .endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(0, doc.rootDoc().getFields("bar").length); assertEquals(0, doc.rootDoc().getFields("bar").length);
} }
@ -522,7 +522,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.field("bar", "baz") .field("bar", "baz")
.endObject().bytes(); .endObject().bytes();
StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class, StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class,
() -> mapper.parse("test", "type", "1", bytes)); () -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals("mapping set to strict, dynamic introduction of [bar] within [type] is not allowed", exception.getMessage()); assertEquals("mapping set to strict, dynamic introduction of [bar] within [type] is not allowed", exception.getMessage());
} }
@ -536,7 +536,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject() .startObject()
.field("bar", (String) null) .field("bar", (String) null)
.endObject().bytes(); .endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(0, doc.rootDoc().getFields("bar").length); assertEquals(0, doc.rootDoc().getFields("bar").length);
} }
@ -551,7 +551,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.field("bar", (String) null) .field("bar", (String) null)
.endObject().bytes(); .endObject().bytes();
StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class, StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class,
() -> mapper.parse("test", "type", "1", bytes)); () -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals("mapping set to strict, dynamic introduction of [bar] within [type] is not allowed", exception.getMessage()); assertEquals("mapping set to strict, dynamic introduction of [bar] within [type] is not allowed", exception.getMessage());
} }
@ -565,7 +565,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
BytesReference bytes = XContentFactory.jsonBuilder() BytesReference bytes = XContentFactory.jsonBuilder()
.startObject().field("foo", (Long) null) .startObject().field("foo", (Long) null)
.endObject().bytes(); .endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(0, doc.rootDoc().getFields("foo").length); assertEquals(0, doc.rootDoc().getFields("foo").length);
} }
@ -580,7 +580,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(0) .value(0)
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(4, doc.rootDoc().getFields("foo.bar.baz").length); assertEquals(4, doc.rootDoc().getFields("foo.bar.baz").length);
Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo"); Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo");
assertNotNull(fooMapper); assertNotNull(fooMapper);
@ -607,7 +607,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(0) .value(0)
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(4, doc.rootDoc().getFields("foo.bar.baz").length); assertEquals(4, doc.rootDoc().getFields("foo.bar.baz").length);
Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo"); Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo");
assertNotNull(fooMapper); assertNotNull(fooMapper);
@ -633,7 +633,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(0) .value(0)
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(4, doc.rootDoc().getFields("foo.bar.baz").length); assertEquals(4, doc.rootDoc().getFields("foo.bar.baz").length);
Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo"); Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo");
assertNotNull(fooMapper); assertNotNull(fooMapper);
@ -659,7 +659,8 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(0) .value(0)
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
MapperParsingException exception = expectThrows(MapperParsingException.class, () -> mapper.parse("test", "type", "1", bytes)); MapperParsingException exception = expectThrows(MapperParsingException.class,
() -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals("Could not dynamically add mapping for field [foo.bar.baz]. " assertEquals("Could not dynamically add mapping for field [foo.bar.baz]. "
+ "Existing mapping for [foo] must be of type object but found [long].", exception.getMessage()); + "Existing mapping for [foo] must be of type object but found [long].", exception.getMessage());
} }
@ -675,7 +676,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(0) .value(0)
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(0, doc.rootDoc().getFields("foo.bar.baz").length); assertEquals(0, doc.rootDoc().getFields("foo.bar.baz").length);
} }
@ -691,7 +692,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.value(1) .value(1)
.endArray().endObject().bytes(); .endArray().endObject().bytes();
StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class, StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class,
() -> mapper.parse("test", "type", "1", bytes)); () -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals("mapping set to strict, dynamic introduction of [foo] within [type] is not allowed", exception.getMessage()); assertEquals("mapping set to strict, dynamic introduction of [foo] within [type] is not allowed", exception.getMessage());
} }
@ -704,7 +705,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
BytesReference bytes = XContentFactory.jsonBuilder() BytesReference bytes = XContentFactory.jsonBuilder()
.startObject().field("foo.bar.baz", 0) .startObject().field("foo.bar.baz", 0)
.endObject().bytes(); .endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(2, doc.rootDoc().getFields("foo.bar.baz").length); assertEquals(2, doc.rootDoc().getFields("foo.bar.baz").length);
Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo"); Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo");
assertNotNull(fooMapper); assertNotNull(fooMapper);
@ -729,7 +730,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
BytesReference bytes = XContentFactory.jsonBuilder() BytesReference bytes = XContentFactory.jsonBuilder()
.startObject().field("foo.bar.baz", 0) .startObject().field("foo.bar.baz", 0)
.endObject().bytes(); .endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(2, doc.rootDoc().getFields("foo.bar.baz").length); assertEquals(2, doc.rootDoc().getFields("foo.bar.baz").length);
Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo"); Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo");
assertNotNull(fooMapper); assertNotNull(fooMapper);
@ -753,7 +754,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
BytesReference bytes = XContentFactory.jsonBuilder() BytesReference bytes = XContentFactory.jsonBuilder()
.startObject().field("foo.bar.baz", 0) .startObject().field("foo.bar.baz", 0)
.endObject().bytes(); .endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(2, doc.rootDoc().getFields("foo.bar.baz").length); assertEquals(2, doc.rootDoc().getFields("foo.bar.baz").length);
Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo"); Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo");
assertNotNull(fooMapper); assertNotNull(fooMapper);
@ -777,7 +778,8 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
BytesReference bytes = XContentFactory.jsonBuilder() BytesReference bytes = XContentFactory.jsonBuilder()
.startObject().field("foo.bar.baz", 0) .startObject().field("foo.bar.baz", 0)
.endObject().bytes(); .endObject().bytes();
MapperParsingException exception = expectThrows(MapperParsingException.class, () -> mapper.parse("test", "type", "1", bytes)); MapperParsingException exception = expectThrows(MapperParsingException.class,
() -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals("Could not dynamically add mapping for field [foo.bar.baz]. " assertEquals("Could not dynamically add mapping for field [foo.bar.baz]. "
+ "Existing mapping for [foo] must be of type object but found [long].", exception.getMessage()); + "Existing mapping for [foo] must be of type object but found [long].", exception.getMessage());
} }
@ -791,7 +793,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
BytesReference bytes = XContentFactory.jsonBuilder() BytesReference bytes = XContentFactory.jsonBuilder()
.startObject().field("foo.bar.baz", 0) .startObject().field("foo.bar.baz", 0)
.endObject().bytes(); .endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(0, doc.rootDoc().getFields("foo.bar.baz").length); assertEquals(0, doc.rootDoc().getFields("foo.bar.baz").length);
} }
@ -805,7 +807,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject().field("foo.bar.baz", 0) .startObject().field("foo.bar.baz", 0)
.endObject().bytes(); .endObject().bytes();
StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class, StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class,
() -> mapper.parse("test", "type", "1", bytes)); () -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals("mapping set to strict, dynamic introduction of [foo] within [type] is not allowed", exception.getMessage()); assertEquals("mapping set to strict, dynamic introduction of [foo] within [type] is not allowed", exception.getMessage());
} }
@ -819,7 +821,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject().startObject("foo.bar.baz") .startObject().startObject("foo.bar.baz")
.field("a", 0) .field("a", 0)
.endObject().endObject().bytes(); .endObject().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(2, doc.rootDoc().getFields("foo.bar.baz.a").length); assertEquals(2, doc.rootDoc().getFields("foo.bar.baz.a").length);
Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo"); Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo");
assertNotNull(fooMapper); assertNotNull(fooMapper);
@ -848,7 +850,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject().startObject("foo.bar.baz") .startObject().startObject("foo.bar.baz")
.field("a", 0) .field("a", 0)
.endObject().endObject().bytes(); .endObject().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(2, doc.rootDoc().getFields("foo.bar.baz.a").length); assertEquals(2, doc.rootDoc().getFields("foo.bar.baz.a").length);
Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo"); Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo");
assertNotNull(fooMapper); assertNotNull(fooMapper);
@ -872,7 +874,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
BytesReference bytes = XContentFactory.jsonBuilder().startObject().startObject("foo.bar.baz").field("a", 0).endObject().endObject() BytesReference bytes = XContentFactory.jsonBuilder().startObject().startObject("foo.bar.baz").field("a", 0).endObject().endObject()
.bytes(); .bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(2, doc.rootDoc().getFields("foo.bar.baz.a").length); assertEquals(2, doc.rootDoc().getFields("foo.bar.baz.a").length);
Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo"); Mapper fooMapper = doc.dynamicMappingsUpdate().root().getMapper("foo");
assertNotNull(fooMapper); assertNotNull(fooMapper);
@ -898,7 +900,9 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
BytesReference bytes = XContentFactory.jsonBuilder().startObject().startObject("foo.bar.baz").field("a", 0).endObject().endObject() BytesReference bytes = XContentFactory.jsonBuilder().startObject().startObject("foo.bar.baz").field("a", 0).endObject().endObject()
.bytes(); .bytes();
MapperParsingException exception = expectThrows(MapperParsingException.class, () -> mapper.parse("test", "type", "1", bytes)); MapperParsingException exception = expectThrows(MapperParsingException.class,
() -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals("Could not dynamically add mapping for field [foo.bar.baz]. " assertEquals("Could not dynamically add mapping for field [foo.bar.baz]. "
+ "Existing mapping for [foo] must be of type object but found [long].", exception.getMessage()); + "Existing mapping for [foo] must be of type object but found [long].", exception.getMessage());
} }
@ -913,7 +917,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.startObject().startObject("foo.bar.baz") .startObject().startObject("foo.bar.baz")
.field("a", 0) .field("a", 0)
.endObject().endObject().bytes(); .endObject().endObject().bytes();
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
assertEquals(0, doc.rootDoc().getFields("foo.bar.baz.a").length); assertEquals(0, doc.rootDoc().getFields("foo.bar.baz.a").length);
} }
@ -928,7 +932,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.field("a", 0) .field("a", 0)
.endObject().endObject().bytes(); .endObject().endObject().bytes();
StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class, StrictDynamicMappingException exception = expectThrows(StrictDynamicMappingException.class,
() -> mapper.parse("test", "type", "1", bytes)); () -> mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
assertEquals("mapping set to strict, dynamic introduction of [foo] within [type] is not allowed", exception.getMessage()); assertEquals("mapping set to strict, dynamic introduction of [foo] within [type] is not allowed", exception.getMessage());
} }
@ -939,12 +943,11 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
BytesReference bytes = XContentFactory.jsonBuilder().startObject().field("_ttl", 0).endObject().bytes(); BytesReference bytes = XContentFactory.jsonBuilder().startObject().field("_ttl", 0).endObject().bytes();
MapperParsingException e = expectThrows(MapperParsingException.class, () -> MapperParsingException e = expectThrows(MapperParsingException.class, () ->
mapper.parse("test", "type", "1", bytes) mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON)));
);
assertTrue(e.getMessage(), e.getMessage().contains("cannot be added inside a document")); assertTrue(e.getMessage(), e.getMessage().contains("cannot be added inside a document"));
BytesReference bytes2 = XContentFactory.jsonBuilder().startObject().field("foo._ttl", 0).endObject().bytes(); BytesReference bytes2 = XContentFactory.jsonBuilder().startObject().field("foo._ttl", 0).endObject().bytes();
mapper.parse("test", "type", "1", bytes2); // parses without error mapper.parse(SourceToParse.source("test", "type", "1", bytes2, XContentType.JSON)); // parses without error
} }
public void testSimpleMapper() throws Exception { public void testSimpleMapper() throws Exception {
@ -955,10 +958,10 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
indexService.mapperService()).build(indexService.mapperService()); indexService.mapperService()).build(indexService.mapperService());
BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/simple/test1.json")); BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/simple/test1.json"));
Document doc = docMapper.parse("test", "person", "1", json).rootDoc(); Document doc = docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
assertThat(doc.get(docMapper.mappers().getMapper("name.first").fieldType().name()), equalTo("shay")); assertThat(doc.get(docMapper.mappers().getMapper("name.first").fieldType().name()), equalTo("shay"));
doc = docMapper.parse("test", "person", "1", json).rootDoc(); doc = docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
} }
public void testParseToJsonAndParse() throws Exception { public void testParseToJsonAndParse() throws Exception {
@ -969,7 +972,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
// reparse it // reparse it
DocumentMapper builtDocMapper = parser.parse("person", new CompressedXContent(builtMapping)); DocumentMapper builtDocMapper = parser.parse("person", new CompressedXContent(builtMapping));
BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/simple/test1.json")); BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/simple/test1.json"));
Document doc = builtDocMapper.parse("test", "person", "1", json).rootDoc(); Document doc = builtDocMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
assertThat(doc.get(docMapper.uidMapper().fieldType().name()), equalTo(Uid.createUid("person", "1"))); assertThat(doc.get(docMapper.uidMapper().fieldType().name()), equalTo(Uid.createUid("person", "1")));
assertThat(doc.get(docMapper.mappers().getMapper("name.first").fieldType().name()), equalTo("shay")); assertThat(doc.get(docMapper.mappers().getMapper("name.first").fieldType().name()), equalTo("shay"));
} }
@ -981,7 +984,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
assertThat((String) docMapper.meta().get("param1"), equalTo("value1")); assertThat((String) docMapper.meta().get("param1"), equalTo("value1"));
BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/simple/test1.json")); BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/simple/test1.json"));
Document doc = docMapper.parse("test", "person", "1", json).rootDoc(); Document doc = docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
assertThat(doc.get(docMapper.uidMapper().fieldType().name()), equalTo(Uid.createUid("person", "1"))); assertThat(doc.get(docMapper.uidMapper().fieldType().name()), equalTo(Uid.createUid("person", "1")));
assertThat(doc.get(docMapper.mappers().getMapper("name.first").fieldType().name()), equalTo("shay")); assertThat(doc.get(docMapper.mappers().getMapper("name.first").fieldType().name()), equalTo("shay"));
} }
@ -990,7 +993,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
String mapping = copyToStringFromClasspath("/org/elasticsearch/index/mapper/simple/test-mapping.json"); String mapping = copyToStringFromClasspath("/org/elasticsearch/index/mapper/simple/test-mapping.json");
DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("person", new CompressedXContent(mapping)); DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("person", new CompressedXContent(mapping));
BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/simple/test1-notype-noid.json")); BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/simple/test1-notype-noid.json"));
Document doc = docMapper.parse("test", "person", "1", json).rootDoc(); Document doc = docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
assertThat(doc.get(docMapper.uidMapper().fieldType().name()), equalTo(Uid.createUid("person", "1"))); assertThat(doc.get(docMapper.uidMapper().fieldType().name()), equalTo(Uid.createUid("person", "1")));
assertThat(doc.get(docMapper.mappers().getMapper("name.first").fieldType().name()), equalTo("shay")); assertThat(doc.get(docMapper.mappers().getMapper("name.first").fieldType().name()), equalTo("shay"));
} }
@ -1016,7 +1019,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
BytesReference json = new BytesArray("".getBytes(StandardCharsets.UTF_8)); BytesReference json = new BytesArray("".getBytes(StandardCharsets.UTF_8));
try { try {
docMapper.parse("test", "person", "1", json).rootDoc(); docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
fail("this point is never reached"); fail("this point is never reached");
} catch (MapperParsingException e) { } catch (MapperParsingException e) {
assertThat(e.getMessage(), equalTo("failed to parse, document is empty")); assertThat(e.getMessage(), equalTo("failed to parse, document is empty"));
@ -1028,13 +1031,14 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("test1", "value1") .field("test1", "value1")
.field("test2", "value2") .field("test2", "value2")
.startObject("inner").field("inner_field", "inner_value").endObject() .startObject("inner").field("inner_field", "inner_value").endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("test1"), equalTo("value1")); assertThat(doc.rootDoc().get("test1"), equalTo("value1"));
assertThat(doc.rootDoc().get("test2"), equalTo("value2")); assertThat(doc.rootDoc().get("test2"), equalTo("value2"));
@ -1046,13 +1050,14 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject().startObject("type") .startObject().startObject("type")
.field("test1", "value1") .field("test1", "value1")
.field("test2", "value2") .field("test2", "value2")
.startObject("inner").field("inner_field", "inner_value").endObject() .startObject("inner").field("inner_field", "inner_value").endObject()
.endObject().endObject() .endObject().endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("type.test1"), equalTo("value1")); assertThat(doc.rootDoc().get("type.test1"), equalTo("value1"));
assertThat(doc.rootDoc().get("type.test2"), equalTo("value2")); assertThat(doc.rootDoc().get("type.test2"), equalTo("value2"));
@ -1064,14 +1069,15 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("type", "value_type") .field("type", "value_type")
.field("test1", "value1") .field("test1", "value1")
.field("test2", "value2") .field("test2", "value2")
.startObject("inner").field("inner_field", "inner_value").endObject() .startObject("inner").field("inner_field", "inner_value").endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("type"), equalTo("value_type")); assertThat(doc.rootDoc().get("type"), equalTo("value_type"));
assertThat(doc.rootDoc().get("test1"), equalTo("value1")); assertThat(doc.rootDoc().get("test1"), equalTo("value1"));
@ -1084,14 +1090,15 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject().startObject("type") .startObject().startObject("type")
.field("type", "value_type") .field("type", "value_type")
.field("test1", "value1") .field("test1", "value1")
.field("test2", "value2") .field("test2", "value2")
.startObject("inner").field("inner_field", "inner_value").endObject() .startObject("inner").field("inner_field", "inner_value").endObject()
.endObject().endObject() .endObject().endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("type.type"), equalTo("value_type")); assertThat(doc.rootDoc().get("type.type"), equalTo("value_type"));
assertThat(doc.rootDoc().get("type.test1"), equalTo("value1")); assertThat(doc.rootDoc().get("type.test1"), equalTo("value1"));
@ -1104,14 +1111,15 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("type").field("type_field", "type_value").endObject() .startObject("type").field("type_field", "type_value").endObject()
.field("test1", "value1") .field("test1", "value1")
.field("test2", "value2") .field("test2", "value2")
.startObject("inner").field("inner_field", "inner_value").endObject() .startObject("inner").field("inner_field", "inner_value").endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
// in this case, we analyze the type object as the actual document, and ignore the other same level fields // in this case, we analyze the type object as the actual document, and ignore the other same level fields
assertThat(doc.rootDoc().get("type.type_field"), equalTo("type_value")); assertThat(doc.rootDoc().get("type.type_field"), equalTo("type_value"));
@ -1124,14 +1132,15 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject().startObject("type") .startObject().startObject("type")
.startObject("type").field("type_field", "type_value").endObject() .startObject("type").field("type_field", "type_value").endObject()
.field("test1", "value1") .field("test1", "value1")
.field("test2", "value2") .field("test2", "value2")
.startObject("inner").field("inner_field", "inner_value").endObject() .startObject("inner").field("inner_field", "inner_value").endObject()
.endObject().endObject() .endObject().endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("type.type.type_field"), equalTo("type_value")); assertThat(doc.rootDoc().get("type.type.type_field"), equalTo("type_value"));
assertThat(doc.rootDoc().get("type.test1"), equalTo("value1")); assertThat(doc.rootDoc().get("type.test1"), equalTo("value1"));
@ -1144,14 +1153,15 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject().startObject("type") .startObject().startObject("type")
.field("test1", "value1") .field("test1", "value1")
.field("test2", "value2") .field("test2", "value2")
.field("type", "value_type") .field("type", "value_type")
.startObject("inner").field("inner_field", "inner_value").endObject() .startObject("inner").field("inner_field", "inner_value").endObject()
.endObject().endObject() .endObject().endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("type.type"), equalTo("value_type")); assertThat(doc.rootDoc().get("type.type"), equalTo("value_type"));
assertThat(doc.rootDoc().get("type.test1"), equalTo("value1")); assertThat(doc.rootDoc().get("type.test1"), equalTo("value1"));
@ -1164,14 +1174,15 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject().startObject("type") .startObject().startObject("type")
.field("test1", "value1") .field("test1", "value1")
.field("type", "value_type") .field("type", "value_type")
.field("test2", "value2") .field("test2", "value2")
.startObject("inner").field("inner_field", "inner_value").endObject() .startObject("inner").field("inner_field", "inner_value").endObject()
.endObject().endObject() .endObject().endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("type.type"), equalTo("value_type")); assertThat(doc.rootDoc().get("type.type"), equalTo("value_type"));
assertThat(doc.rootDoc().get("type.test1"), equalTo("value1")); assertThat(doc.rootDoc().get("type.test1"), equalTo("value1"));
@ -1184,14 +1195,15 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("test1", "value1") .field("test1", "value1")
.startObject("type").field("type_field", "type_value").endObject() .startObject("type").field("type_field", "type_value").endObject()
.field("test2", "value2") .field("test2", "value2")
.startObject("inner").field("inner_field", "inner_value").endObject() .startObject("inner").field("inner_field", "inner_value").endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
// when the type is not the first one, we don't confuse it... // when the type is not the first one, we don't confuse it...
assertThat(doc.rootDoc().get("type.type_field"), equalTo("type_value")); assertThat(doc.rootDoc().get("type.type_field"), equalTo("type_value"));
@ -1205,14 +1217,15 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(defaultMapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject().startObject("type") .startObject().startObject("type")
.field("test1", "value1") .field("test1", "value1")
.startObject("type").field("type_field", "type_value").endObject() .startObject("type").field("type_field", "type_value").endObject()
.field("test2", "value2") .field("test2", "value2")
.startObject("inner").field("inner_field", "inner_value").endObject() .startObject("inner").field("inner_field", "inner_value").endObject()
.endObject().endObject() .endObject().endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("type.type.type_field"), equalTo("type_value")); assertThat(doc.rootDoc().get("type.type.type_field"), equalTo("type_value"));
assertThat(doc.rootDoc().get("type.test1"), equalTo("value1")); assertThat(doc.rootDoc().get("type.test1"), equalTo("value1"));
@ -1235,7 +1248,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
// Even though we matched the dynamic format, we do not match on numbers, // Even though we matched the dynamic format, we do not match on numbers,
// which are too likely to be false positives // which are too likely to be false positives
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
Mapping update = doc.dynamicMappingsUpdate(); Mapping update = doc.dynamicMappingsUpdate();
assertNotNull(update); assertNotNull(update);
Mapper dateMapper = update.root().getMapper("foo"); Mapper dateMapper = update.root().getMapper("foo");
@ -1257,7 +1270,7 @@ public class DocumentParserTests extends ESSingleNodeTestCase {
.endObject().bytes(); .endObject().bytes();
// We should have generated a date field // We should have generated a date field
ParsedDocument doc = mapper.parse("test", "type", "1", bytes); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", bytes, XContentType.JSON));
Mapping update = doc.dynamicMappingsUpdate(); Mapping update = doc.dynamicMappingsUpdate();
assertNotNull(update); assertNotNull(update);
Mapper dateMapper = update.root().getMapper("foo"); Mapper dateMapper = update.root().getMapper("foo");

View File

@ -48,7 +48,7 @@ public class DoubleIndexingDocTests extends ESSingleNodeTestCase {
DocumentMapper mapper = index.mapperService().documentMapper("type"); DocumentMapper mapper = index.mapperService().documentMapper("type");
QueryShardContext context = index.newQueryShardContext(0, null, () -> 0L); QueryShardContext context = index.newQueryShardContext(0, null, () -> 0L);
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field1", "value1") .field("field1", "value1")
.field("field2", 1) .field("field2", 1)
@ -56,7 +56,8 @@ public class DoubleIndexingDocTests extends ESSingleNodeTestCase {
.field("field4", "2010-01-01") .field("field4", "2010-01-01")
.startArray("field5").value(1).value(2).value(3).endArray() .startArray("field5").value(1).value(2).value(3).endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertNotNull(doc.dynamicMappingsUpdate()); assertNotNull(doc.dynamicMappingsUpdate());
client().admin().indices().preparePutMapping("test").setType("type") client().admin().indices().preparePutMapping("test").setType("type")
.setSource(doc.dynamicMappingsUpdate().toString(), XContentType.JSON).get(); .setSource(doc.dynamicMappingsUpdate().toString(), XContentType.JSON).get();

View File

@ -58,12 +58,13 @@ public class DynamicMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", jsonBuilder()
.startObject() .startObject()
.field("field1", "value1") .field("field1", "value1")
.field("field2", "value2") .field("field2", "value2")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("field1"), equalTo("value1")); assertThat(doc.rootDoc().get("field1"), equalTo("value1"));
assertThat(doc.rootDoc().get("field2"), equalTo("value2")); assertThat(doc.rootDoc().get("field2"), equalTo("value2"));
@ -79,12 +80,13 @@ public class DynamicMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", jsonBuilder()
.startObject() .startObject()
.field("field1", "value1") .field("field1", "value1")
.field("field2", "value2") .field("field2", "value2")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("field1"), equalTo("value1")); assertThat(doc.rootDoc().get("field1"), equalTo("value1"));
assertThat(doc.rootDoc().get("field2"), nullValue()); assertThat(doc.rootDoc().get("field2"), nullValue());
@ -101,20 +103,22 @@ public class DynamicMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
StrictDynamicMappingException e = expectThrows(StrictDynamicMappingException.class, () -> defaultMapper.parse("test", "type", "1", jsonBuilder() StrictDynamicMappingException e = expectThrows(StrictDynamicMappingException.class, () -> defaultMapper.parse(SourceToParse.source("test", "type", "1", jsonBuilder()
.startObject() .startObject()
.field("field1", "value1") .field("field1", "value1")
.field("field2", "value2") .field("field2", "value2")
.endObject() .endObject()
.bytes())); .bytes(),
XContentType.JSON)));
assertThat(e.getMessage(), equalTo("mapping set to strict, dynamic introduction of [field2] within [type] is not allowed")); assertThat(e.getMessage(), equalTo("mapping set to strict, dynamic introduction of [field2] within [type] is not allowed"));
e = expectThrows(StrictDynamicMappingException.class, () -> defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() e = expectThrows(StrictDynamicMappingException.class, () -> defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field1", "value1") .field("field1", "value1")
.field("field2", (String) null) .field("field2", (String) null)
.endObject() .endObject()
.bytes())); .bytes(),
XContentType.JSON)));
assertThat(e.getMessage(), equalTo("mapping set to strict, dynamic introduction of [field2] within [type] is not allowed")); assertThat(e.getMessage(), equalTo("mapping set to strict, dynamic introduction of [field2] within [type] is not allowed"));
} }
@ -130,13 +134,14 @@ public class DynamicMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", jsonBuilder()
.startObject().startObject("obj1") .startObject().startObject("obj1")
.field("field1", "value1") .field("field1", "value1")
.field("field2", "value2") .field("field2", "value2")
.endObject() .endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("obj1.field1"), equalTo("value1")); assertThat(doc.rootDoc().get("obj1.field1"), equalTo("value1"));
assertThat(doc.rootDoc().get("obj1.field2"), nullValue()); assertThat(doc.rootDoc().get("obj1.field2"), nullValue());
@ -155,13 +160,14 @@ public class DynamicMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
StrictDynamicMappingException e = expectThrows(StrictDynamicMappingException.class, () -> StrictDynamicMappingException e = expectThrows(StrictDynamicMappingException.class, () ->
defaultMapper.parse("test", "type", "1", jsonBuilder() defaultMapper.parse(SourceToParse.source("test", "type", "1", jsonBuilder()
.startObject().startObject("obj1") .startObject().startObject("obj1")
.field("field1", "value1") .field("field1", "value1")
.field("field2", "value2") .field("field2", "value2")
.endObject() .endObject()
.endObject() .endObject()
.bytes())); .bytes(),
XContentType.JSON)));
assertThat(e.getMessage(), equalTo("mapping set to strict, dynamic introduction of [field2] within [obj1] is not allowed")); assertThat(e.getMessage(), equalTo("mapping set to strict, dynamic introduction of [field2] within [obj1] is not allowed"));
} }
@ -585,7 +591,8 @@ public class DynamicMappingTests extends ESSingleNodeTestCase {
.field("baz", (double) 3.2f) // double that can be accurately represented as a float .field("baz", (double) 3.2f) // double that can be accurately represented as a float
.field("quux", "3.2") // float detected through numeric detection .field("quux", "3.2") // float detected through numeric detection
.endObject().bytes(); .endObject().bytes();
ParsedDocument parsedDocument = mapper.parse("index", "type", "id", source); ParsedDocument parsedDocument = mapper.parse(SourceToParse.source("index", "type", "id", source,
XContentType.JSON));
Mapping update = parsedDocument.dynamicMappingsUpdate(); Mapping update = parsedDocument.dynamicMappingsUpdate();
assertNotNull(update); assertNotNull(update);
assertThat(((FieldMapper) update.root().getMapper("foo")).fieldType().typeName(), equalTo("float")); assertThat(((FieldMapper) update.root().getMapper("foo")).fieldType().typeName(), equalTo("float"));
@ -603,12 +610,13 @@ public class DynamicMappingTests extends ESSingleNodeTestCase {
client().admin().indices().preparePutMapping("test").setType("type").setSource(mapping, XContentType.JSON).get(); client().admin().indices().preparePutMapping("test").setType("type").setSource(mapping, XContentType.JSON).get();
DocumentMapper defaultMapper = index.mapperService().documentMapper("type"); DocumentMapper defaultMapper = index.mapperService().documentMapper("type");
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("s_long", "100") .field("s_long", "100")
.field("s_double", "100.0") .field("s_double", "100.0")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertNotNull(doc.dynamicMappingsUpdate()); assertNotNull(doc.dynamicMappingsUpdate());
client().admin().indices().preparePutMapping("test").setType("type") client().admin().indices().preparePutMapping("test").setType("type")
.setSource(doc.dynamicMappingsUpdate().toString(), XContentType.JSON).get(); .setSource(doc.dynamicMappingsUpdate().toString(), XContentType.JSON).get();
@ -629,12 +637,13 @@ public class DynamicMappingTests extends ESSingleNodeTestCase {
client().admin().indices().preparePutMapping("test").setType("type").setSource(mapping, XContentType.JSON).get(); client().admin().indices().preparePutMapping("test").setType("type").setSource(mapping, XContentType.JSON).get();
DocumentMapper defaultMapper = index.mapperService().documentMapper("type"); DocumentMapper defaultMapper = index.mapperService().documentMapper("type");
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("s_long", "100") .field("s_long", "100")
.field("s_double", "100.0") .field("s_double", "100.0")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertNotNull(doc.dynamicMappingsUpdate()); assertNotNull(doc.dynamicMappingsUpdate());
assertAcked(client().admin().indices().preparePutMapping("test").setType("type") assertAcked(client().admin().indices().preparePutMapping("test").setType("type")
.setSource(doc.dynamicMappingsUpdate().toString(), XContentType.JSON).get()); .setSource(doc.dynamicMappingsUpdate().toString(), XContentType.JSON).get());
@ -677,13 +686,14 @@ public class DynamicMappingTests extends ESSingleNodeTestCase {
client().admin().indices().preparePutMapping("test").setType("type").setSource(mapping, XContentType.JSON).get(); client().admin().indices().preparePutMapping("test").setType("type").setSource(mapping, XContentType.JSON).get();
DocumentMapper defaultMapper = index.mapperService().documentMapper("type"); DocumentMapper defaultMapper = index.mapperService().documentMapper("type");
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("date1", "2016-11-20") .field("date1", "2016-11-20")
.field("date2", "2016-11-20") .field("date2", "2016-11-20")
.field("date3", "2016-11-20") .field("date3", "2016-11-20")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertNotNull(doc.dynamicMappingsUpdate()); assertNotNull(doc.dynamicMappingsUpdate());
assertAcked(client().admin().indices().preparePutMapping("test").setType("type") assertAcked(client().admin().indices().preparePutMapping("test").setType("type")
.setSource(doc.dynamicMappingsUpdate().toString(), XContentType.JSON).get()); .setSource(doc.dynamicMappingsUpdate().toString(), XContentType.JSON).get());

View File

@ -51,7 +51,8 @@ public class DynamicTemplatesTests extends ESSingleNodeTestCase {
DocumentMapper docMapper = index.mapperService().documentMapper("person"); DocumentMapper docMapper = index.mapperService().documentMapper("person");
builder = JsonXContent.contentBuilder(); builder = JsonXContent.contentBuilder();
builder.startObject().field("s", "hello").field("l", 1).endObject(); builder.startObject().field("s", "hello").field("l", 1).endObject();
ParsedDocument parsedDoc = docMapper.parse("test", "person", "1", builder.bytes()); ParsedDocument parsedDoc = docMapper.parse(SourceToParse.source("test", "person", "1", builder.bytes(),
XContentType.JSON));
client().admin().indices().preparePutMapping("test").setType("person") client().admin().indices().preparePutMapping("test").setType("person")
.setSource(parsedDoc.dynamicMappingsUpdate().toString(), XContentType.JSON).get(); .setSource(parsedDoc.dynamicMappingsUpdate().toString(), XContentType.JSON).get();
@ -73,7 +74,8 @@ public class DynamicTemplatesTests extends ESSingleNodeTestCase {
client().admin().indices().preparePutMapping("test").setType("person").setSource(mapping, XContentType.JSON).get(); client().admin().indices().preparePutMapping("test").setType("person").setSource(mapping, XContentType.JSON).get();
DocumentMapper docMapper = index.mapperService().documentMapper("person"); DocumentMapper docMapper = index.mapperService().documentMapper("person");
byte[] json = copyToBytesFromClasspath("/org/elasticsearch/index/mapper/dynamictemplate/simple/test-data.json"); byte[] json = copyToBytesFromClasspath("/org/elasticsearch/index/mapper/dynamictemplate/simple/test-data.json");
ParsedDocument parsedDoc = docMapper.parse("test", "person", "1", new BytesArray(json)); ParsedDocument parsedDoc = docMapper.parse(SourceToParse.source("test", "person", "1", new BytesArray(json),
XContentType.JSON));
client().admin().indices().preparePutMapping("test").setType("person") client().admin().indices().preparePutMapping("test").setType("person")
.setSource(parsedDoc.dynamicMappingsUpdate().toString(), XContentType.JSON).get(); .setSource(parsedDoc.dynamicMappingsUpdate().toString(), XContentType.JSON).get();
docMapper = index.mapperService().documentMapper("person"); docMapper = index.mapperService().documentMapper("person");
@ -131,7 +133,8 @@ public class DynamicTemplatesTests extends ESSingleNodeTestCase {
client().admin().indices().preparePutMapping("test").setType("person").setSource(mapping, XContentType.JSON).get(); client().admin().indices().preparePutMapping("test").setType("person").setSource(mapping, XContentType.JSON).get();
DocumentMapper docMapper = index.mapperService().documentMapper("person"); DocumentMapper docMapper = index.mapperService().documentMapper("person");
byte[] json = copyToBytesFromClasspath("/org/elasticsearch/index/mapper/dynamictemplate/simple/test-data.json"); byte[] json = copyToBytesFromClasspath("/org/elasticsearch/index/mapper/dynamictemplate/simple/test-data.json");
ParsedDocument parsedDoc = docMapper.parse("test", "person", "1", new BytesArray(json)); ParsedDocument parsedDoc = docMapper.parse(SourceToParse.source("test", "person", "1", new BytesArray(json),
XContentType.JSON));
client().admin().indices().preparePutMapping("test").setType("person") client().admin().indices().preparePutMapping("test").setType("person")
.setSource(parsedDoc.dynamicMappingsUpdate().toString(), XContentType.JSON).get(); .setSource(parsedDoc.dynamicMappingsUpdate().toString(), XContentType.JSON).get();
docMapper = index.mapperService().documentMapper("person"); docMapper = index.mapperService().documentMapper("person");

View File

@ -27,6 +27,7 @@ import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.geo.GeoPoint; import org.elasticsearch.common.geo.GeoPoint;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.query.QueryShardContext; import org.elasticsearch.index.query.QueryShardContext;
import org.elasticsearch.indices.mapper.MapperRegistry; import org.elasticsearch.indices.mapper.MapperRegistry;
@ -76,11 +77,12 @@ public class ExternalFieldMapperTests extends ESSingleNodeTestCase {
.endObject().endObject().string() .endObject().endObject().string()
)); ));
ParsedDocument doc = documentMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = documentMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("field.bool"), notNullValue()); assertThat(doc.rootDoc().getField("field.bool"), notNullValue());
assertThat(doc.rootDoc().getField("field.bool").stringValue(), is("T")); assertThat(doc.rootDoc().getField("field.bool").stringValue(), is("T"));
@ -136,11 +138,12 @@ public class ExternalFieldMapperTests extends ESSingleNodeTestCase {
.endObject().endObject().endObject() .endObject().endObject().endObject()
.string())); .string()));
ParsedDocument doc = documentMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = documentMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("field.bool"), notNullValue()); assertThat(doc.rootDoc().getField("field.bool"), notNullValue());
assertThat(doc.rootDoc().getField("field.bool").stringValue(), is("T")); assertThat(doc.rootDoc().getField("field.bool").stringValue(), is("T"));
@ -204,11 +207,12 @@ public class ExternalFieldMapperTests extends ESSingleNodeTestCase {
.endObject().endObject().endObject() .endObject().endObject().endObject()
.string())); .string()));
ParsedDocument doc = documentMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = documentMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("field.bool"), notNullValue()); assertThat(doc.rootDoc().getField("field.bool"), notNullValue());
assertThat(doc.rootDoc().getField("field.bool").stringValue(), is("T")); assertThat(doc.rootDoc().getField("field.bool").stringValue(), is("T"));

View File

@ -26,6 +26,7 @@ import org.elasticsearch.common.bytes.BytesArray;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.query.QueryShardContext; import org.elasticsearch.index.query.QueryShardContext;
import org.elasticsearch.indices.IndicesModule; import org.elasticsearch.indices.IndicesModule;
@ -88,14 +89,15 @@ public class FieldNamesFieldMapperTests extends ESSingleNodeTestCase {
String mapping = XContentFactory.jsonBuilder().startObject().startObject("type").endObject().endObject().string(); String mapping = XContentFactory.jsonBuilder().startObject().startObject("type").endObject().endObject().string();
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("a", "100") .field("a", "100")
.startObject("b") .startObject("b")
.field("c", 42) .field("c", 42)
.endObject() .endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertFieldNames(set("a", "a.keyword", "b", "b.c", "_uid", "_type", "_version", "_seq_no", "_primary_term", "_source"), doc); assertFieldNames(set("a", "a.keyword", "b", "b.c", "_uid", "_type", "_version", "_seq_no", "_primary_term", "_source"), doc);
} }
@ -108,11 +110,12 @@ public class FieldNamesFieldMapperTests extends ESSingleNodeTestCase {
FieldNamesFieldMapper fieldNamesMapper = docMapper.metadataMapper(FieldNamesFieldMapper.class); FieldNamesFieldMapper fieldNamesMapper = docMapper.metadataMapper(FieldNamesFieldMapper.class);
assertTrue(fieldNamesMapper.fieldType().isEnabled()); assertTrue(fieldNamesMapper.fieldType().isEnabled());
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertFieldNames(set("field", "field.keyword", "_uid", "_type", "_version", "_seq_no", "_primary_term", "_source"), doc); assertFieldNames(set("field", "field.keyword", "_uid", "_type", "_version", "_seq_no", "_primary_term", "_source"), doc);
} }
@ -125,11 +128,12 @@ public class FieldNamesFieldMapperTests extends ESSingleNodeTestCase {
FieldNamesFieldMapper fieldNamesMapper = docMapper.metadataMapper(FieldNamesFieldMapper.class); FieldNamesFieldMapper fieldNamesMapper = docMapper.metadataMapper(FieldNamesFieldMapper.class);
assertFalse(fieldNamesMapper.fieldType().isEnabled()); assertFalse(fieldNamesMapper.fieldType().isEnabled());
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertNull(doc.rootDoc().get("_field_names")); assertNull(doc.rootDoc().get("_field_names"));
} }
@ -244,7 +248,8 @@ public class FieldNamesFieldMapperTests extends ESSingleNodeTestCase {
queryShardContext); queryShardContext);
String mapping = XContentFactory.jsonBuilder().startObject().startObject("type").endObject().endObject().string(); String mapping = XContentFactory.jsonBuilder().startObject().startObject("type").endObject().endObject().string();
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping));
ParsedDocument parsedDocument = mapper.parse("index", "type", "id", new BytesArray("{}")); ParsedDocument parsedDocument = mapper.parse(SourceToParse.source("index", "type", "id", new BytesArray("{}"),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(FieldNamesFieldMapper.NAME); IndexableField[] fields = parsedDocument.rootDoc().getFields(FieldNamesFieldMapper.NAME);
boolean found = false; boolean found = false;
for (IndexableField f : fields) { for (IndexableField f : fields) {

View File

@ -40,7 +40,8 @@ public class GenericStoreDynamicTemplateTests extends ESSingleNodeTestCase {
client().admin().indices().preparePutMapping("test").setType("person").setSource(mapping, XContentType.JSON).get(); client().admin().indices().preparePutMapping("test").setType("person").setSource(mapping, XContentType.JSON).get();
DocumentMapper docMapper = index.mapperService().documentMapper("person"); DocumentMapper docMapper = index.mapperService().documentMapper("person");
byte[] json = copyToBytesFromClasspath("/org/elasticsearch/index/mapper/dynamictemplate/genericstore/test-data.json"); byte[] json = copyToBytesFromClasspath("/org/elasticsearch/index/mapper/dynamictemplate/genericstore/test-data.json");
ParsedDocument parsedDoc = docMapper.parse("test", "person", "1", new BytesArray(json)); ParsedDocument parsedDoc = docMapper.parse(SourceToParse.source("test", "person", "1", new BytesArray(json),
XContentType.JSON));
client().admin().indices().preparePutMapping("test").setType("person") client().admin().indices().preparePutMapping("test").setType("person")
.setSource(parsedDoc.dynamicMappingsUpdate().toString(), XContentType.JSON).get(); .setSource(parsedDoc.dynamicMappingsUpdate().toString(), XContentType.JSON).get();
docMapper = index.mapperService().documentMapper("person"); docMapper = index.mapperService().documentMapper("person");

View File

@ -55,11 +55,12 @@ public class GeoPointFieldMapperTests extends ESSingleNodeTestCase {
String mapping = xContentBuilder.endObject().endObject().endObject().endObject().string(); String mapping = xContentBuilder.endObject().endObject().endObject().endObject().string();
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("point", stringEncode(1.3, 1.2)) .field("point", stringEncode(1.3, 1.2))
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("point"), notNullValue()); assertThat(doc.rootDoc().getField("point"), notNullValue());
} }
@ -70,11 +71,12 @@ public class GeoPointFieldMapperTests extends ESSingleNodeTestCase {
String mapping = xContentBuilder.field("store", true).endObject().endObject().endObject().endObject().string(); String mapping = xContentBuilder.field("store", true).endObject().endObject().endObject().endObject().string();
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("point").field("lat", 1.2).field("lon", 1.3).endObject() .startObject("point").field("lat", 1.2).field("lon", 1.3).endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("point"), notNullValue()); assertThat(doc.rootDoc().getField("point"), notNullValue());
} }
@ -85,14 +87,15 @@ public class GeoPointFieldMapperTests extends ESSingleNodeTestCase {
String mapping = xContentBuilder.field("store", true).endObject().endObject().endObject().endObject().string(); String mapping = xContentBuilder.field("store", true).endObject().endObject().endObject().endObject().string();
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startArray("point") .startArray("point")
.startObject().field("lat", 1.2).field("lon", 1.3).endObject() .startObject().field("lat", 1.2).field("lon", 1.3).endObject()
.startObject().field("lat", 1.4).field("lon", 1.5).endObject() .startObject().field("lat", 1.4).field("lon", 1.5).endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
// doc values are enabled by default, but in this test we disable them; we should only have 2 points // doc values are enabled by default, but in this test we disable them; we should only have 2 points
assertThat(doc.rootDoc().getFields("point"), notNullValue()); assertThat(doc.rootDoc().getFields("point"), notNullValue());
@ -106,11 +109,12 @@ public class GeoPointFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type",
new CompressedXContent(mapping)); new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("point", "1.2,1.3") .field("point", "1.2,1.3")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("point"), notNullValue()); assertThat(doc.rootDoc().getField("point"), notNullValue());
} }
@ -122,11 +126,12 @@ public class GeoPointFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type",
new CompressedXContent(mapping)); new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("point", "1.2,1.3") .field("point", "1.2,1.3")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("point"), notNullValue()); assertThat(doc.rootDoc().getField("point"), notNullValue());
} }
@ -137,14 +142,15 @@ public class GeoPointFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type",
new CompressedXContent(mapping)); new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startArray("point") .startArray("point")
.value("1.2,1.3") .value("1.2,1.3")
.value("1.4,1.5") .value("1.4,1.5")
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
// doc values are enabled by default, but in this test we disable them; we should only have 2 points // doc values are enabled by default, but in this test we disable them; we should only have 2 points
assertThat(doc.rootDoc().getFields("point"), notNullValue()); assertThat(doc.rootDoc().getFields("point"), notNullValue());
@ -157,11 +163,12 @@ public class GeoPointFieldMapperTests extends ESSingleNodeTestCase {
String mapping = xContentBuilder.endObject().endObject().endObject().endObject().string(); String mapping = xContentBuilder.endObject().endObject().endObject().endObject().string();
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startArray("point").value(1.3).value(1.2).endArray() .startArray("point").value(1.3).value(1.2).endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("point"), notNullValue()); assertThat(doc.rootDoc().getField("point"), notNullValue());
} }
@ -173,11 +180,12 @@ public class GeoPointFieldMapperTests extends ESSingleNodeTestCase {
String mapping = xContentBuilder.endObject().endObject().endObject().endArray().endObject().endObject().string(); String mapping = xContentBuilder.endObject().endObject().endObject().endArray().endObject().endObject().string();
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startArray("point").value(1.3).value(1.2).endArray() .startArray("point").value(1.3).value(1.2).endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("point"), notNullValue()); assertThat(doc.rootDoc().getField("point"), notNullValue());
} }
@ -188,11 +196,12 @@ public class GeoPointFieldMapperTests extends ESSingleNodeTestCase {
String mapping = xContentBuilder.field("store", true).endObject().endObject().endObject().endObject().string(); String mapping = xContentBuilder.field("store", true).endObject().endObject().endObject().endObject().string();
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startArray("point").value(1.3).value(1.2).endArray() .startArray("point").value(1.3).value(1.2).endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("point"), notNullValue()); assertThat(doc.rootDoc().getField("point"), notNullValue());
assertThat(doc.rootDoc().getFields("point").length, equalTo(3)); assertThat(doc.rootDoc().getFields("point").length, equalTo(3));
@ -205,14 +214,15 @@ public class GeoPointFieldMapperTests extends ESSingleNodeTestCase {
.endObject().endObject().string(); .endObject().endObject().string();
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startArray("point") .startArray("point")
.startArray().value(1.3).value(1.2).endArray() .startArray().value(1.3).value(1.2).endArray()
.startArray().value(1.5).value(1.4).endArray() .startArray().value(1.5).value(1.4).endArray()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getFields("point"), notNullValue()); assertThat(doc.rootDoc().getFields("point"), notNullValue());
assertThat(doc.rootDoc().getFields("point").length, CoreMatchers.equalTo(4)); assertThat(doc.rootDoc().getFields("point").length, CoreMatchers.equalTo(4));

View File

@ -40,10 +40,11 @@ public class IdFieldMapperTests extends ESSingleNodeTestCase {
.endObject().endObject().string(); .endObject().endObject().string();
DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get(UidFieldMapper.NAME), notNullValue()); assertThat(doc.rootDoc().get(UidFieldMapper.NAME), notNullValue());
assertThat(doc.rootDoc().get(IdFieldMapper.NAME), nullValue()); assertThat(doc.rootDoc().get(IdFieldMapper.NAME), nullValue());

View File

@ -24,6 +24,7 @@ import org.elasticsearch.cluster.metadata.IndexMetaData;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.DocumentMapperParser; import org.elasticsearch.index.mapper.DocumentMapperParser;
import org.elasticsearch.index.mapper.MapperParsingException; import org.elasticsearch.index.mapper.MapperParsingException;
@ -50,11 +51,12 @@ public class IndexFieldMapperTests extends ESSingleNodeTestCase {
.endObject().endObject().string(); .endObject().endObject().string();
DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("_index"), nullValue()); assertThat(doc.rootDoc().get("_index"), nullValue());
assertThat(doc.rootDoc().get("field"), equalTo("value")); assertThat(doc.rootDoc().get("field"), equalTo("value"));

View File

@ -28,6 +28,7 @@ import org.elasticsearch.common.network.InetAddresses;
import org.elasticsearch.common.xcontent.ToXContent; import org.elasticsearch.common.xcontent.ToXContent;
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.XContentType;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.plugins.Plugin; import org.elasticsearch.plugins.Plugin;
import org.elasticsearch.test.ESSingleNodeTestCase; import org.elasticsearch.test.ESSingleNodeTestCase;
@ -65,11 +66,12 @@ public class IpFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "::1") .field("field", "::1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -93,11 +95,12 @@ public class IpFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "::1") .field("field", "::1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -114,11 +117,12 @@ public class IpFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "::1") .field("field", "::1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -136,11 +140,12 @@ public class IpFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "::1") .field("field", "::1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(3, fields.length); assertEquals(3, fields.length);
@ -163,11 +168,12 @@ public class IpFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ThrowingRunnable runnable = () -> mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ThrowingRunnable runnable = () -> mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", ":1") .field("field", ":1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
MapperParsingException e = expectThrows(MapperParsingException.class, runnable); MapperParsingException e = expectThrows(MapperParsingException.class, runnable);
assertThat(e.getCause().getMessage(), containsString("':1' is not an IP string literal")); assertThat(e.getCause().getMessage(), containsString("':1' is not an IP string literal"));
@ -177,11 +183,12 @@ public class IpFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper mapper2 = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper2 = parser.parse("type", new CompressedXContent(mapping));
ParsedDocument doc = mapper2.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper2.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", ":1") .field("field", ":1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(0, fields.length); assertEquals(0, fields.length);
@ -200,11 +207,12 @@ public class IpFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping));
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("field") .nullField("field")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertArrayEquals(new IndexableField[0], doc.rootDoc().getFields("field")); assertArrayEquals(new IndexableField[0], doc.rootDoc().getFields("field"));
mapping = XContentFactory.jsonBuilder().startObject() mapping = XContentFactory.jsonBuilder().startObject()
@ -220,11 +228,12 @@ public class IpFieldMapperTests extends ESSingleNodeTestCase {
mapper = parser.parse("type", new CompressedXContent(mapping)); mapper = parser.parse("type", new CompressedXContent(mapping));
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("field") .nullField("field")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
IndexableField pointField = fields[0]; IndexableField pointField = fields[0];

View File

@ -24,6 +24,7 @@ import org.apache.lucene.index.IndexableField;
import org.elasticsearch.common.bytes.BytesReference; import org.elasticsearch.common.bytes.BytesReference;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.MapperService; import org.elasticsearch.index.mapper.MapperService;
import org.elasticsearch.index.mapper.ParseContext.Document; import org.elasticsearch.index.mapper.ParseContext.Document;
@ -45,7 +46,7 @@ public class JavaMultiFieldMergeTests extends ESSingleNodeTestCase {
assertThat(docMapper.mappers().getMapper("name.indexed"), nullValue()); assertThat(docMapper.mappers().getMapper("name.indexed"), nullValue());
BytesReference json = XContentFactory.jsonBuilder().startObject().field("name", "some name").endObject().bytes(); BytesReference json = XContentFactory.jsonBuilder().startObject().field("name", "some name").endObject().bytes();
Document doc = docMapper.parse("test", "person", "1", json).rootDoc(); Document doc = docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
IndexableField f = doc.getField("name"); IndexableField f = doc.getField("name");
assertThat(f, notNullValue()); assertThat(f, notNullValue());
f = doc.getField("name.indexed"); f = doc.getField("name.indexed");
@ -62,7 +63,7 @@ public class JavaMultiFieldMergeTests extends ESSingleNodeTestCase {
assertThat(docMapper.mappers().getMapper("name.not_indexed2"), nullValue()); assertThat(docMapper.mappers().getMapper("name.not_indexed2"), nullValue());
assertThat(docMapper.mappers().getMapper("name.not_indexed3"), nullValue()); assertThat(docMapper.mappers().getMapper("name.not_indexed3"), nullValue());
doc = docMapper.parse("test", "person", "1", json).rootDoc(); doc = docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
f = doc.getField("name"); f = doc.getField("name");
assertThat(f, notNullValue()); assertThat(f, notNullValue());
f = doc.getField("name.indexed"); f = doc.getField("name.indexed");
@ -101,7 +102,7 @@ public class JavaMultiFieldMergeTests extends ESSingleNodeTestCase {
assertThat(docMapper.mappers().getMapper("name.indexed"), nullValue()); assertThat(docMapper.mappers().getMapper("name.indexed"), nullValue());
BytesReference json = XContentFactory.jsonBuilder().startObject().field("name", "some name").endObject().bytes(); BytesReference json = XContentFactory.jsonBuilder().startObject().field("name", "some name").endObject().bytes();
Document doc = docMapper.parse("test", "person", "1", json).rootDoc(); Document doc = docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
IndexableField f = doc.getField("name"); IndexableField f = doc.getField("name");
assertThat(f, notNullValue()); assertThat(f, notNullValue());
f = doc.getField("name.indexed"); f = doc.getField("name.indexed");
@ -119,7 +120,7 @@ public class JavaMultiFieldMergeTests extends ESSingleNodeTestCase {
assertThat(docMapper.mappers().getMapper("name.not_indexed2"), nullValue()); assertThat(docMapper.mappers().getMapper("name.not_indexed2"), nullValue());
assertThat(docMapper.mappers().getMapper("name.not_indexed3"), nullValue()); assertThat(docMapper.mappers().getMapper("name.not_indexed3"), nullValue());
doc = docMapper.parse("test", "person", "1", json).rootDoc(); doc = docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
f = doc.getField("name"); f = doc.getField("name");
assertThat(f, notNullValue()); assertThat(f, notNullValue());
f = doc.getField("name.indexed"); f = doc.getField("name.indexed");

View File

@ -27,6 +27,7 @@ import org.apache.lucene.util.BytesRef;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.mapper.MapperService.MergeReason; import org.elasticsearch.index.mapper.MapperService.MergeReason;
import org.elasticsearch.plugins.Plugin; import org.elasticsearch.plugins.Plugin;
@ -70,11 +71,12 @@ public class KeywordFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -106,20 +108,22 @@ public class KeywordFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "elk") .field("field", "elk")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "elasticsearch") .field("field", "elasticsearch")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
fields = doc.rootDoc().getFields("field"); fields = doc.rootDoc().getFields("field");
assertEquals(0, fields.length); assertEquals(0, fields.length);
@ -133,11 +137,12 @@ public class KeywordFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping));
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("field") .nullField("field")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertArrayEquals(new IndexableField[0], doc.rootDoc().getFields("field")); assertArrayEquals(new IndexableField[0], doc.rootDoc().getFields("field"));
mapping = XContentFactory.jsonBuilder().startObject().startObject("type") mapping = XContentFactory.jsonBuilder().startObject().startObject("type")
@ -148,19 +153,21 @@ public class KeywordFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(0, fields.length); assertEquals(0, fields.length);
doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("field") .nullField("field")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
fields = doc.rootDoc().getFields("field"); fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -176,11 +183,12 @@ public class KeywordFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -196,11 +204,12 @@ public class KeywordFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -217,11 +226,12 @@ public class KeywordFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -238,11 +248,12 @@ public class KeywordFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -278,11 +289,12 @@ public class KeywordFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -299,11 +311,12 @@ public class KeywordFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "AbC") .field("field", "AbC")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);

View File

@ -27,6 +27,7 @@ import org.elasticsearch.common.bytes.BytesReference;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.common.xcontent.XContentHelper; import org.elasticsearch.common.xcontent.XContentHelper;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.common.xcontent.support.XContentMapValues; import org.elasticsearch.common.xcontent.support.XContentMapValues;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.mapper.DateFieldMapper; import org.elasticsearch.index.mapper.DateFieldMapper;
@ -62,7 +63,7 @@ public class MultiFieldTests extends ESSingleNodeTestCase {
private void testMultiField(String mapping) throws Exception { private void testMultiField(String mapping) throws Exception {
DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("person", new CompressedXContent(mapping)); DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("person", new CompressedXContent(mapping));
BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/multifield/test-data.json")); BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/multifield/test-data.json"));
Document doc = docMapper.parse("test", "person", "1", json).rootDoc(); Document doc = docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
IndexableField f = doc.getField("name"); IndexableField f = doc.getField("name");
assertThat(f.name(), equalTo("name")); assertThat(f.name(), equalTo("name"));
@ -146,7 +147,7 @@ public class MultiFieldTests extends ESSingleNodeTestCase {
BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/multifield/test-data.json")); BytesReference json = new BytesArray(copyToBytesFromClasspath("/org/elasticsearch/index/mapper/multifield/test-data.json"));
Document doc = docMapper.parse("test", "person", "1", json).rootDoc(); Document doc = docMapper.parse(SourceToParse.source("test", "person", "1", json, XContentType.JSON)).rootDoc();
IndexableField f = doc.getField("name"); IndexableField f = doc.getField("name");
assertThat(f.name(), equalTo("name")); assertThat(f.name(), equalTo("name"));

View File

@ -22,6 +22,7 @@ package org.elasticsearch.index.mapper;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.mapper.MapperService.MergeReason; import org.elasticsearch.index.mapper.MapperService.MergeReason;
import org.elasticsearch.index.mapper.ObjectMapper.Dynamic; import org.elasticsearch.index.mapper.ObjectMapper.Dynamic;
import org.elasticsearch.test.ESSingleNodeTestCase; import org.elasticsearch.test.ESSingleNodeTestCase;
@ -42,21 +43,23 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.nullField("nested1") .nullField("nested1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.docs().size(), equalTo(1)); assertThat(doc.docs().size(), equalTo(1));
doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.startArray("nested").endArray() .startArray("nested").endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.docs().size(), equalTo(1)); assertThat(doc.docs().size(), equalTo(1));
} }
@ -72,12 +75,13 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
ObjectMapper nested1Mapper = docMapper.objectMappers().get("nested1"); ObjectMapper nested1Mapper = docMapper.objectMappers().get("nested1");
assertThat(nested1Mapper.nested().isNested(), equalTo(true)); assertThat(nested1Mapper.nested().isNested(), equalTo(true));
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.startObject("nested1").field("field1", "1").field("field2", "2").endObject() .startObject("nested1").field("field1", "1").field("field2", "2").endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.docs().size(), equalTo(2)); assertThat(doc.docs().size(), equalTo(2));
assertThat(doc.docs().get(0).get(TypeFieldMapper.NAME), equalTo(nested1Mapper.nestedTypePathAsString())); assertThat(doc.docs().get(0).get(TypeFieldMapper.NAME), equalTo(nested1Mapper.nestedTypePathAsString()));
@ -87,7 +91,7 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
assertThat(doc.docs().get(1).get("field"), equalTo("value")); assertThat(doc.docs().get(1).get("field"), equalTo("value"));
doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.startArray("nested1") .startArray("nested1")
@ -95,7 +99,8 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
.startObject().field("field1", "3").field("field2", "4").endObject() .startObject().field("field1", "3").field("field2", "4").endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.docs().size(), equalTo(3)); assertThat(doc.docs().size(), equalTo(3));
assertThat(doc.docs().get(0).get(TypeFieldMapper.NAME), equalTo(nested1Mapper.nestedTypePathAsString())); assertThat(doc.docs().get(0).get(TypeFieldMapper.NAME), equalTo(nested1Mapper.nestedTypePathAsString()));
@ -127,7 +132,7 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
assertThat(nested2Mapper.nested().isIncludeInParent(), equalTo(false)); assertThat(nested2Mapper.nested().isIncludeInParent(), equalTo(false));
assertThat(nested2Mapper.nested().isIncludeInRoot(), equalTo(false)); assertThat(nested2Mapper.nested().isIncludeInRoot(), equalTo(false));
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.startArray("nested1") .startArray("nested1")
@ -135,7 +140,8 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
.startObject().field("field1", "4").startArray("nested2").startObject().field("field2", "5").endObject().startObject().field("field2", "6").endObject().endArray().endObject() .startObject().field("field1", "4").startArray("nested2").startObject().field("field2", "5").endObject().startObject().field("field2", "6").endObject().endArray().endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.docs().size(), equalTo(7)); assertThat(doc.docs().size(), equalTo(7));
assertThat(doc.docs().get(0).get("nested1.nested2.field2"), equalTo("6")); assertThat(doc.docs().get(0).get("nested1.nested2.field2"), equalTo("6"));
@ -178,7 +184,7 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
assertThat(nested2Mapper.nested().isIncludeInParent(), equalTo(true)); assertThat(nested2Mapper.nested().isIncludeInParent(), equalTo(true));
assertThat(nested2Mapper.nested().isIncludeInRoot(), equalTo(false)); assertThat(nested2Mapper.nested().isIncludeInRoot(), equalTo(false));
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.startArray("nested1") .startArray("nested1")
@ -186,7 +192,8 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
.startObject().field("field1", "4").startArray("nested2").startObject().field("field2", "5").endObject().startObject().field("field2", "6").endObject().endArray().endObject() .startObject().field("field1", "4").startArray("nested2").startObject().field("field2", "5").endObject().startObject().field("field2", "6").endObject().endArray().endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.docs().size(), equalTo(7)); assertThat(doc.docs().size(), equalTo(7));
assertThat(doc.docs().get(0).get("nested1.nested2.field2"), equalTo("6")); assertThat(doc.docs().get(0).get("nested1.nested2.field2"), equalTo("6"));
@ -229,7 +236,7 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
assertThat(nested2Mapper.nested().isIncludeInParent(), equalTo(true)); assertThat(nested2Mapper.nested().isIncludeInParent(), equalTo(true));
assertThat(nested2Mapper.nested().isIncludeInRoot(), equalTo(false)); assertThat(nested2Mapper.nested().isIncludeInRoot(), equalTo(false));
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.startArray("nested1") .startArray("nested1")
@ -237,7 +244,8 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
.startObject().field("field1", "4").startArray("nested2").startObject().field("field2", "5").endObject().startObject().field("field2", "6").endObject().endArray().endObject() .startObject().field("field1", "4").startArray("nested2").startObject().field("field2", "5").endObject().startObject().field("field2", "6").endObject().endArray().endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.docs().size(), equalTo(7)); assertThat(doc.docs().size(), equalTo(7));
assertThat(doc.docs().get(0).get("nested1.nested2.field2"), equalTo("6")); assertThat(doc.docs().get(0).get("nested1.nested2.field2"), equalTo("6"));
@ -280,7 +288,7 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
assertThat(nested2Mapper.nested().isIncludeInParent(), equalTo(false)); assertThat(nested2Mapper.nested().isIncludeInParent(), equalTo(false));
assertThat(nested2Mapper.nested().isIncludeInRoot(), equalTo(true)); assertThat(nested2Mapper.nested().isIncludeInRoot(), equalTo(true));
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.startArray("nested1") .startArray("nested1")
@ -288,7 +296,8 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
.startObject().field("field1", "4").startArray("nested2").startObject().field("field2", "5").endObject().startObject().field("field2", "6").endObject().endArray().endObject() .startObject().field("field1", "4").startArray("nested2").startObject().field("field2", "5").endObject().startObject().field("field2", "6").endObject().endArray().endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.docs().size(), equalTo(7)); assertThat(doc.docs().size(), equalTo(7));
assertThat(doc.docs().get(0).get("nested1.nested2.field2"), equalTo("6")); assertThat(doc.docs().get(0).get("nested1.nested2.field2"), equalTo("6"));
@ -326,7 +335,7 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
assertThat(nested1Mapper.nested().isNested(), equalTo(true)); assertThat(nested1Mapper.nested().isNested(), equalTo(true));
assertThat(nested1Mapper.dynamic(), equalTo(Dynamic.STRICT)); assertThat(nested1Mapper.dynamic(), equalTo(Dynamic.STRICT));
ParsedDocument doc = docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.startArray("nested1") .startArray("nested1")
@ -334,7 +343,8 @@ public class NestedObjectMapperTests extends ESSingleNodeTestCase {
.startObject().field("field1", "4").endObject() .startObject().field("field1", "4").endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.docs().size(), equalTo(3)); assertThat(doc.docs().size(), equalTo(3));
assertThat(doc.docs().get(0).get("nested1.field1"), equalTo("4")); assertThat(doc.docs().get(0).get("nested1.field1"), equalTo("4"));

View File

@ -21,6 +21,7 @@ package org.elasticsearch.index.mapper;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.ParsedDocument; import org.elasticsearch.index.mapper.ParsedDocument;
import org.elasticsearch.test.ESSingleNodeTestCase; import org.elasticsearch.test.ESSingleNodeTestCase;
@ -37,30 +38,33 @@ public class NullValueObjectMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("obj1").endObject() .startObject("obj1").endObject()
.field("value1", "test1") .field("value1", "test1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("value1"), equalTo("test1")); assertThat(doc.rootDoc().get("value1"), equalTo("test1"));
doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("obj1") .nullField("obj1")
.field("value1", "test1") .field("value1", "test1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("value1"), equalTo("test1")); assertThat(doc.rootDoc().get("value1"), equalTo("test1"));
doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("obj1").field("field", "value").endObject() .startObject("obj1").field("field", "value").endObject()
.field("value1", "test1") .field("value1", "test1")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().get("obj1.field"), equalTo("value")); assertThat(doc.rootDoc().get("obj1.field"), equalTo("value"));
assertThat(doc.rootDoc().get("value1"), equalTo("test1")); assertThat(doc.rootDoc().get("value1"), equalTo("test1"));

View File

@ -23,6 +23,7 @@ import org.apache.lucene.index.DocValuesType;
import org.apache.lucene.index.IndexableField; import org.apache.lucene.index.IndexableField;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import java.io.IOException; import java.io.IOException;
import java.util.Arrays; import java.util.Arrays;
@ -47,11 +48,12 @@ public class NumberFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", 123) .field("field", 123)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -74,11 +76,12 @@ public class NumberFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", 123) .field("field", 123)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -96,11 +99,12 @@ public class NumberFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", 123) .field("field", 123)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -119,11 +123,12 @@ public class NumberFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", 123) .field("field", 123)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(3, fields.length); assertEquals(3, fields.length);
@ -147,11 +152,12 @@ public class NumberFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "123") .field("field", "123")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -169,11 +175,12 @@ public class NumberFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping, mapper2.mappingSource().toString()); assertEquals(mapping, mapper2.mappingSource().toString());
ThrowingRunnable runnable = () -> mapper2.parse("test", "type", "1", XContentFactory.jsonBuilder() ThrowingRunnable runnable = () -> mapper2.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "123") .field("field", "123")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
MapperParsingException e = expectThrows(MapperParsingException.class, runnable); MapperParsingException e = expectThrows(MapperParsingException.class, runnable);
assertThat(e.getCause().getMessage(), containsString("passed as String")); assertThat(e.getCause().getMessage(), containsString("passed as String"));
} }
@ -193,11 +200,12 @@ public class NumberFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ThrowingRunnable runnable = () -> mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ThrowingRunnable runnable = () -> mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "a") .field("field", "a")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
MapperParsingException e = expectThrows(MapperParsingException.class, runnable); MapperParsingException e = expectThrows(MapperParsingException.class, runnable);
assertThat(e.getCause().getMessage(), containsString("For input string: \"a\"")); assertThat(e.getCause().getMessage(), containsString("For input string: \"a\""));
@ -207,11 +215,12 @@ public class NumberFieldMapperTests extends AbstractNumericFieldMapperTestCase {
DocumentMapper mapper2 = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper2 = parser.parse("type", new CompressedXContent(mapping));
ParsedDocument doc = mapper2.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper2.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "a") .field("field", "a")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(0, fields.length); assertEquals(0, fields.length);
@ -248,11 +257,12 @@ public class NumberFieldMapperTests extends AbstractNumericFieldMapperTestCase {
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping));
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("field") .nullField("field")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertArrayEquals(new IndexableField[0], doc.rootDoc().getFields("field")); assertArrayEquals(new IndexableField[0], doc.rootDoc().getFields("field"));
Object missing; Object missing;
@ -274,11 +284,12 @@ public class NumberFieldMapperTests extends AbstractNumericFieldMapperTestCase {
mapper = parser.parse("type", new CompressedXContent(mapping)); mapper = parser.parse("type", new CompressedXContent(mapping));
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("field") .nullField("field")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
IndexableField pointField = fields[0]; IndexableField pointField = fields[0];

View File

@ -25,6 +25,7 @@ import org.elasticsearch.common.bytes.BytesArray;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.DocumentMapperParser; import org.elasticsearch.index.mapper.DocumentMapperParser;
import org.elasticsearch.index.mapper.MapperParsingException; import org.elasticsearch.index.mapper.MapperParsingException;
@ -48,7 +49,7 @@ public class ObjectMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
IllegalArgumentException e = expectThrows(IllegalArgumentException.class, () -> { IllegalArgumentException e = expectThrows(IllegalArgumentException.class, () -> {
defaultMapper.parse("test", "type", "1", new BytesArray(" {\n" + defaultMapper.parse(SourceToParse.source("test", "type", "1", new BytesArray(" {\n" +
" \"object\": {\n" + " \"object\": {\n" +
" \"array\":[\n" + " \"array\":[\n" +
" {\n" + " {\n" +
@ -60,7 +61,8 @@ public class ObjectMapperTests extends ESSingleNodeTestCase {
" ]\n" + " ]\n" +
" },\n" + " },\n" +
" \"value\":\"value\"\n" + " \"value\":\"value\"\n" +
" }")); " }"),
XContentType.JSON));
}); });
assertTrue(e.getMessage(), e.getMessage().contains("different type")); assertTrue(e.getMessage(), e.getMessage().contains("different type"));
} }

View File

@ -40,7 +40,8 @@ public class PathMatchDynamicTemplateTests extends ESSingleNodeTestCase {
client().admin().indices().preparePutMapping("test").setType("person").setSource(mapping, XContentType.JSON).get(); client().admin().indices().preparePutMapping("test").setType("person").setSource(mapping, XContentType.JSON).get();
DocumentMapper docMapper = index.mapperService().documentMapper("person"); DocumentMapper docMapper = index.mapperService().documentMapper("person");
byte[] json = copyToBytesFromClasspath("/org/elasticsearch/index/mapper/dynamictemplate/pathmatch/test-data.json"); byte[] json = copyToBytesFromClasspath("/org/elasticsearch/index/mapper/dynamictemplate/pathmatch/test-data.json");
ParsedDocument parsedDoc = docMapper.parse("test", "person", "1", new BytesArray(json)); ParsedDocument parsedDoc = docMapper.parse(SourceToParse.source("test", "person", "1", new BytesArray(json),
XContentType.JSON));
client().admin().indices().preparePutMapping("test").setType("person") client().admin().indices().preparePutMapping("test").setType("person")
.setSource(parsedDoc.dynamicMappingsUpdate().toString(), XContentType.JSON).get(); .setSource(parsedDoc.dynamicMappingsUpdate().toString(), XContentType.JSON).get();
docMapper = index.mapperService().documentMapper("person"); docMapper = index.mapperService().documentMapper("person");

View File

@ -23,6 +23,7 @@ import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.ToXContent; import org.elasticsearch.common.xcontent.ToXContent;
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.XContentType;
import java.io.IOException; import java.io.IOException;
import java.util.Arrays; import java.util.Arrays;
@ -95,13 +96,14 @@ public class RangeFieldMapperTests extends AbstractNumericFieldMapperTestCase {
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping.string())); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping.string()));
assertEquals(mapping.string(), mapper.mappingSource().toString()); assertEquals(mapping.string(), mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("field") .startObject("field")
.field(getFromField(), getFrom(type)) .field(getFromField(), getFrom(type))
.field(getToField(), getTo(type)) .field(getToField(), getTo(type))
.endObject() .endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -122,13 +124,14 @@ public class RangeFieldMapperTests extends AbstractNumericFieldMapperTestCase {
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping.string())); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping.string()));
assertEquals(mapping.string(), mapper.mappingSource().toString()); assertEquals(mapping.string(), mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("field") .startObject("field")
.field(getFromField(), getFrom(type)) .field(getFromField(), getFrom(type))
.field(getToField(), getTo(type)) .field(getToField(), getTo(type))
.endObject() .endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(0, fields.length); assertEquals(0, fields.length);
@ -145,13 +148,14 @@ public class RangeFieldMapperTests extends AbstractNumericFieldMapperTestCase {
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping.string())); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping.string()));
assertEquals(mapping.string(), mapper.mappingSource().toString()); assertEquals(mapping.string(), mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("field") .startObject("field")
.field(getFromField(), getFrom(type)) .field(getFromField(), getFrom(type))
.field(getToField(), getTo(type)) .field(getToField(), getTo(type))
.endObject() .endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -170,13 +174,14 @@ public class RangeFieldMapperTests extends AbstractNumericFieldMapperTestCase {
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping.string())); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping.string()));
assertEquals(mapping.string(), mapper.mappingSource().toString()); assertEquals(mapping.string(), mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("field") .startObject("field")
.field(getFromField(), getFrom(type)) .field(getFromField(), getFrom(type))
.field(getToField(), getTo(type)) .field(getToField(), getTo(type))
.endObject() .endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -199,13 +204,14 @@ public class RangeFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping.string(), mapper.mappingSource().toString()); assertEquals(mapping.string(), mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("field") .startObject("field")
.field(getFromField(), getFrom(type)) .field(getFromField(), getFrom(type))
.field(getToField(), getTo(type)) .field(getToField(), getTo(type))
.endObject() .endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -219,13 +225,14 @@ public class RangeFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping.string(), mapper2.mappingSource().toString()); assertEquals(mapping.string(), mapper2.mappingSource().toString());
ThrowingRunnable runnable = () -> mapper2.parse("test", "type", "1", XContentFactory.jsonBuilder() ThrowingRunnable runnable = () -> mapper2.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("field") .startObject("field")
.field(getFromField(), "5.2") .field(getFromField(), "5.2")
.field(getToField(), "10") .field(getToField(), "10")
.endObject() .endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
MapperParsingException e = expectThrows(MapperParsingException.class, runnable); MapperParsingException e = expectThrows(MapperParsingException.class, runnable);
assertThat(e.getCause().getMessage(), anyOf(containsString("passed as String"), containsString("failed to parse date"))); assertThat(e.getCause().getMessage(), anyOf(containsString("passed as String"), containsString("failed to parse date")));
} }
@ -243,26 +250,28 @@ public class RangeFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping.string(), mapper.mappingSource().toString()); assertEquals(mapping.string(), mapper.mappingSource().toString());
// test null value for min and max // test null value for min and max
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("field") .startObject("field")
.nullField(getFromField()) .nullField(getFromField())
.nullField(getToField()) .nullField(getToField())
.endObject() .endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
assertEquals(2, doc.rootDoc().getFields("field").length); assertEquals(2, doc.rootDoc().getFields("field").length);
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
IndexableField storedField = fields[1]; IndexableField storedField = fields[1];
assertThat(storedField.stringValue(), containsString(type.equals("date_range") ? Long.MAX_VALUE+"" : getMax(type)+"")); assertThat(storedField.stringValue(), containsString(type.equals("date_range") ? Long.MAX_VALUE+"" : getMax(type)+""));
// test null max value // test null max value
doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("field") .startObject("field")
.field(getFromField(), getFrom(type)) .field(getFromField(), getFrom(type))
.nullField(getToField()) .nullField(getToField())
.endObject() .endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
fields = doc.rootDoc().getFields("field"); fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -293,11 +302,12 @@ public class RangeFieldMapperTests extends AbstractNumericFieldMapperTestCase {
assertEquals(mapping.string(), mapper.mappingSource().toString()); assertEquals(mapping.string(), mapper.mappingSource().toString());
// test no bounds specified // test no bounds specified
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.startObject("field") .startObject("field")
.endObject() .endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);

View File

@ -41,7 +41,8 @@ public class RoutingFieldMapperTests extends ESSingleNodeTestCase {
.startObject() .startObject()
.field("field", "value") .field("field", "value")
.endObject() .endObject()
.bytes(), XContentType.JSON).routing("routing_value")); .bytes(),
XContentType.JSON).routing("routing_value"));
assertThat(doc.rootDoc().get("_routing"), equalTo("routing_value")); assertThat(doc.rootDoc().get("_routing"), equalTo("routing_value"));
assertThat(doc.rootDoc().get("field"), equalTo("value")); assertThat(doc.rootDoc().get("field"), equalTo("value"));
@ -52,8 +53,8 @@ public class RoutingFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
try { try {
docMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() docMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject().field("_routing", "foo").endObject().bytes()); .startObject().field("_routing", "foo").endObject().bytes(),XContentType.JSON));
fail("Expected failure to parse metadata field"); fail("Expected failure to parse metadata field");
} catch (MapperParsingException e) { } catch (MapperParsingException e) {
assertTrue(e.getMessage(), e.getMessage().contains("Field [_routing] is a metadata field and cannot be added inside a document")); assertTrue(e.getMessage(), e.getMessage().contains("Field [_routing] is a metadata field and cannot be added inside a document"));

View File

@ -23,6 +23,7 @@ import org.apache.lucene.index.DocValuesType;
import org.apache.lucene.index.IndexableField; import org.apache.lucene.index.IndexableField;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.plugins.Plugin; import org.elasticsearch.plugins.Plugin;
import org.elasticsearch.test.ESSingleNodeTestCase; import org.elasticsearch.test.ESSingleNodeTestCase;
@ -60,11 +61,12 @@ public class ScaledFloatFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", 123) .field("field", 123)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -109,11 +111,12 @@ public class ScaledFloatFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", 123) .field("field", 123)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -132,11 +135,12 @@ public class ScaledFloatFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", 123) .field("field", 123)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -155,11 +159,12 @@ public class ScaledFloatFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", 123) .field("field", 123)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(3, fields.length); assertEquals(3, fields.length);
@ -183,11 +188,12 @@ public class ScaledFloatFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "123") .field("field", "123")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -206,11 +212,12 @@ public class ScaledFloatFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper2.mappingSource().toString()); assertEquals(mapping, mapper2.mappingSource().toString());
ThrowingRunnable runnable = () -> mapper2.parse("test", "type", "1", XContentFactory.jsonBuilder() ThrowingRunnable runnable = () -> mapper2.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "123") .field("field", "123")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
MapperParsingException e = expectThrows(MapperParsingException.class, runnable); MapperParsingException e = expectThrows(MapperParsingException.class, runnable);
assertThat(e.getCause().getMessage(), containsString("passed as String")); assertThat(e.getCause().getMessage(), containsString("passed as String"));
} }
@ -225,11 +232,12 @@ public class ScaledFloatFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ThrowingRunnable runnable = () -> mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ThrowingRunnable runnable = () -> mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "a") .field("field", "a")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
MapperParsingException e = expectThrows(MapperParsingException.class, runnable); MapperParsingException e = expectThrows(MapperParsingException.class, runnable);
assertThat(e.getCause().getMessage(), containsString("For input string: \"a\"")); assertThat(e.getCause().getMessage(), containsString("For input string: \"a\""));
@ -240,11 +248,12 @@ public class ScaledFloatFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper mapper2 = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper2 = parser.parse("type", new CompressedXContent(mapping));
ParsedDocument doc = mapper2.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper2.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "a") .field("field", "a")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(0, fields.length); assertEquals(0, fields.length);
@ -264,11 +273,12 @@ public class ScaledFloatFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping));
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("field") .nullField("field")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertArrayEquals(new IndexableField[0], doc.rootDoc().getFields("field")); assertArrayEquals(new IndexableField[0], doc.rootDoc().getFields("field"));
mapping = XContentFactory.jsonBuilder().startObject() mapping = XContentFactory.jsonBuilder().startObject()
@ -285,11 +295,12 @@ public class ScaledFloatFieldMapperTests extends ESSingleNodeTestCase {
mapper = parser.parse("type", new CompressedXContent(mapping)); mapper = parser.parse("type", new CompressedXContent(mapping));
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.nullField("field") .nullField("field")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
IndexableField pointField = fields[0]; IndexableField pointField = fields[0];

View File

@ -51,16 +51,18 @@ public class SourceFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapperParser parser = createIndex("test").mapperService().documentMapperParser(); DocumentMapperParser parser = createIndex("test").mapperService().documentMapperParser();
DocumentMapper documentMapper = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper documentMapper = parser.parse("type", new CompressedXContent(mapping));
ParsedDocument doc = documentMapper.parse("test", "type", "1", XContentFactory.jsonBuilder().startObject() ParsedDocument doc = documentMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder().startObject()
.field("field", "value") .field("field", "value")
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
assertThat(XContentFactory.xContentType(doc.source()), equalTo(XContentType.JSON)); assertThat(XContentFactory.xContentType(doc.source()), equalTo(XContentType.JSON));
documentMapper = parser.parse("type", new CompressedXContent(mapping)); documentMapper = parser.parse("type", new CompressedXContent(mapping));
doc = documentMapper.parse("test", "type", "1", XContentFactory.smileBuilder().startObject() doc = documentMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.smileBuilder().startObject()
.field("field", "value") .field("field", "value")
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
assertThat(XContentFactory.xContentType(doc.source()), equalTo(XContentType.SMILE)); assertThat(XContentFactory.xContentType(doc.source()), equalTo(XContentType.SMILE));
} }
@ -72,10 +74,11 @@ public class SourceFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper documentMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper documentMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = documentMapper.parse("test", "type", "1", XContentFactory.jsonBuilder().startObject() ParsedDocument doc = documentMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder().startObject()
.startObject("path1").field("field1", "value1").endObject() .startObject("path1").field("field1", "value1").endObject()
.startObject("path2").field("field2", "value2").endObject() .startObject("path2").field("field2", "value2").endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
IndexableField sourceField = doc.rootDoc().getField("_source"); IndexableField sourceField = doc.rootDoc().getField("_source");
Map<String, Object> sourceAsMap; Map<String, Object> sourceAsMap;
@ -93,10 +96,11 @@ public class SourceFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper documentMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper documentMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
ParsedDocument doc = documentMapper.parse("test", "type", "1", XContentFactory.jsonBuilder().startObject() ParsedDocument doc = documentMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder().startObject()
.startObject("path1").field("field1", "value1").endObject() .startObject("path1").field("field1", "value1").endObject()
.startObject("path2").field("field2", "value2").endObject() .startObject("path2").field("field2", "value2").endObject()
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
IndexableField sourceField = doc.rootDoc().getField("_source"); IndexableField sourceField = doc.rootDoc().getField("_source");
Map<String, Object> sourceAsMap; Map<String, Object> sourceAsMap;
@ -276,7 +280,7 @@ public class SourceFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper documentMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping)); DocumentMapper documentMapper = createIndex("test").mapperService().documentMapperParser().parse("type", new CompressedXContent(mapping));
try { try {
documentMapper.parse("test", "type", "1", new BytesArray("{}}")); // extra end object (invalid JSON) documentMapper.parse(SourceToParse.source("test", "type", "1", new BytesArray("{}}"), XContentType.JSON)); // extra end object (invalid JSON)
fail("Expected parse exception"); fail("Expected parse exception");
} catch (MapperParsingException e) { } catch (MapperParsingException e) {
assertNotNull(e.getRootCause()); assertNotNull(e.getRootCause());

View File

@ -27,6 +27,7 @@ import org.apache.lucene.store.RAMDirectory;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.lucene.Lucene; import org.elasticsearch.common.lucene.Lucene;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.fieldvisitor.CustomFieldsVisitor; import org.elasticsearch.index.fieldvisitor.CustomFieldsVisitor;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.MapperService; import org.elasticsearch.index.mapper.MapperService;
@ -63,7 +64,7 @@ public class StoredNumericValuesTests extends ESSingleNodeTestCase {
MapperService mapperService = createIndex("test").mapperService(); MapperService mapperService = createIndex("test").mapperService();
DocumentMapper mapper = mapperService.merge("type", new CompressedXContent(mapping), MergeReason.MAPPING_UPDATE, false); DocumentMapper mapper = mapperService.merge("type", new CompressedXContent(mapping), MergeReason.MAPPING_UPDATE, false);
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field1", 1) .field("field1", 1)
.field("field2", 1) .field("field2", 1)
@ -76,7 +77,8 @@ public class StoredNumericValuesTests extends ESSingleNodeTestCase {
.field("field9", "2016-04-05") .field("field9", "2016-04-05")
.field("field10", true) .field("field10", true)
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
writer.addDocument(doc.rootDoc()); writer.addDocument(doc.rootDoc());

View File

@ -32,6 +32,7 @@ import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.ToXContent; import org.elasticsearch.common.xcontent.ToXContent;
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.XContentType;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.engine.Engine; import org.elasticsearch.index.engine.Engine;
import org.elasticsearch.index.mapper.MapperService.MergeReason; import org.elasticsearch.index.mapper.MapperService.MergeReason;
@ -77,11 +78,12 @@ public class TextFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -108,11 +110,12 @@ public class TextFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -128,11 +131,12 @@ public class TextFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(0, fields.length); assertEquals(0, fields.length);
@ -150,11 +154,12 @@ public class TextFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field", "1234") .field("field", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(1, fields.length); assertEquals(1, fields.length);
@ -180,7 +185,8 @@ public class TextFieldMapperTests extends ESSingleNodeTestCase {
for (String option : supportedOptions.keySet()) { for (String option : supportedOptions.keySet()) {
jsonDoc.field(option, "1234"); jsonDoc.field(option, "1234");
} }
ParsedDocument doc = mapper.parse("test", "type", "1", jsonDoc.endObject().bytes()); ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", jsonDoc.endObject().bytes(),
XContentType.JSON));
for (Map.Entry<String, IndexOptions> entry : supportedOptions.entrySet()) { for (Map.Entry<String, IndexOptions> entry : supportedOptions.entrySet()) {
String field = entry.getKey(); String field = entry.getKey();
@ -201,11 +207,12 @@ public class TextFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.array("field", new String[] {"a", "b"}) .array("field", new String[] {"a", "b"})
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -240,11 +247,12 @@ public class TextFieldMapperTests extends ESSingleNodeTestCase {
assertEquals(mapping, mapper.mappingSource().toString()); assertEquals(mapping, mapper.mappingSource().toString());
ParsedDocument doc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.array("field", new String[] {"a", "b"}) .array("field", new String[] {"a", "b"})
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = doc.rootDoc().getFields("field"); IndexableField[] fields = doc.rootDoc().getFields("field");
assertEquals(2, fields.length); assertEquals(2, fields.length);
@ -396,7 +404,7 @@ public class TextFieldMapperTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper defaultMapper = parser.parse("type", new CompressedXContent(mapping));
ParsedDocument doc = defaultMapper.parse("test", "type", "1", XContentFactory.jsonBuilder() ParsedDocument doc = defaultMapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject() .startObject()
.field("field1", "1234") .field("field1", "1234")
.field("field2", "1234") .field("field2", "1234")
@ -405,7 +413,8 @@ public class TextFieldMapperTests extends ESSingleNodeTestCase {
.field("field5", "1234") .field("field5", "1234")
.field("field6", "1234") .field("field6", "1234")
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getField("field1").fieldType().storeTermVectors(), equalTo(false)); assertThat(doc.rootDoc().getField("field1").fieldType().storeTermVectors(), equalTo(false));
assertThat(doc.rootDoc().getField("field1").fieldType().storeTermVectorOffsets(), equalTo(false)); assertThat(doc.rootDoc().getField("field1").fieldType().storeTermVectorOffsets(), equalTo(false));

View File

@ -26,12 +26,14 @@ import org.apache.lucene.search.suggest.document.ContextSuggestField;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.common.xcontent.XContentParser; import org.elasticsearch.common.xcontent.XContentParser;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.common.xcontent.json.JsonXContent; import org.elasticsearch.common.xcontent.json.JsonXContent;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.FieldMapper; import org.elasticsearch.index.mapper.FieldMapper;
import org.elasticsearch.index.mapper.MappedFieldType; import org.elasticsearch.index.mapper.MappedFieldType;
import org.elasticsearch.index.mapper.ParseContext; import org.elasticsearch.index.mapper.ParseContext;
import org.elasticsearch.index.mapper.ParsedDocument; import org.elasticsearch.index.mapper.ParsedDocument;
import org.elasticsearch.index.mapper.SourceToParse;
import org.elasticsearch.index.query.QueryParseContext; import org.elasticsearch.index.query.QueryParseContext;
import org.elasticsearch.search.suggest.completion.context.CategoryContextMapping; import org.elasticsearch.search.suggest.completion.context.CategoryContextMapping;
import org.elasticsearch.search.suggest.completion.context.ContextBuilder; import org.elasticsearch.search.suggest.completion.context.ContextBuilder;
@ -62,7 +64,7 @@ public class CategoryContextMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", jsonBuilder()
.startObject() .startObject()
.startArray("completion") .startArray("completion")
.startObject() .startObject()
@ -79,7 +81,8 @@ public class CategoryContextMappingTests extends ESSingleNodeTestCase {
.endObject() .endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertContextSuggestFields(fields, 7); assertContextSuggestFields(fields, 7);
} }
@ -100,7 +103,7 @@ public class CategoryContextMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", jsonBuilder()
.startObject() .startObject()
.startArray("completion") .startArray("completion")
.startObject() .startObject()
@ -112,7 +115,8 @@ public class CategoryContextMappingTests extends ESSingleNodeTestCase {
.endObject() .endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertContextSuggestFields(fields, 3); assertContextSuggestFields(fields, 3);
} }
@ -133,7 +137,7 @@ public class CategoryContextMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", jsonBuilder()
.startObject() .startObject()
.startObject("completion") .startObject("completion")
.array("input", "suggestion5", "suggestion6", "suggestion7") .array("input", "suggestion5", "suggestion6", "suggestion7")
@ -143,7 +147,8 @@ public class CategoryContextMappingTests extends ESSingleNodeTestCase {
.field("weight", 5) .field("weight", 5)
.endObject() .endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertContextSuggestFields(fields, 3); assertContextSuggestFields(fields, 3);
} }
@ -181,7 +186,8 @@ public class CategoryContextMappingTests extends ESSingleNodeTestCase {
.endObject() .endObject()
.endArray() .endArray()
.endObject(); .endObject();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", builder.bytes()); ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", builder.bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertContextSuggestFields(fields, 3); assertContextSuggestFields(fields, 3);
} }

View File

@ -23,11 +23,13 @@ import org.apache.lucene.index.IndexableField;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.common.xcontent.XContentParser; import org.elasticsearch.common.xcontent.XContentParser;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.common.xcontent.json.JsonXContent; import org.elasticsearch.common.xcontent.json.JsonXContent;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.FieldMapper; import org.elasticsearch.index.mapper.FieldMapper;
import org.elasticsearch.index.mapper.MappedFieldType; import org.elasticsearch.index.mapper.MappedFieldType;
import org.elasticsearch.index.mapper.ParsedDocument; import org.elasticsearch.index.mapper.ParsedDocument;
import org.elasticsearch.index.mapper.SourceToParse;
import org.elasticsearch.index.query.QueryParseContext; import org.elasticsearch.index.query.QueryParseContext;
import org.elasticsearch.search.suggest.completion.context.ContextBuilder; import org.elasticsearch.search.suggest.completion.context.ContextBuilder;
import org.elasticsearch.search.suggest.completion.context.ContextMapping; import org.elasticsearch.search.suggest.completion.context.ContextMapping;
@ -62,7 +64,7 @@ public class GeoContextMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", jsonBuilder()
.startObject() .startObject()
.startArray("completion") .startArray("completion")
.startObject() .startObject()
@ -79,7 +81,8 @@ public class GeoContextMappingTests extends ESSingleNodeTestCase {
.endObject() .endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertContextSuggestFields(fields, 7); assertContextSuggestFields(fields, 7);
} }
@ -101,7 +104,7 @@ public class GeoContextMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", jsonBuilder()
.startObject() .startObject()
.startArray("completion") .startArray("completion")
.startObject() .startObject()
@ -116,7 +119,8 @@ public class GeoContextMappingTests extends ESSingleNodeTestCase {
.endObject() .endObject()
.endArray() .endArray()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertContextSuggestFields(fields, 3); assertContextSuggestFields(fields, 3);
} }
@ -137,7 +141,7 @@ public class GeoContextMappingTests extends ESSingleNodeTestCase {
DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping)); DocumentMapper defaultMapper = createIndex("test").mapperService().documentMapperParser().parse("type1", new CompressedXContent(mapping));
FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion"); FieldMapper fieldMapper = defaultMapper.mappers().getMapper("completion");
MappedFieldType completionFieldType = fieldMapper.fieldType(); MappedFieldType completionFieldType = fieldMapper.fieldType();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", jsonBuilder() ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", jsonBuilder()
.startObject() .startObject()
.startObject("completion") .startObject("completion")
.array("input", "suggestion5", "suggestion6", "suggestion7") .array("input", "suggestion5", "suggestion6", "suggestion7")
@ -156,7 +160,8 @@ public class GeoContextMappingTests extends ESSingleNodeTestCase {
.field("weight", 5) .field("weight", 5)
.endObject() .endObject()
.endObject() .endObject()
.bytes()); .bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertContextSuggestFields(fields, 3); assertContextSuggestFields(fields, 3);
} }
@ -194,7 +199,8 @@ public class GeoContextMappingTests extends ESSingleNodeTestCase {
.endObject() .endObject()
.endArray() .endArray()
.endObject(); .endObject();
ParsedDocument parsedDocument = defaultMapper.parse("test", "type1", "1", builder.bytes()); ParsedDocument parsedDocument = defaultMapper.parse(SourceToParse.source("test", "type1", "1", builder.bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name()); IndexableField[] fields = parsedDocument.rootDoc().getFields(completionFieldType.name());
assertContextSuggestFields(fields, 3); assertContextSuggestFields(fields, 3);
} }

View File

@ -44,6 +44,7 @@ import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentHelper; import org.elasticsearch.common.xcontent.XContentHelper;
import org.elasticsearch.common.xcontent.XContentParser; import org.elasticsearch.common.xcontent.XContentParser;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.common.xcontent.support.XContentMapValues; import org.elasticsearch.common.xcontent.support.XContentMapValues;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
@ -52,6 +53,7 @@ import org.elasticsearch.index.mapper.MapperParsingException;
import org.elasticsearch.index.mapper.MapperService; import org.elasticsearch.index.mapper.MapperService;
import org.elasticsearch.index.mapper.ParseContext; import org.elasticsearch.index.mapper.ParseContext;
import org.elasticsearch.index.mapper.ParsedDocument; import org.elasticsearch.index.mapper.ParsedDocument;
import org.elasticsearch.index.mapper.SourceToParse;
import org.elasticsearch.index.query.BoolQueryBuilder; import org.elasticsearch.index.query.BoolQueryBuilder;
import org.elasticsearch.index.query.BoostingQueryBuilder; import org.elasticsearch.index.query.BoostingQueryBuilder;
import org.elasticsearch.index.query.ConstantScoreQueryBuilder; import org.elasticsearch.index.query.ConstantScoreQueryBuilder;
@ -244,9 +246,12 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
public void testPercolatorFieldMapper() throws Exception { public void testPercolatorFieldMapper() throws Exception {
addQueryMapping(); addQueryMapping();
QueryBuilder queryBuilder = termQuery("field", "value"); QueryBuilder queryBuilder = termQuery("field", "value");
ParsedDocument doc = mapperService.documentMapper(typeName).parse("test", typeName, "1", XContentFactory.jsonBuilder().startObject() ParsedDocument doc = mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1", XContentFactory
.field(fieldName, queryBuilder) .jsonBuilder()
.endObject().bytes()); .startObject()
.field(fieldName, queryBuilder)
.endObject().bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getFields(fieldType.queryTermsField.name()).length, equalTo(1)); assertThat(doc.rootDoc().getFields(fieldType.queryTermsField.name()).length, equalTo(1));
assertThat(doc.rootDoc().getFields(fieldType.queryTermsField.name())[0].binaryValue().utf8ToString(), equalTo("field\0value")); assertThat(doc.rootDoc().getFields(fieldType.queryTermsField.name())[0].binaryValue().utf8ToString(), equalTo("field\0value"));
@ -259,9 +264,12 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
// add an query for which we don't extract terms from // add an query for which we don't extract terms from
queryBuilder = rangeQuery("field").from("a").to("z"); queryBuilder = rangeQuery("field").from("a").to("z");
doc = mapperService.documentMapper(typeName).parse("test", typeName, "1", XContentFactory.jsonBuilder().startObject() doc = mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1", XContentFactory
.jsonBuilder()
.startObject()
.field(fieldName, queryBuilder) .field(fieldName, queryBuilder)
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getFields(fieldType.extractionResultField.name()).length, equalTo(1)); assertThat(doc.rootDoc().getFields(fieldType.extractionResultField.name()).length, equalTo(1));
assertThat(doc.rootDoc().getFields(fieldType.extractionResultField.name())[0].stringValue(), assertThat(doc.rootDoc().getFields(fieldType.extractionResultField.name())[0].stringValue(),
equalTo(EXTRACTION_FAILED)); equalTo(EXTRACTION_FAILED));
@ -282,10 +290,11 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
// (it can't use shard data for rewriting purposes, because percolator queries run on MemoryIndex) // (it can't use shard data for rewriting purposes, because percolator queries run on MemoryIndex)
for (QueryBuilder query : queries) { for (QueryBuilder query : queries) {
ParsedDocument doc = mapperService.documentMapper(typeName).parse("test", typeName, "1", ParsedDocument doc = mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
XContentFactory.jsonBuilder().startObject() XContentFactory.jsonBuilder().startObject()
.field(fieldName, query) .field(fieldName, query)
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
BytesRef qbSource = doc.rootDoc().getFields(fieldType.queryBuilderField.name())[0].binaryValue(); BytesRef qbSource = doc.rootDoc().getFields(fieldType.queryBuilderField.name())[0].binaryValue();
assertQueryBuilder(qbSource, query); assertQueryBuilder(qbSource, query);
} }
@ -295,9 +304,12 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
addQueryMapping(); addQueryMapping();
client().prepareIndex("remote", "type", "1").setSource("field", "value").get(); client().prepareIndex("remote", "type", "1").setSource("field", "value").get();
QueryBuilder queryBuilder = termsLookupQuery("field", new TermsLookup("remote", "type", "1", "field")); QueryBuilder queryBuilder = termsLookupQuery("field", new TermsLookup("remote", "type", "1", "field"));
ParsedDocument doc = mapperService.documentMapper(typeName).parse("test", typeName, "1", XContentFactory.jsonBuilder().startObject() ParsedDocument doc = mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1", XContentFactory
.jsonBuilder()
.startObject()
.field(fieldName, queryBuilder) .field(fieldName, queryBuilder)
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
BytesRef qbSource = doc.rootDoc().getFields(fieldType.queryBuilderField.name())[0].binaryValue(); BytesRef qbSource = doc.rootDoc().getFields(fieldType.queryBuilderField.name())[0].binaryValue();
assertQueryBuilder(qbSource, queryBuilder.rewrite(indexService.newQueryShardContext( assertQueryBuilder(qbSource, queryBuilder.rewrite(indexService.newQueryShardContext(
randomInt(20), null, () -> { throw new UnsupportedOperationException(); }))); randomInt(20), null, () -> { throw new UnsupportedOperationException(); })));
@ -307,9 +319,12 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
public void testPercolatorFieldMapperUnMappedField() throws Exception { public void testPercolatorFieldMapperUnMappedField() throws Exception {
addQueryMapping(); addQueryMapping();
MapperParsingException exception = expectThrows(MapperParsingException.class, () -> { MapperParsingException exception = expectThrows(MapperParsingException.class, () -> {
mapperService.documentMapper(typeName).parse("test", typeName, "1", XContentFactory.jsonBuilder().startObject() mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1", XContentFactory
.jsonBuilder()
.startObject()
.field(fieldName, termQuery("unmapped_field", "value")) .field(fieldName, termQuery("unmapped_field", "value"))
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
}); });
assertThat(exception.getCause(), instanceOf(QueryShardException.class)); assertThat(exception.getCause(), instanceOf(QueryShardException.class));
assertThat(exception.getCause().getMessage(), equalTo("No field mapping can be found for the field with name [unmapped_field]")); assertThat(exception.getCause().getMessage(), equalTo("No field mapping can be found for the field with name [unmapped_field]"));
@ -318,14 +333,21 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
public void testPercolatorFieldMapper_noQuery() throws Exception { public void testPercolatorFieldMapper_noQuery() throws Exception {
addQueryMapping(); addQueryMapping();
ParsedDocument doc = mapperService.documentMapper(typeName).parse("test", typeName, "1", XContentFactory.jsonBuilder().startObject() ParsedDocument doc = mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1", XContentFactory
.endObject().bytes()); .jsonBuilder()
.startObject()
.endObject()
.bytes(),
XContentType.JSON));
assertThat(doc.rootDoc().getFields(fieldType.queryBuilderField.name()).length, equalTo(0)); assertThat(doc.rootDoc().getFields(fieldType.queryBuilderField.name()).length, equalTo(0));
try { try {
mapperService.documentMapper(typeName).parse("test", typeName, "1", XContentFactory.jsonBuilder().startObject() mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1", XContentFactory
.nullField(fieldName) .jsonBuilder()
.endObject().bytes()); .startObject()
.nullField(fieldName)
.endObject().bytes(),
XContentType.JSON));
} catch (MapperParsingException e) { } catch (MapperParsingException e) {
assertThat(e.getDetailedMessage(), containsString("query malformed, must start with start_object")); assertThat(e.getDetailedMessage(), containsString("query malformed, must start with start_object"));
} }
@ -357,12 +379,12 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
mapperService.merge(typeName, new CompressedXContent(percolatorMapper), MapperService.MergeReason.MAPPING_UPDATE, true); mapperService.merge(typeName, new CompressedXContent(percolatorMapper), MapperService.MergeReason.MAPPING_UPDATE, true);
QueryBuilder queryBuilder = matchQuery("field", "value"); QueryBuilder queryBuilder = matchQuery("field", "value");
ParsedDocument doc = mapperService.documentMapper(typeName).parse("test", typeName, "1", ParsedDocument doc = mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.field("query_field1", queryBuilder) .field("query_field1", queryBuilder)
.field("query_field2", queryBuilder) .field("query_field2", queryBuilder)
.endObject().bytes() .endObject().bytes(),
); XContentType.JSON));
assertThat(doc.rootDoc().getFields().size(), equalTo(14)); // also includes all other meta fields assertThat(doc.rootDoc().getFields().size(), equalTo(14)); // also includes all other meta fields
BytesRef queryBuilderAsBytes = doc.rootDoc().getField("query_field1.query_builder_field").binaryValue(); BytesRef queryBuilderAsBytes = doc.rootDoc().getField("query_field1.query_builder_field").binaryValue();
assertQueryBuilder(queryBuilderAsBytes, queryBuilder); assertQueryBuilder(queryBuilderAsBytes, queryBuilder);
@ -388,35 +410,35 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
mapperService.merge(typeName, new CompressedXContent(percolatorMapper), MapperService.MergeReason.MAPPING_UPDATE, true); mapperService.merge(typeName, new CompressedXContent(percolatorMapper), MapperService.MergeReason.MAPPING_UPDATE, true);
QueryBuilder queryBuilder = matchQuery("field", "value"); QueryBuilder queryBuilder = matchQuery("field", "value");
ParsedDocument doc = mapperService.documentMapper(typeName).parse("test", typeName, "1", ParsedDocument doc = mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject().startObject("object_field") jsonBuilder().startObject().startObject("object_field")
.field("query_field", queryBuilder) .field("query_field", queryBuilder)
.endObject().endObject().bytes() .endObject().endObject().bytes(),
); XContentType.JSON));
assertThat(doc.rootDoc().getFields().size(), equalTo(11)); // also includes all other meta fields assertThat(doc.rootDoc().getFields().size(), equalTo(11)); // also includes all other meta fields
BytesRef queryBuilderAsBytes = doc.rootDoc().getField("object_field.query_field.query_builder_field").binaryValue(); BytesRef queryBuilderAsBytes = doc.rootDoc().getField("object_field.query_field.query_builder_field").binaryValue();
assertQueryBuilder(queryBuilderAsBytes, queryBuilder); assertQueryBuilder(queryBuilderAsBytes, queryBuilder);
doc = mapperService.documentMapper(typeName).parse("test", typeName, "1", doc = mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.startArray("object_field") .startArray("object_field")
.startObject().field("query_field", queryBuilder).endObject() .startObject().field("query_field", queryBuilder).endObject()
.endArray() .endArray()
.endObject().bytes() .endObject().bytes(),
); XContentType.JSON));
assertThat(doc.rootDoc().getFields().size(), equalTo(11)); // also includes all other meta fields assertThat(doc.rootDoc().getFields().size(), equalTo(11)); // also includes all other meta fields
queryBuilderAsBytes = doc.rootDoc().getField("object_field.query_field.query_builder_field").binaryValue(); queryBuilderAsBytes = doc.rootDoc().getField("object_field.query_field.query_builder_field").binaryValue();
assertQueryBuilder(queryBuilderAsBytes, queryBuilder); assertQueryBuilder(queryBuilderAsBytes, queryBuilder);
MapperParsingException e = expectThrows(MapperParsingException.class, () -> { MapperParsingException e = expectThrows(MapperParsingException.class, () -> {
mapperService.documentMapper(typeName).parse("test", typeName, "1", mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.startArray("object_field") .startArray("object_field")
.startObject().field("query_field", queryBuilder).endObject() .startObject().field("query_field", queryBuilder).endObject()
.startObject().field("query_field", queryBuilder).endObject() .startObject().field("query_field", queryBuilder).endObject()
.endArray() .endArray()
.endObject().bytes() .endObject().bytes(),
); XContentType.JSON));
} }
); );
assertThat(e.getCause(), instanceOf(IllegalArgumentException.class)); assertThat(e.getCause(), instanceOf(IllegalArgumentException.class));
@ -426,42 +448,47 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
public void testRangeQueryWithNowRangeIsForbidden() throws Exception { public void testRangeQueryWithNowRangeIsForbidden() throws Exception {
addQueryMapping(); addQueryMapping();
MapperParsingException e = expectThrows(MapperParsingException.class, () -> { MapperParsingException e = expectThrows(MapperParsingException.class, () -> {
mapperService.documentMapper(typeName).parse("test", typeName, "1", mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.field(fieldName, rangeQuery("date_field").from("2016-01-01||/D").to("now")) .field(fieldName, rangeQuery("date_field").from("2016-01-01||/D").to("now"))
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
} }
); );
assertThat(e.getCause(), instanceOf(IllegalArgumentException.class)); assertThat(e.getCause(), instanceOf(IllegalArgumentException.class));
e = expectThrows(MapperParsingException.class, () -> { e = expectThrows(MapperParsingException.class, () -> {
mapperService.documentMapper(typeName).parse("test", typeName, "1", mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.field(fieldName, rangeQuery("date_field").from("2016-01-01||/D").to("now/D")) .field(fieldName, rangeQuery("date_field").from("2016-01-01||/D").to("now/D"))
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
} }
); );
assertThat(e.getCause(), instanceOf(IllegalArgumentException.class)); assertThat(e.getCause(), instanceOf(IllegalArgumentException.class));
e = expectThrows(MapperParsingException.class, () -> { e = expectThrows(MapperParsingException.class, () -> {
mapperService.documentMapper(typeName).parse("test", typeName, "1", mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.field(fieldName, rangeQuery("date_field").from("now-1d").to("now")) .field(fieldName, rangeQuery("date_field").from("now-1d").to("now"))
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
} }
); );
assertThat(e.getCause(), instanceOf(IllegalArgumentException.class)); assertThat(e.getCause(), instanceOf(IllegalArgumentException.class));
e = expectThrows(MapperParsingException.class, () -> { e = expectThrows(MapperParsingException.class, () -> {
mapperService.documentMapper(typeName).parse("test", typeName, "1", mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.field(fieldName, rangeQuery("date_field").from("now")) .field(fieldName, rangeQuery("date_field").from("now"))
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
} }
); );
assertThat(e.getCause(), instanceOf(IllegalArgumentException.class)); assertThat(e.getCause(), instanceOf(IllegalArgumentException.class));
e = expectThrows(MapperParsingException.class, () -> { e = expectThrows(MapperParsingException.class, () -> {
mapperService.documentMapper(typeName).parse("test", typeName, "1", mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.field(fieldName, rangeQuery("date_field").to("now")) .field(fieldName, rangeQuery("date_field").to("now"))
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
} }
); );
assertThat(e.getCause(), instanceOf(IllegalArgumentException.class)); assertThat(e.getCause(), instanceOf(IllegalArgumentException.class));
@ -471,31 +498,39 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
public void testVerifyRangeQueryWithNullBounds() throws Exception { public void testVerifyRangeQueryWithNullBounds() throws Exception {
addQueryMapping(); addQueryMapping();
MapperParsingException e = expectThrows(MapperParsingException.class, () -> { MapperParsingException e = expectThrows(MapperParsingException.class, () -> {
mapperService.documentMapper(typeName).parse("test", typeName, "1", mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.field(fieldName, rangeQuery("date_field").from("now").to(null)) .field(fieldName, rangeQuery("date_field").from("now").to(null))
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
} }
); );
assertThat(e.getCause(), instanceOf(IllegalArgumentException.class)); assertThat(e.getCause(), instanceOf(IllegalArgumentException.class));
e = expectThrows(MapperParsingException.class, () -> { e = expectThrows(MapperParsingException.class, () -> {
mapperService.documentMapper(typeName).parse("test", typeName, "1", mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.field(fieldName, rangeQuery("date_field").from(null).to("now")) .field(fieldName, rangeQuery("date_field").from(null).to("now"))
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
} }
); );
assertThat(e.getCause(), instanceOf(IllegalArgumentException.class)); assertThat(e.getCause(), instanceOf(IllegalArgumentException.class));
// No validation failures: // No validation failures:
mapperService.documentMapper(typeName).parse("test", typeName, "1", mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.field(fieldName, rangeQuery("date_field").from("2016-01-01").to(null)) .field(fieldName, rangeQuery("date_field").from("2016-01-01").to(null))
.endObject().bytes()); .endObject().bytes(),
mapperService.documentMapper(typeName).parse("test", typeName, "1", XContentType.JSON));
mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
jsonBuilder().startObject() jsonBuilder().startObject()
.field(fieldName, rangeQuery("date_field").from(null).to("2016-01-01")) .field(fieldName, rangeQuery("date_field").from(null).to("2016-01-01"))
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
} }
public void testUnsupportedQueries() { public void testUnsupportedQueries() {
@ -570,10 +605,11 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
query.endObject(); query.endObject();
query.endObject(); query.endObject();
ParsedDocument doc = mapperService.documentMapper(typeName).parse("test", typeName, "1", ParsedDocument doc = mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
XContentFactory.jsonBuilder().startObject() XContentFactory.jsonBuilder().startObject()
.rawField(fieldName, new BytesArray(query.string()), query.contentType()) .rawField(fieldName, new BytesArray(query.string()), query.contentType())
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
BytesRef querySource = doc.rootDoc().getFields(fieldType.queryBuilderField.name())[0].binaryValue(); BytesRef querySource = doc.rootDoc().getFields(fieldType.queryBuilderField.name())[0].binaryValue();
Map<String, Object> parsedQuery = XContentHelper.convertToMap(new BytesArray(querySource), true).v2(); Map<String, Object> parsedQuery = XContentHelper.convertToMap(new BytesArray(querySource), true).v2();
assertEquals(Script.DEFAULT_SCRIPT_LANG, XContentMapValues.extractValue("script.script.lang", parsedQuery)); assertEquals(Script.DEFAULT_SCRIPT_LANG, XContentMapValues.extractValue("script.script.lang", parsedQuery));
@ -597,10 +633,11 @@ public class PercolatorFieldMapperTests extends ESSingleNodeTestCase {
query.endObject(); query.endObject();
query.endObject(); query.endObject();
doc = mapperService.documentMapper(typeName).parse("test", typeName, "1", doc = mapperService.documentMapper(typeName).parse(SourceToParse.source("test", typeName, "1",
XContentFactory.jsonBuilder().startObject() XContentFactory.jsonBuilder().startObject()
.rawField(fieldName, new BytesArray(query.string()), query.contentType()) .rawField(fieldName, new BytesArray(query.string()), query.contentType())
.endObject().bytes()); .endObject().bytes(),
XContentType.JSON));
querySource = doc.rootDoc().getFields(fieldType.queryBuilderField.name())[0].binaryValue(); querySource = doc.rootDoc().getFields(fieldType.queryBuilderField.name())[0].binaryValue();
parsedQuery = XContentHelper.convertToMap(new BytesArray(querySource), true).v2(); parsedQuery = XContentHelper.convertToMap(new BytesArray(querySource), true).v2();
assertEquals(Script.DEFAULT_SCRIPT_LANG, assertEquals(Script.DEFAULT_SCRIPT_LANG,

View File

@ -27,11 +27,13 @@ import org.elasticsearch.cluster.metadata.IndexMetaData;
import org.elasticsearch.common.compress.CompressedXContent; import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.IndexService; import org.elasticsearch.index.IndexService;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.DocumentMapperParser; import org.elasticsearch.index.mapper.DocumentMapperParser;
import org.elasticsearch.index.mapper.MapperParsingException; import org.elasticsearch.index.mapper.MapperParsingException;
import org.elasticsearch.index.mapper.ParsedDocument; import org.elasticsearch.index.mapper.ParsedDocument;
import org.elasticsearch.index.mapper.SourceToParse;
import org.elasticsearch.index.query.QueryShardContext; import org.elasticsearch.index.query.QueryShardContext;
import org.elasticsearch.indices.mapper.MapperRegistry; import org.elasticsearch.indices.mapper.MapperRegistry;
import org.elasticsearch.plugins.Plugin; import org.elasticsearch.plugins.Plugin;
@ -78,7 +80,11 @@ public class Murmur3FieldMapperTests extends ESSingleNodeTestCase {
.field("type", "murmur3") .field("type", "murmur3")
.endObject().endObject().endObject().endObject().string(); .endObject().endObject().endObject().endObject().string();
DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping)); DocumentMapper mapper = parser.parse("type", new CompressedXContent(mapping));
ParsedDocument parsedDoc = mapper.parse("test", "type", "1", XContentFactory.jsonBuilder().startObject().field("field", "value").endObject().bytes()); ParsedDocument parsedDoc = mapper.parse(SourceToParse.source("test", "type", "1", XContentFactory.jsonBuilder()
.startObject()
.field("field", "value")
.endObject().bytes(),
XContentType.JSON));
IndexableField[] fields = parsedDoc.rootDoc().getFields("field"); IndexableField[] fields = parsedDoc.rootDoc().getFields("field");
assertNotNull(fields); assertNotNull(fields);
assertEquals(Arrays.toString(fields), 1, fields.length); assertEquals(Arrays.toString(fields), 1, fields.length);