From f96d7c284e5419827cd05cf9a26599dd9fb6461b Mon Sep 17 00:00:00 2001 From: Bas Passon Date: Thu, 21 Mar 2024 11:14:10 +0100 Subject: [PATCH] Added failing test and fix or issue #646 --- .../jackson/dataformat/xml/util/TypeUtil.java | 2 +- .../IterableCollectionBuilder646Test.java | 88 +++++++++++++++++++ 2 files changed, 89 insertions(+), 1 deletion(-) create mode 100644 src/test/java/com/fasterxml/jackson/dataformat/xml/failing/IterableCollectionBuilder646Test.java diff --git a/src/main/java/com/fasterxml/jackson/dataformat/xml/util/TypeUtil.java b/src/main/java/com/fasterxml/jackson/dataformat/xml/util/TypeUtil.java index fdfc8d242..d10793d1d 100644 --- a/src/main/java/com/fasterxml/jackson/dataformat/xml/util/TypeUtil.java +++ b/src/main/java/com/fasterxml/jackson/dataformat/xml/util/TypeUtil.java @@ -11,7 +11,7 @@ public class TypeUtil public static boolean isIndexedType(JavaType type) { Class cls = type.getRawClass(); - if (type.isContainerType() || type.isIterationType()) { + if (type.isContainerType() || type.isIterationType() || cls == Iterable.class) { // One special case; byte[] will be serialized as base64-encoded String, not real array, so: // (actually, ditto for char[]; thought to be a String) if (cls == byte[].class || cls == char[].class) { diff --git a/src/test/java/com/fasterxml/jackson/dataformat/xml/failing/IterableCollectionBuilder646Test.java b/src/test/java/com/fasterxml/jackson/dataformat/xml/failing/IterableCollectionBuilder646Test.java new file mode 100644 index 000000000..41bb509ea --- /dev/null +++ b/src/test/java/com/fasterxml/jackson/dataformat/xml/failing/IterableCollectionBuilder646Test.java @@ -0,0 +1,88 @@ +package com.fasterxml.jackson.dataformat.xml.failing; + +import java.util.ArrayList; +import java.util.List; + +import com.fasterxml.jackson.annotation.JsonProperty; +import com.fasterxml.jackson.databind.annotation.JsonDeserialize; +import com.fasterxml.jackson.dataformat.xml.XmlMapper; +import com.fasterxml.jackson.dataformat.xml.XmlTestBase; +import com.fasterxml.jackson.dataformat.xml.annotation.JacksonXmlElementWrapper; +import com.fasterxml.jackson.dataformat.xml.annotation.JacksonXmlRootElement; + +public class IterableCollectionBuilder646Test extends XmlTestBase { + + @JsonDeserialize(builder = Parent.Builder.class) + @JacksonXmlRootElement(localName = "parent") + static class Parent { + private final List children; + + private Parent(List children) { + this.children = children; + } + + @JsonProperty("child") + @JacksonXmlElementWrapper(useWrapping = false) + public List getChildren() { + return children; + } + + static class Builder { + private final List children = new ArrayList<>(); + + @JsonProperty("child") + @JacksonXmlElementWrapper(useWrapping = false) + public Builder children(Iterable children) { + for (Child c : children) { + this.children.add(c); + } + return this; + } + + public Parent build() { + return new Parent(children); + } + } + } + + @JsonDeserialize(builder = Child.Builder.class) + @JacksonXmlRootElement(localName = "child") + static class Child { + private final String id; + + public Child(String id) { + this.id = id; + } + + @JsonProperty("id") + public String getId() { + return id; + } + + static class Builder { + private String id; + + @JsonProperty("id") + public Builder id(String id) { + this.id = id; + return this; + } + + public Child build() { + return new Child(id); + } + } + } + + // -- Test Methods --// + private final XmlMapper MAPPER = newMapper(); + + public void testIssue646() throws Exception { + final String XML = "1"; + Parent parent = MAPPER.readValue(XML, Parent.class); + assertNotNull(parent); + assertNotNull(parent.getChildren()); + assertEquals(1, parent.getChildren().size()); + + } +}