Allow update of `eager_global_ordinals` on `_parent`. (#28014)
A bug introduced in #24407 currently prevents `eager_global_ordinals` from being updated. This new approach should fix the issue while still allowing mapping updates to not specify the `_parent` field if it doesn't need updating, which was the goal of #24407.
This commit is contained in:
parent
bd11e6c441
commit
77a7e2480b
|
@ -303,15 +303,16 @@ public class ParentFieldMapper extends MetadataFieldMapper {
|
||||||
@Override
|
@Override
|
||||||
protected void doMerge(Mapper mergeWith, boolean updateAllTypes) {
|
protected void doMerge(Mapper mergeWith, boolean updateAllTypes) {
|
||||||
ParentFieldMapper fieldMergeWith = (ParentFieldMapper) mergeWith;
|
ParentFieldMapper fieldMergeWith = (ParentFieldMapper) mergeWith;
|
||||||
ParentFieldType currentFieldType = (ParentFieldType) fieldType.clone();
|
|
||||||
super.doMerge(mergeWith, updateAllTypes);
|
|
||||||
if (fieldMergeWith.parentType != null && Objects.equals(parentType, fieldMergeWith.parentType) == false) {
|
if (fieldMergeWith.parentType != null && Objects.equals(parentType, fieldMergeWith.parentType) == false) {
|
||||||
throw new IllegalArgumentException("The _parent field's type option can't be changed: [" + parentType + "]->[" + fieldMergeWith.parentType + "]");
|
throw new IllegalArgumentException("The _parent field's type option can't be changed: [" + parentType + "]->[" + fieldMergeWith.parentType + "]");
|
||||||
}
|
}
|
||||||
|
// If fieldMergeWith is not active it means the user provided a mapping
|
||||||
if (active()) {
|
// update that does not explicitly configure the _parent field, so we
|
||||||
fieldType = currentFieldType;
|
// ignore it.
|
||||||
|
if (fieldMergeWith.active()) {
|
||||||
|
super.doMerge(mergeWith, updateAllTypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -41,6 +41,7 @@ import org.elasticsearch.test.ESSingleNodeTestCase;
|
||||||
import org.elasticsearch.test.IndexSettingsModule;
|
import org.elasticsearch.test.IndexSettingsModule;
|
||||||
import org.elasticsearch.test.InternalSettingsPlugin;
|
import org.elasticsearch.test.InternalSettingsPlugin;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
@ -138,4 +139,23 @@ public class ParentFieldMapperTests extends ESSingleNodeTestCase {
|
||||||
return numFieldWithParentPrefix;
|
return numFieldWithParentPrefix;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testUpdateEagerGlobalOrds() throws IOException {
|
||||||
|
String parentMapping = XContentFactory.jsonBuilder().startObject().startObject("parent_type")
|
||||||
|
.endObject().endObject().string();
|
||||||
|
String childMapping = XContentFactory.jsonBuilder().startObject().startObject("child_type")
|
||||||
|
.startObject("_parent").field("type", "parent_type").endObject()
|
||||||
|
.endObject().endObject().string();
|
||||||
|
IndexService indexService = createIndex("test", Settings.builder().put("index.version.created", Version.V_5_6_0).build());
|
||||||
|
indexService.mapperService().merge("parent_type", new CompressedXContent(parentMapping), MergeReason.MAPPING_UPDATE, false);
|
||||||
|
indexService.mapperService().merge("child_type", new CompressedXContent(childMapping), MergeReason.MAPPING_UPDATE, false);
|
||||||
|
|
||||||
|
assertTrue(indexService.mapperService().documentMapper("child_type").parentFieldMapper().fieldType().eagerGlobalOrdinals());
|
||||||
|
|
||||||
|
String childMappingUpdate = XContentFactory.jsonBuilder().startObject().startObject("child_type")
|
||||||
|
.startObject("_parent").field("type", "parent_type").field("eager_global_ordinals", false).endObject()
|
||||||
|
.endObject().endObject().string();
|
||||||
|
indexService.mapperService().merge("child_type", new CompressedXContent(childMappingUpdate), MergeReason.MAPPING_UPDATE, false);
|
||||||
|
|
||||||
|
assertFalse(indexService.mapperService().documentMapper("child_type").parentFieldMapper().fieldType().eagerGlobalOrdinals());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue