Mapping updates on objects should propagate `include_an_all`. #20051

Today you can't update `include_an_all` on an existing object. The bug affects
2.x too.
This commit is contained in:
Adrien Grand 2016-08-18 09:17:24 +02:00
parent 825edd8dba
commit 8f8ae8f577
2 changed files with 28 additions and 0 deletions

View File

@ -430,6 +430,7 @@ public class ObjectMapper extends Mapper implements Cloneable {
} }
} }
this.includeInAll = mergeWith.includeInAll;
if (mergeWith.dynamic != null) { if (mergeWith.dynamic != null) {
this.dynamic = mergeWith.dynamic; this.dynamic = mergeWith.dynamic;
} }

View File

@ -24,8 +24,12 @@ import org.elasticsearch.common.compress.CompressedXContent;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.index.mapper.DocumentMapper; import org.elasticsearch.index.mapper.DocumentMapper;
import org.elasticsearch.index.mapper.MapperParsingException; import org.elasticsearch.index.mapper.MapperParsingException;
import org.elasticsearch.index.mapper.MapperService.MergeReason;
import org.elasticsearch.index.mapper.ObjectMapper.Dynamic;
import org.elasticsearch.test.ESSingleNodeTestCase; import org.elasticsearch.test.ESSingleNodeTestCase;
import java.io.IOException;
import static org.hamcrest.Matchers.containsString; import static org.hamcrest.Matchers.containsString;
public class ObjectMapperTests extends ESSingleNodeTestCase { public class ObjectMapperTests extends ESSingleNodeTestCase {
@ -155,4 +159,27 @@ public class ObjectMapperTests extends ESSingleNodeTestCase {
.string(); .string();
createIndex("test").mapperService().documentMapperParser().parse("tweet", new CompressedXContent(mapping)); createIndex("test").mapperService().documentMapperParser().parse("tweet", new CompressedXContent(mapping));
} }
public void testMerge() throws IOException {
String mapping = XContentFactory.jsonBuilder().startObject()
.startObject("type")
.startObject("properties")
.startObject("foo")
.field("type", "keyword")
.endObject()
.endObject()
.endObject().endObject().string();
MapperService mapperService = createIndex("test").mapperService();
DocumentMapper mapper = mapperService.merge("type", new CompressedXContent(mapping), MergeReason.MAPPING_UPDATE, false);
assertNull(mapper.root().includeInAll());
assertNull(mapper.root().dynamic());
String update = XContentFactory.jsonBuilder().startObject()
.startObject("type")
.field("include_in_all", false)
.field("dynamic", "strict")
.endObject().endObject().string();
mapper = mapperService.merge("type", new CompressedXContent(update), MergeReason.MAPPING_UPDATE, false);
assertFalse(mapper.root().includeInAll());
assertEquals(Dynamic.STRICT, mapper.root().dynamic());
}
} }