|
3 | 3 | import java.util.*;
|
4 | 4 |
|
5 | 5 | import com.fasterxml.jackson.annotation.JsonPropertyOrder;
|
6 |
| - |
| 6 | +import com.fasterxml.jackson.annotation.JsonRootName; |
7 | 7 | import com.fasterxml.jackson.dataformat.xml.XmlMapper;
|
8 | 8 | import com.fasterxml.jackson.dataformat.xml.XmlTestBase;
|
9 | 9 | import com.fasterxml.jackson.dataformat.xml.annotation.JacksonXmlElementWrapper;
|
|
13 | 13 | // needed, alas
|
14 | 14 | public class ListDeser469FailingTest extends XmlTestBase
|
15 | 15 | {
|
16 |
| - static class OuterBean { |
17 |
| - public MiddleBean middle; |
18 |
| - } |
19 |
| - |
20 | 16 | @JsonPropertyOrder({"inner1", "inner2"})
|
21 |
| - static class MiddleBean |
| 17 | + @JsonRootName("outer") |
| 18 | + static class Outer469 |
22 | 19 | {
|
23 | 20 | public InnerBean1 inner1;
|
24 | 21 |
|
@@ -64,40 +61,35 @@ public void testIssue469WithDefaults() throws Exception
|
64 | 61 | final XmlMapper mapper = newMapper();
|
65 | 62 |
|
66 | 63 | // First: create POJO value to test round-trip:
|
67 |
| - { |
68 |
| - OuterBean source = new OuterBean(); |
69 |
| - source.middle = new MiddleBean(); |
| 64 | + if (true) { |
| 65 | + Outer469 source = new Outer469(); |
70 | 66 | List<InnerBean2> items = new ArrayList<>();
|
71 | 67 | items.add(new InnerBean2("foo"));
|
72 |
| - source.middle.inner2 = items; |
| 68 | + source.inner2 = items; |
73 | 69 |
|
74 | 70 | String xml = mapper.writerWithDefaultPrettyPrinter()
|
75 | 71 | .writeValueAsString(source);
|
| 72 | +//System.err.println("XML: \n"+xml); |
| 73 | + Outer469 result = mapper.readValue(xml, Outer469.class); |
76 | 74 |
|
77 |
| - OuterBean result = mapper.readValue(xml, OuterBean.class); |
78 |
| - |
79 |
| - MiddleBean mid = result.middle; |
80 |
| - assertNotNull(mid); |
81 |
| - assertNotNull(mid.inner2); |
82 |
| - assertEquals(1, mid.inner2.size()); |
83 |
| - assertEquals("foo", mid.inner2.get(0).str2); |
| 75 | + assertNotNull(result); |
| 76 | + assertNotNull(result.inner2); |
| 77 | + assertEquals(1, result.inner2.size()); |
| 78 | + assertEquals("foo", result.inner2.get(0).str2); |
84 | 79 | }
|
85 | 80 |
|
86 | 81 | // And then verify from XML String
|
87 |
| - String xmlInput = "<OuterBean>\n" + |
88 |
| - " <middle>\n" + |
89 |
| - " <inner1/>\n" + |
90 |
| - " <inner2 str2='aaaa'/>\n" + |
91 |
| - " </middle>\n" + |
92 |
| - "</OuterBean>\n"; |
93 |
| - |
94 |
| - OuterBean outer = mapper.readValue(xmlInput, OuterBean.class); |
95 |
| - |
96 |
| - MiddleBean mid = outer.middle; |
97 |
| - assertNotNull(mid); |
98 |
| - |
99 |
| - assertNotNull(mid.inner2); |
100 |
| - assertEquals(1, mid.inner2.size()); |
101 |
| - assertEquals("aaaa", mid.inner2.get(0).str2); |
| 82 | + String xmlInput = |
| 83 | + "<outer>\n" + |
| 84 | + " <inner1/>\n" + |
| 85 | + " <inner2 str2='aaaa'/>\n" + |
| 86 | + "</outer>\n"; |
| 87 | + |
| 88 | + Outer469 result = mapper.readValue(xmlInput, Outer469.class); |
| 89 | + assertNotNull(result); |
| 90 | + |
| 91 | + assertNotNull(result.inner2); |
| 92 | + assertEquals(1, result.inner2.size()); |
| 93 | + assertEquals("aaaa", result.inner2.get(0).str2); |
102 | 94 | }
|
103 | 95 | }
|
0 commit comments