|
7 | 7 |
|
8 | 8 | import com.fasterxml.jackson.annotation.JsonCreator; |
9 | 9 | import com.fasterxml.jackson.annotation.JsonGetter; |
| 10 | +import com.fasterxml.jackson.annotation.JsonIgnore; |
10 | 11 | import com.fasterxml.jackson.annotation.JsonProperty; |
11 | 12 |
|
12 | 13 | import com.fasterxml.jackson.core.type.TypeReference; |
|
16 | 17 | import com.fasterxml.jackson.databind.exc.ValueInstantiationException; |
17 | 18 | import com.fasterxml.jackson.databind.introspect.AnnotatedMethod; |
18 | 19 | import com.fasterxml.jackson.databind.module.SimpleModule; |
| 20 | +import com.fasterxml.jackson.databind.testutil.DatabindTestUtil; |
19 | 21 |
|
20 | 22 | import static org.junit.jupiter.api.Assertions.*; |
21 | 23 |
|
22 | | -import static com.fasterxml.jackson.databind.testutil.DatabindTestUtil.*; |
23 | | - |
24 | | -public class EnumCreatorTest |
| 24 | +public class EnumCreatorTest extends DatabindTestUtil |
25 | 25 | { |
26 | 26 | protected enum EnumWithCreator { |
27 | 27 | A, B; |
@@ -221,6 +221,35 @@ public static Enum3280 getByValue(@JsonProperty("b") String value) { |
221 | 221 | } |
222 | 222 | } |
223 | 223 |
|
| 224 | + static class DataClass4544 { |
| 225 | + public DataEnum4544 data; |
| 226 | + } |
| 227 | + |
| 228 | + public enum DataEnum4544 |
| 229 | + { |
| 230 | + TEST(0); |
| 231 | + |
| 232 | + private final int data; |
| 233 | + |
| 234 | + DataEnum4544(int data) { |
| 235 | + this.data = data; |
| 236 | + } |
| 237 | + |
| 238 | + // Important! Without ignoring accessor will find logical property |
| 239 | + // that matches Creator parameter... and assume properties-based |
| 240 | + @JsonIgnore |
| 241 | + public int getData() { |
| 242 | + return data; |
| 243 | + } |
| 244 | + |
| 245 | + @JsonCreator |
| 246 | + public static DataEnum4544 of(@ImplicitName("data") int data) { |
| 247 | + return Arrays.stream(values()) |
| 248 | + .filter(it -> it.getData() == data) |
| 249 | + .findAny().get(); |
| 250 | + } |
| 251 | + } |
| 252 | + |
224 | 253 | /* |
225 | 254 | /********************************************************** |
226 | 255 | /* Test methods |
@@ -393,4 +422,17 @@ public void testEnumsFromStringUnwrapped() throws Exception |
393 | 422 | assertEquals(TestEnumFromString.class, ob.getClass()); |
394 | 423 | assertSame(TestEnumFromString.ENUM_A, ob); |
395 | 424 | } |
| 425 | + |
| 426 | + // for [databind#4544] |
| 427 | + @Test |
| 428 | + void testEnumsWithImplicitNames4544() throws Exception { |
| 429 | + final ObjectMapper mapper = jsonMapperBuilder() |
| 430 | + .annotationIntrospector(new ImplicitNameIntrospector()) |
| 431 | + .build(); |
| 432 | + |
| 433 | + String json = a2q("{'data': 0}"); |
| 434 | + DataClass4544 data = mapper.readValue(json, DataClass4544.class); |
| 435 | + |
| 436 | + assertEquals(DataEnum4544.TEST, data.data); |
| 437 | + } |
396 | 438 | } |
0 commit comments