XContentHelper.mergeDefaults with single key object list ([ { key: .. } , {key : ... } .. ] ) didn't add defaults which were not already in content
Closes #3538
This commit is contained in:
parent
7f7f79d622
commit
11fab5c66f
|
@ -233,6 +233,9 @@ public class XContentHelper {
|
||||||
Map.Entry<String, Object> entry = map.entrySet().iterator().next();
|
Map.Entry<String, Object> entry = map.entrySet().iterator().next();
|
||||||
if (processed.containsKey(entry.getKey())) {
|
if (processed.containsKey(entry.getKey())) {
|
||||||
mergeDefaults(processed.get(entry.getKey()), map);
|
mergeDefaults(processed.get(entry.getKey()), map);
|
||||||
|
} else {
|
||||||
|
// put the default entries after the content ones.
|
||||||
|
processed.put(entry.getKey(), map);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (Map<String, Object> map : processed.values()) {
|
for (Map<String, Object> map : processed.values()) {
|
||||||
|
|
|
@ -0,0 +1,69 @@
|
||||||
|
package org.elasticsearch.test.unit.common.xcontent.support;
|
||||||
|
/*
|
||||||
|
* Licensed to ElasticSearch under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. ElasticSearch licenses this
|
||||||
|
* file to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
import org.elasticsearch.common.xcontent.XContentHelper;
|
||||||
|
import org.hamcrest.Matchers;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static org.hamcrest.MatcherAssert.assertThat;
|
||||||
|
|
||||||
|
public class XContentHelperTests {
|
||||||
|
|
||||||
|
Map<String, Object> getMap(Object... keyValues) {
|
||||||
|
Map<String, Object> map = new HashMap<String, Object>();
|
||||||
|
for (int i = 0; i < keyValues.length; i++) {
|
||||||
|
map.put((String) keyValues[i], keyValues[++i]);
|
||||||
|
}
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, Object> getNamedMap(String name, Object... keyValues) {
|
||||||
|
Map<String, Object> map = getMap(keyValues);
|
||||||
|
|
||||||
|
Map<String, Object> namedMap = new HashMap<String, Object>(1);
|
||||||
|
namedMap.put(name, map);
|
||||||
|
return namedMap;
|
||||||
|
}
|
||||||
|
|
||||||
|
List<Object> getList(Object... values) {
|
||||||
|
return Arrays.asList(values);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testMergingListValuesAreMapsOfOne() {
|
||||||
|
|
||||||
|
Map<String, Object> defaults = getMap("test", getList(getNamedMap("name1", "t1", "1"), getNamedMap("name2", "t2", "2")));
|
||||||
|
Map<String, Object> content = getMap("test", getList(getNamedMap("name2", "t3", "3"), getNamedMap("name4", "t4", "4")));
|
||||||
|
Map<String, Object> expected = getMap("test",
|
||||||
|
getList(getNamedMap("name2", "t2", "2", "t3", "3"), getNamedMap("name4", "t4", "4"), getNamedMap("name1", "t1", "1")));
|
||||||
|
|
||||||
|
XContentHelper.mergeDefaults(content, defaults);
|
||||||
|
|
||||||
|
assertThat(content, Matchers.equalTo(expected));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue