diff --git a/line-bot-model/src/main/java/com/linecorp/bot/model/narrowcast/recipient/Recipient.java b/line-bot-model/src/main/java/com/linecorp/bot/model/narrowcast/recipient/Recipient.java index 4e1fad1d1..dfab1690c 100644 --- a/line-bot-model/src/main/java/com/linecorp/bot/model/narrowcast/recipient/Recipient.java +++ b/line-bot-model/src/main/java/com/linecorp/bot/model/narrowcast/recipient/Recipient.java @@ -21,7 +21,7 @@ import com.fasterxml.jackson.annotation.JsonTypeInfo; import com.fasterxml.jackson.annotation.JsonTypeInfo.Id; -@JsonTypeInfo(use = Id.NAME, property = "type") +@JsonTypeInfo(use = Id.NAME, property = "type", include = JsonTypeInfo.As.EXISTING_PROPERTY) @JsonSubTypes({ @JsonSubTypes.Type(AudienceRecipient.class), @JsonSubTypes.Type(LogicalOperatorRecipient.class), diff --git a/line-bot-model/src/test/java/com/linecorp/bot/model/NarrowcastTest.java b/line-bot-model/src/test/java/com/linecorp/bot/model/NarrowcastTest.java index a42ce5704..9630d4ece 100644 --- a/line-bot-model/src/test/java/com/linecorp/bot/model/NarrowcastTest.java +++ b/line-bot-model/src/test/java/com/linecorp/bot/model/NarrowcastTest.java @@ -78,6 +78,18 @@ public void testRecipientDeserializeAudience() throws JsonProcessingException { assertThat(((AudienceRecipient) recipient).getAudienceGroupId()).isEqualTo(59693); } + @Test + public void testRecipientSerializeAudience() throws JsonProcessingException { + ObjectMapper objectMapper = ModelObjectMapper.createNewObjectMapper(); + String content = "{\"audienceGroupId\":59693,\"type\":\"audience\"}"; + Recipient recipient = objectMapper.readValue( + content, + Recipient.class); + assertThat(recipient).isInstanceOf(AudienceRecipient.class); + String json = objectMapper.writeValueAsString(recipient); + assertThat(json).isEqualTo(content); + } + @Test public void testRecipientDeserializeOperator() throws JsonProcessingException { ObjectMapper objectMapper = ModelObjectMapper.createNewObjectMapper();