Skip to content

Commit dd03e13

Browse files
kostyakostya
kostya
authored and
kostya
committed
Add: additional tests
1 parent 022ad9e commit dd03e13

File tree

2 files changed

+413
-0
lines changed

2 files changed

+413
-0
lines changed

tests.js

Lines changed: 398 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,398 @@
1+
[
2+
{ "comment": "empty list, empty docs",
3+
"doc": {},
4+
"patch": [],
5+
"expected": {} },
6+
7+
{ "comment": "empty patch list",
8+
"doc": {"foo": 1},
9+
"patch": [],
10+
"expected": {"foo": 1} },
11+
12+
{ "comment": "rearrangements OK?",
13+
"doc": {"foo": 1, "bar": 2},
14+
"patch": [],
15+
"expected": {"bar":2, "foo": 1} },
16+
17+
{ "comment": "rearrangements OK? How about one level down ... array",
18+
"doc": [{"foo": 1, "bar": 2}],
19+
"patch": [],
20+
"expected": [{"bar":2, "foo": 1}] },
21+
22+
{ "comment": "rearrangements OK? How about one level down...",
23+
"doc": {"foo":{"foo": 1, "bar": 2}},
24+
"patch": [],
25+
"expected": {"foo":{"bar":2, "foo": 1}} },
26+
27+
{ "comment": "add replaces any existing field",
28+
"doc": {"foo": null},
29+
"patch": [{"op": "add", "path": "/foo", "value":1}],
30+
"expected": {"foo": 1} },
31+
32+
{ "comment": "toplevel array",
33+
"doc": [],
34+
"patch": [{"op": "add", "path": "/0", "value": "foo"}],
35+
"expected": ["foo"] },
36+
37+
{ "comment": "toplevel array, no change",
38+
"doc": ["foo"],
39+
"patch": [],
40+
"expected": ["foo"] },
41+
42+
{ "comment": "toplevel object, numeric string",
43+
"doc": {},
44+
"patch": [{"op": "add", "path": "/foo", "value": "1"}],
45+
"expected": {"foo":"1"} },
46+
47+
{ "comment": "toplevel object, integer",
48+
"doc": {},
49+
"patch": [{"op": "add", "path": "/foo", "value": 1}],
50+
"expected": {"foo":1} },
51+
52+
{ "comment": "Toplevel scalar values OK?",
53+
"doc": "foo",
54+
"patch": [{"op": "replace", "path": "", "value": "bar"}],
55+
"expected": "bar",
56+
"disabled": true },
57+
58+
{ "comment": "Add, / target",
59+
"doc": {},
60+
"patch": [ {"op": "add", "path": "/", "value":1 } ],
61+
"expected": {"":1} },
62+
63+
{ "comment": "Add, /foo/ deep target (trailing slash)",
64+
"doc": {"foo": {}},
65+
"patch": [ {"op": "add", "path": "/foo/", "value":1 } ],
66+
"expected": {"foo":{"": 1}} },
67+
68+
{ "comment": "Add composite value at top level",
69+
"doc": {"foo": 1},
70+
"patch": [{"op": "add", "path": "/bar", "value": [1, 2]}],
71+
"expected": {"foo": 1, "bar": [1, 2]} },
72+
73+
{ "comment": "Add into composite value",
74+
"doc": {"foo": 1, "baz": [{"qux": "hello"}]},
75+
"patch": [{"op": "add", "path": "/baz/0/foo", "value": "world"}],
76+
"expected": {"foo": 1, "baz": [{"qux": "hello", "foo": "world"}]} },
77+
78+
{ "doc": {"bar": [1, 2]},
79+
"patch": [{"op": "add", "path": "/bar/8", "value": "5"}],
80+
"error": "Out of bounds (upper)" },
81+
82+
{ "doc": {"bar": [1, 2]},
83+
"patch": [{"op": "add", "path": "/bar/-1", "value": "5"}],
84+
"error": "Out of bounds (lower)" },
85+
86+
{ "doc": {"foo": 1},
87+
"patch": [{"op": "add", "path": "/bar", "value": true}],
88+
"expected": {"foo": 1, "bar": true} },
89+
90+
{ "doc": {"foo": 1},
91+
"patch": [{"op": "add", "path": "/bar", "value": false}],
92+
"expected": {"foo": 1, "bar": false} },
93+
94+
{ "doc": {"foo": 1},
95+
"patch": [{"op": "add", "path": "/bar", "value": null}],
96+
"expected": {"foo": 1, "bar": null} },
97+
98+
{ "comment": "0 can be an array index or object element name",
99+
"doc": {"foo": 1},
100+
"patch": [{"op": "add", "path": "/0", "value": "bar"}],
101+
"expected": {"foo": 1, "0": "bar" } },
102+
103+
{ "doc": ["foo"],
104+
"patch": [{"op": "add", "path": "/1", "value": "bar"}],
105+
"expected": ["foo", "bar"] },
106+
107+
{ "doc": ["foo", "sil"],
108+
"patch": [{"op": "add", "path": "/1", "value": "bar"}],
109+
"expected": ["foo", "bar", "sil"] },
110+
111+
{ "doc": ["foo", "sil"],
112+
"patch": [{"op": "add", "path": "/0", "value": "bar"}],
113+
"expected": ["bar", "foo", "sil"] },
114+
115+
{ "comment": "push item to array via last index + 1",
116+
"doc": ["foo", "sil"],
117+
"patch": [{"op":"add", "path": "/2", "value": "bar"}],
118+
"expected": ["foo", "sil", "bar"] },
119+
120+
{ "comment": "add item to array at index > length should fail",
121+
"doc": ["foo", "sil"],
122+
"patch": [{"op":"add", "path": "/3", "value": "bar"}],
123+
"error": "index is greater than number of items in array" },
124+
125+
{ "comment": "test against implementation-specific numeric parsing",
126+
"doc": {"1e0": "foo"},
127+
"patch": [{"op": "test", "path": "/1e0", "value": "foo"}],
128+
"expected": {"1e0": "foo"} },
129+
130+
{ "comment": "test with bad number should fail",
131+
"doc": ["foo", "bar"],
132+
"patch": [{"op": "test", "path": "/1e0", "value": "bar"}],
133+
"error": "test op shouldn't get array element 1" },
134+
135+
{ "doc": ["foo", "sil"],
136+
"patch": [{"op": "add", "path": "/bar", "value": 42}],
137+
"error": "Object operation on array target" },
138+
139+
{ "doc": ["foo", "sil"],
140+
"patch": [{"op": "add", "path": "/1", "value": ["bar", "baz"]}],
141+
"expected": ["foo", ["bar", "baz"], "sil"],
142+
"comment": "value in array add not flattened" },
143+
144+
{ "doc": {"foo": 1, "bar": [1, 2, 3, 4]},
145+
"patch": [{"op": "remove", "path": "/bar"}],
146+
"expected": {"foo": 1} },
147+
148+
{ "doc": {"foo": 1, "baz": [{"qux": "hello"}]},
149+
"patch": [{"op": "remove", "path": "/baz/0/qux"}],
150+
"expected": {"foo": 1, "baz": [{}]} },
151+
152+
{ "doc": {"foo": 1, "baz": [{"qux": "hello"}]},
153+
"patch": [{"op": "replace", "path": "/foo", "value": [1, 2, 3, 4]}],
154+
"expected": {"foo": [1, 2, 3, 4], "baz": [{"qux": "hello"}]} },
155+
156+
{ "doc": {"foo": [1, 2, 3, 4], "baz": [{"qux": "hello"}]},
157+
"patch": [{"op": "replace", "path": "/baz/0/qux", "value": "world"}],
158+
"expected": {"foo": [1, 2, 3, 4], "baz": [{"qux": "world"}]} },
159+
160+
{ "doc": ["foo"],
161+
"patch": [{"op": "replace", "path": "/0", "value": "bar"}],
162+
"expected": ["bar"] },
163+
164+
{ "doc": [""],
165+
"patch": [{"op": "replace", "path": "/0", "value": 0}],
166+
"expected": [0] },
167+
168+
{ "doc": [""],
169+
"patch": [{"op": "replace", "path": "/0", "value": true}],
170+
"expected": [true] },
171+
172+
{ "doc": [""],
173+
"patch": [{"op": "replace", "path": "/0", "value": false}],
174+
"expected": [false] },
175+
176+
{ "doc": [""],
177+
"patch": [{"op": "replace", "path": "/0", "value": null}],
178+
"expected": [null] },
179+
180+
{ "doc": ["foo", "sil"],
181+
"patch": [{"op": "replace", "path": "/1", "value": ["bar", "baz"]}],
182+
"expected": ["foo", ["bar", "baz"]],
183+
"comment": "value in array replace not flattened" },
184+
185+
{ "comment": "replace whole document",
186+
"doc": {"foo": "bar"},
187+
"patch": [{"op": "replace", "path": "", "value": {"baz": "qux"}}],
188+
"expected": {"baz": "qux"} },
189+
190+
{ "comment": "spurious patch properties",
191+
"doc": {"foo": 1},
192+
"patch": [{"op": "test", "path": "/foo", "value": 1, "spurious": 1}],
193+
"expected": {"foo": 1} },
194+
195+
{ "doc": {"foo": null},
196+
"patch": [{"op": "test", "path": "/foo", "value": null}],
197+
"comment": "null value should be valid obj property" },
198+
199+
{ "doc": {"foo": null},
200+
"patch": [{"op": "replace", "path": "/foo", "value": "truthy"}],
201+
"expected": {"foo": "truthy"},
202+
"comment": "null value should be valid obj property to be replaced with something truthy" },
203+
204+
{ "doc": {"foo": null},
205+
"patch": [{"op": "move", "from": "/foo", "path": "/bar"}],
206+
"expected": {"bar": null},
207+
"comment": "null value should be valid obj property to be moved" },
208+
209+
{ "doc": {"foo": null},
210+
"patch": [{"op": "copy", "from": "/foo", "path": "/bar"}],
211+
"expected": {"foo": null, "bar": null},
212+
"comment": "null value should be valid obj property to be copied" },
213+
214+
{ "doc": {"foo": null},
215+
"patch": [{"op": "remove", "path": "/foo"}],
216+
"expected": {},
217+
"comment": "null value should be valid obj property to be removed" },
218+
219+
{ "doc": {"foo": "bar"},
220+
"patch": [{"op": "replace", "path": "/foo", "value": null}],
221+
"expected": {"foo": null},
222+
"comment": "null value should still be valid obj property replace other value" },
223+
224+
{ "doc": {"foo": {"foo": 1, "bar": 2}},
225+
"patch": [{"op": "test", "path": "/foo", "value": {"bar": 2, "foo": 1}}],
226+
"comment": "test should pass despite rearrangement" },
227+
228+
{ "doc": {"foo": [{"foo": 1, "bar": 2}]},
229+
"patch": [{"op": "test", "path": "/foo", "value": [{"bar": 2, "foo": 1}]}],
230+
"comment": "test should pass despite (nested) rearrangement" },
231+
232+
{ "doc": {"foo": {"bar": [1, 2, 5, 4]}},
233+
"patch": [{"op": "test", "path": "/foo", "value": {"bar": [1, 2, 5, 4]}}],
234+
"comment": "test should pass - no error" },
235+
236+
{ "doc": {"foo": {"bar": [1, 2, 5, 4]}},
237+
"patch": [{"op": "test", "path": "/foo", "value": [1, 2]}],
238+
"error": "test op should fail" },
239+
240+
{ "comment": "Whole document",
241+
"doc": { "foo": 1 },
242+
"patch": [{"op": "test", "path": "", "value": {"foo": 1}}],
243+
"disabled": true },
244+
245+
{ "comment": "Empty-string element",
246+
"doc": { "": 1 },
247+
"patch": [{"op": "test", "path": "/", "value": 1}] },
248+
249+
{ "doc": {
250+
"foo": ["bar", "baz"],
251+
"": 0,
252+
"a/b": 1,
253+
"c%d": 2,
254+
"e^f": 3,
255+
"g|h": 4,
256+
"i\\j": 5,
257+
"k\"l": 6,
258+
" ": 7,
259+
"m~n": 8
260+
},
261+
"patch": [{"op": "test", "path": "/foo", "value": ["bar", "baz"]},
262+
{"op": "test", "path": "/foo/0", "value": "bar"},
263+
{"op": "test", "path": "/", "value": 0},
264+
{"op": "test", "path": "/a~1b", "value": 1},
265+
{"op": "test", "path": "/c%d", "value": 2},
266+
{"op": "test", "path": "/e^f", "value": 3},
267+
{"op": "test", "path": "/g|h", "value": 4},
268+
{"op": "test", "path": "/i\\j", "value": 5},
269+
{"op": "test", "path": "/k\"l", "value": 6},
270+
{"op": "test", "path": "/ ", "value": 7},
271+
{"op": "test", "path": "/m~0n", "value": 8}] },
272+
273+
{ "comment": "Move to same location has no effect",
274+
"doc": {"foo": 1},
275+
"patch": [{"op": "move", "from": "/foo", "path": "/foo"}],
276+
"expected": {"foo": 1} },
277+
278+
{ "doc": {"foo": 1, "baz": [{"qux": "hello"}]},
279+
"patch": [{"op": "move", "from": "/foo", "path": "/bar"}],
280+
"expected": {"baz": [{"qux": "hello"}], "bar": 1} },
281+
282+
{ "doc": {"baz": [{"qux": "hello"}], "bar": 1},
283+
"patch": [{"op": "move", "from": "/baz/0/qux", "path": "/baz/1"}],
284+
"expected": {"baz": [{}, "hello"], "bar": 1} },
285+
286+
{ "doc": {"baz": [{"qux": "hello"}], "bar": 1},
287+
"patch": [{"op": "copy", "from": "/baz/0", "path": "/boo"}],
288+
"expected": {"baz":[{"qux":"hello"}],"bar":1,"boo":{"qux":"hello"}} },
289+
290+
{ "comment": "replacing the root of the document is possible with add",
291+
"doc": {"foo": "bar"},
292+
"patch": [{"op": "add", "path": "", "value": {"baz": "qux"}}],
293+
"expected": {"baz":"qux"}},
294+
295+
{ "comment": "Adding to \"/-\" adds to the end of the array",
296+
"doc": [ 1, 2 ],
297+
"patch": [ { "op": "add", "path": "/-", "value": { "foo": [ "bar", "baz" ] } } ],
298+
"expected": [ 1, 2, { "foo": [ "bar", "baz" ] } ]},
299+
300+
{ "comment": "Adding to \"/-\" adds to the end of the array, even n levels down",
301+
"doc": [ 1, 2, [ 3, [ 4, 5 ] ] ],
302+
"patch": [ { "op": "add", "path": "/2/1/-", "value": { "foo": [ "bar", "baz" ] } } ],
303+
"expected": [ 1, 2, [ 3, [ 4, 5, { "foo": [ "bar", "baz" ] } ] ] ]},
304+
305+
{ "comment": "test remove with bad number should fail",
306+
"doc": {"foo": 1, "baz": [{"qux": "hello"}]},
307+
"patch": [{"op": "remove", "path": "/baz/1e0/qux"}],
308+
"error": "remove op shouldn't remove from array with bad number" },
309+
310+
{ "comment": "test remove on array",
311+
"doc": [1, 2, 3, 4],
312+
"patch": [{"op": "remove", "path": "/0"}],
313+
"expected": [2, 3, 4] },
314+
315+
{ "comment": "test repeated removes",
316+
"doc": [1, 2, 3, 4],
317+
"patch": [{ "op": "remove", "path": "/1" },
318+
{ "op": "remove", "path": "/2" }],
319+
"expected": [1, 3] },
320+
321+
{ "comment": "test remove with bad index should fail",
322+
"doc": [1, 2, 3, 4],
323+
"patch": [{"op": "remove", "path": "/1e0"}],
324+
"error": "remove op shouldn't remove from array with bad number" },
325+
326+
{ "comment": "test replace with bad number should fail",
327+
"doc": [""],
328+
"patch": [{"op": "replace", "path": "/1e0", "value": false}],
329+
"error": "replace op shouldn't replace in array with bad number" },
330+
331+
{ "comment": "test copy with bad number should fail",
332+
"doc": {"baz": [1,2,3], "bar": 1},
333+
"patch": [{"op": "copy", "from": "/baz/1e0", "path": "/boo"}],
334+
"error": "copy op shouldn't work with bad number" },
335+
336+
{ "comment": "test move with bad number should fail",
337+
"doc": {"foo": 1, "baz": [1,2,3,4]},
338+
"patch": [{"op": "move", "from": "/baz/1e0", "path": "/foo"}],
339+
"error": "move op shouldn't work with bad number" },
340+
341+
{ "comment": "test add with bad number should fail",
342+
"doc": ["foo", "sil"],
343+
"patch": [{"op": "add", "path": "/1e0", "value": "bar"}],
344+
"error": "add op shouldn't add to array with bad number" },
345+
346+
{ "comment": "missing 'value' parameter to add",
347+
"doc": [ 1 ],
348+
"patch": [ { "op": "add", "path": "/-" } ],
349+
"error": "missing 'value' parameter" },
350+
351+
{ "comment": "missing 'value' parameter to replace",
352+
"doc": [ 1 ],
353+
"patch": [ { "op": "replace", "path": "/0" } ],
354+
"error": "missing 'value' parameter" },
355+
356+
{ "comment": "missing 'value' parameter to test",
357+
"doc": [ null ],
358+
"patch": [ { "op": "test", "path": "/0" } ],
359+
"error": "missing 'value' parameter" },
360+
361+
{ "comment": "missing value parameter to test - where undef is falsy",
362+
"doc": [ false ],
363+
"patch": [ { "op": "test", "path": "/0" } ],
364+
"error": "missing 'value' parameter" },
365+
366+
{ "comment": "missing from parameter to copy",
367+
"doc": [ 1 ],
368+
"patch": [ { "op": "copy", "path": "/-" } ],
369+
"error": "missing 'from' parameter" },
370+
371+
{ "comment": "missing from parameter to move",
372+
"doc": { "foo": 1 },
373+
"patch": [ { "op": "move", "path": "" } ],
374+
"error": "missing 'from' parameter" },
375+
376+
{ "comment": "duplicate ops",
377+
"doc": { "foo": "bar" },
378+
"patch": [ { "op": "add", "path": "/baz", "value": "qux",
379+
"op": "move", "from":"/foo" } ],
380+
"error": "patch has two 'op' members",
381+
"disabled": true },
382+
383+
{ "comment": "unrecognized op should fail",
384+
"doc": {"foo": 1},
385+
"patch": [{"op": "spam", "path": "/foo", "value": 1}],
386+
"error": "Unrecognized op 'spam'" },
387+
388+
{ "comment": "test with bad array number that has leading zeros",
389+
"doc": ["foo", "bar"],
390+
"patch": [{"op": "test", "path": "/00", "value": "foo"}],
391+
"error": "test op should reject the array value, it has leading zeros" },
392+
393+
{ "comment": "test with bad array number that has leading zeros",
394+
"doc": ["foo", "bar"],
395+
"patch": [{"op": "test", "path": "/01", "value": "bar"}],
396+
"error": "test op should reject the array value, it has leading zeros" }
397+
398+
]

0 commit comments

Comments
 (0)