forked from FasterXML/jackson-databind
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTestPOJOAsArrayWithBuilder.java
215 lines (181 loc) · 6.01 KB
/
TestPOJOAsArrayWithBuilder.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
package tools.jackson.databind.struct;
import org.junit.jupiter.api.Test;
import com.fasterxml.jackson.annotation.*;
import tools.jackson.databind.*;
import tools.jackson.databind.annotation.JsonDeserialize;
import tools.jackson.databind.exc.InvalidDefinitionException;
import tools.jackson.databind.exc.MismatchedInputException;
import tools.jackson.databind.testutil.DatabindTestUtil;
import static org.junit.jupiter.api.Assertions.*;
/**
* Unit tests for "POJO as array" feature using Builder-style
* POJO construction.
*/
public class TestPOJOAsArrayWithBuilder extends DatabindTestUtil
{
@JsonDeserialize(builder=SimpleBuilderXY.class)
@JsonFormat(shape=JsonFormat.Shape.ARRAY)
@JsonPropertyOrder(alphabetic=true)
static class ValueClassXY
{
final int _x, _y;
protected ValueClassXY(int x, int y) {
_x = x+1;
_y = y+1;
}
}
@JsonFormat(shape=JsonFormat.Shape.ARRAY)
@JsonPropertyOrder(alphabetic=true)
static class SimpleBuilderXY
{
public int x, y;
protected SimpleBuilderXY() { }
protected SimpleBuilderXY(int x0, int y0) {
x = x0;
y = y0;
}
public SimpleBuilderXY withX(int x0) {
this.x = x0;
return this;
}
public SimpleBuilderXY withY(int y0) {
this.y = y0;
return this;
}
public ValueClassXY build() {
return new ValueClassXY(x, y);
}
}
// Also, with creator:
@JsonDeserialize(builder=CreatorBuilder.class)
@JsonFormat(shape=JsonFormat.Shape.ARRAY)
@JsonPropertyOrder(alphabetic=true)
static class CreatorValue
{
final int a, b, c;
protected CreatorValue(int a, int b, int c) {
this.a = a;
this.b = b;
this.c = c;
}
}
@JsonFormat(shape=JsonFormat.Shape.ARRAY)
static class CreatorBuilder {
private final int a, b;
private int c;
@JsonCreator
public CreatorBuilder(@JsonProperty("a") int a,
@JsonProperty("b") int b)
{
this.a = a;
this.b = b;
}
@JsonView(String.class)
public CreatorBuilder withC(int v) {
c = v;
return this;
}
public CreatorValue build() {
return new CreatorValue(a, b, c);
}
}
/*
/*****************************************************
/* Basic tests
/*****************************************************
*/
private final static ObjectMapper MAPPER = newJsonMapper();
@Test
public void testSimpleBuilder() throws Exception
{
// Ok, first, ensure that serializer will "black out" filtered properties
ValueClassXY value = MAPPER.readValue("[1,2]", ValueClassXY.class);
assertEquals(2, value._x);
assertEquals(3, value._y);
}
// Won't work, but verify exception
@Test
public void testBuilderWithUpdate() throws Exception
{
// Ok, first, simple case of all values being present
try {
/*value =*/ MAPPER.readerFor(ValueClassXY.class)
.withValueToUpdate(new ValueClassXY(6, 7))
.readValue("[1,2]");
fail("Should not pass");
} catch (InvalidDefinitionException e) {
verifyException(e, "Deserialization of");
verifyException(e, "by passing existing instance");
verifyException(e, "ValueClassXY");
}
}
/*
/*****************************************************
/* Creator test(s)
/*****************************************************
*/
// test to ensure @JsonCreator also works
@Test
public void testWithCreator() throws Exception
{
CreatorValue value = MAPPER.readValue("[1,2,3]", CreatorValue.class);
assertEquals(1, value.a);
assertEquals(2, value.b);
assertEquals(3, value.c);
// and should be ok with partial too?
value = MAPPER.readValue("[1,2]", CreatorValue.class);
assertEquals(1, value.a);
assertEquals(2, value.b);
assertEquals(0, value.c);
value = MAPPER.readValue("[1]", CreatorValue.class);
assertEquals(1, value.a);
assertEquals(0, value.b);
assertEquals(0, value.c);
value = MAPPER.readValue("[]", CreatorValue.class);
assertEquals(0, value.a);
assertEquals(0, value.b);
assertEquals(0, value.c);
}
@Test
public void testWithCreatorAndView() throws Exception
{
ObjectReader reader = MAPPER.readerFor(CreatorValue.class);
CreatorValue value;
// First including values in view
value = reader.withView(String.class).readValue("[1,2,3]");
assertEquals(1, value.a);
assertEquals(2, value.b);
assertEquals(3, value.c);
// then not including view
value = reader.withView(Character.class).readValue("[1,2,3]");
assertEquals(1, value.a);
assertEquals(2, value.b);
assertEquals(0, value.c);
}
/*
/*****************************************************
/* Failure tests
/*****************************************************
*/
@Test
public void testUnknownExtraProp() throws Exception
{
String json = "[1, 2, 3, 4]";
try {
MAPPER.readerFor(ValueClassXY.class)
.with(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES)
.readValue(json);
fail("should not pass with extra element");
} catch (MismatchedInputException e) {
verifyException(e, "Unexpected JSON values");
}
// but actually fine if skip-unknown set
ValueClassXY v = MAPPER.readerFor(ValueClassXY.class)
.without(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES)
.readValue(json);
assertNotNull(v);
// note: +1 for both so
assertEquals(v._x, 2);
assertEquals(v._y, 3);
}
}