Merge pull request #18194 from rjernst/null_ip_default
Mappings: Fix ip mapper to correctly serialize a null null_value
This commit is contained in:
commit
10e3b37875
|
@ -396,7 +396,11 @@ public class IpFieldMapper extends FieldMapper implements AllFieldMapper.Include
|
|||
super.doXContentBody(builder, includeDefaults, params);
|
||||
|
||||
if (includeDefaults || fieldType().nullValue() != null) {
|
||||
builder.field("null_value", InetAddresses.toAddrString((InetAddress) fieldType().nullValue()));
|
||||
Object nullValue = fieldType().nullValue();
|
||||
if (nullValue != null) {
|
||||
nullValue = InetAddresses.toAddrString((InetAddress) nullValue);
|
||||
}
|
||||
builder.field("null_value", nullValue);
|
||||
}
|
||||
|
||||
if (includeDefaults || ignoreMalformed.explicit()) {
|
||||
|
|
|
@ -25,6 +25,8 @@ import org.apache.lucene.index.IndexableField;
|
|||
import org.apache.lucene.util.BytesRef;
|
||||
import org.elasticsearch.common.compress.CompressedXContent;
|
||||
import org.elasticsearch.common.network.InetAddresses;
|
||||
import org.elasticsearch.common.xcontent.ToXContent;
|
||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||
import org.elasticsearch.common.xcontent.XContentFactory;
|
||||
import org.elasticsearch.index.IndexService;
|
||||
import org.elasticsearch.index.mapper.DocumentMapper;
|
||||
|
@ -269,4 +271,22 @@ public class IpFieldMapperTests extends ESSingleNodeTestCase {
|
|||
assertEquals(new BytesRef(InetAddressPoint.encode(InetAddresses.forString("::1"))), dvField.binaryValue());
|
||||
assertFalse(dvField.fieldType().stored());
|
||||
}
|
||||
|
||||
public void testSerializeDefaults() throws Exception {
|
||||
String mapping = XContentFactory.jsonBuilder().startObject().startObject("type")
|
||||
.startObject("properties").startObject("field").field("type", "ip").endObject().endObject()
|
||||
.endObject().endObject().string();
|
||||
|
||||
DocumentMapper docMapper = parser.parse("type", new CompressedXContent(mapping));
|
||||
IpFieldMapper mapper = (IpFieldMapper)docMapper.root().getMapper("field");
|
||||
XContentBuilder builder = XContentFactory.jsonBuilder().startObject();
|
||||
mapper.doXContentBody(builder, true, ToXContent.EMPTY_PARAMS);
|
||||
String got = builder.endObject().string();
|
||||
|
||||
// it would be nice to check the entire serialized default mapper, but there are
|
||||
// a whole lot of bogus settings right now it picks up from calling super.doXContentBody...
|
||||
assertTrue(got, got.contains("\"null_value\":null"));
|
||||
assertTrue(got, got.contains("\"ignore_malformed\":false"));
|
||||
assertTrue(got, got.contains("\"include_in_all\":false"));
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue