From 5329b0011d20bf2e7624ab79089c33ecd35a5221 Mon Sep 17 00:00:00 2001 From: Charlie La Mothe Date: Mon, 12 Jan 2015 17:50:36 +0700 Subject: [PATCH 1/2] Added a failing test case for issue #51. --- .../datatype/joda/JodaSerializationTest.java | 23 ++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/src/test/java/com/fasterxml/jackson/datatype/joda/JodaSerializationTest.java b/src/test/java/com/fasterxml/jackson/datatype/joda/JodaSerializationTest.java index 1b707504..71f909ea 100644 --- a/src/test/java/com/fasterxml/jackson/datatype/joda/JodaSerializationTest.java +++ b/src/test/java/com/fasterxml/jackson/datatype/joda/JodaSerializationTest.java @@ -1,7 +1,10 @@ package com.fasterxml.jackson.datatype.joda; import java.io.IOException; +import java.util.HashMap; +import java.util.Map; +import com.fasterxml.jackson.annotation.JsonInclude; import org.joda.time.*; import com.fasterxml.jackson.annotation.JsonTypeInfo; @@ -70,8 +73,14 @@ public void testLocalDateSer() throws IOException ObjectMapper mapper = jodaMapper(); mapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false); assertEquals(quote("2001-05-25"), mapper.writeValueAsString(date)); + + // We can also configure beans to not include empty values. In this case, + // JodaDateSerializerBase#isEmpty is called to check if the value is empty. + mapper = jodaMapper(); + mapper.setSerializationInclusion(JsonInclude.Include.NON_EMPTY); + assertEquals("{\"contents\":[2001,5,25]}", mapper.writeValueAsString(new Container(date))); } - + public void testLocalDateSerWithTypeInfo() throws IOException { LocalDate date = new LocalDate(2001, 5, 25); @@ -229,4 +238,16 @@ public void testYearMonthSer() throws Exception assertEquals(quote("2013-08"), json); } + private static class Container { + T contents; + + public Container(T contents) { + this.contents = contents; + } + + public T getContents() { + return contents; + } + } + } From aff2c7f33d513f7577810ca8d4c26a13ee9f42a8 Mon Sep 17 00:00:00 2001 From: Charlie La Mothe Date: Mon, 12 Jan 2015 17:51:19 +0700 Subject: [PATCH 2/2] Fixed issue #51: StackOverflowError resulting from any call to JodaDateSerializerBase#isEmpty. --- .../jackson/datatype/joda/ser/JodaDateSerializerBase.java | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/main/java/com/fasterxml/jackson/datatype/joda/ser/JodaDateSerializerBase.java b/src/main/java/com/fasterxml/jackson/datatype/joda/ser/JodaDateSerializerBase.java index 73e831ac..613069ea 100644 --- a/src/main/java/com/fasterxml/jackson/datatype/joda/ser/JodaDateSerializerBase.java +++ b/src/main/java/com/fasterxml/jackson/datatype/joda/ser/JodaDateSerializerBase.java @@ -47,7 +47,12 @@ protected JodaDateSerializerBase(Class type, JacksonJodaDateFormat format, public final boolean isEmpty(T value) { return isEmpty(null, value); } - + + @Override + public boolean isEmpty(SerializerProvider prov, T value) { + return value == null; + } + @Override public JsonSerializer createContextual(SerializerProvider prov, BeanProperty property) throws JsonMappingException