tests: Always make ovsdb-server exit cleanly, to better find memory leaks.
[cascardo/ovs.git] / tests / ovsdb-idl.at
1 AT_BANNER([OVSDB -- interface description language (IDL)])
2
3 # OVSDB_CHECK_IDL(TITLE, [PRE-IDL-TXN], TRANSACTIONS, OUTPUT, [KEYWORDS])
4 #
5 # Creates a database with a schema derived from idltest.ovsidl, runs
6 # each PRE-IDL-TXN (if any), starts an ovsdb-server on that database,
7 # and runs "test-ovsdb idl" passing each of the TRANSACTIONS along.
8 #
9 # Checks that the overall output is OUTPUT.  Before comparison, the
10 # output is sorted (using "sort") and UUIDs in the output are replaced
11 # by markers of the form <N> where N is a number.  The first unique
12 # UUID is replaced by <0>, the next by <1>, and so on.  If a given
13 # UUID appears more than once it is always replaced by the same
14 # marker.
15 #
16 # TITLE is provided to AT_SETUP and KEYWORDS to AT_KEYWORDS.
17 m4_define([OVSDB_CHECK_IDL], 
18   [AT_SETUP([$1])
19    AT_KEYWORDS([ovsdb server idl positive $5])
20    AT_CHECK([ovsdb-tool create db $abs_srcdir/idltest.ovsschema],
21                   [0], [stdout], [ignore])
22    AT_CHECK([ovsdb-server '-vPATTERN:console:ovsdb-server|%c|%m' --detach --pidfile=$PWD/pid --remote=punix:socket --unixctl=$PWD/unixctl db], [0], [ignore], [ignore])
23    m4_if([$2], [], [],
24      [AT_CHECK([ovsdb-client transact unix:socket $2], [0], [ignore], [ignore], [kill `cat pid`])])
25    AT_CHECK([test-ovsdb '-vPATTERN:console:test-ovsdb|%c|%m' -vjsonrpc -t10 idl unix:socket $3], 
26             [0], [stdout], [ignore], [kill `cat pid`])
27    AT_CHECK([sort stdout | perl $srcdir/uuidfilt.pl], [0], [$4], [],
28             [kill `cat pid`])
29    OVSDB_SERVER_SHUTDOWN
30    AT_CLEANUP])
31
32 OVSDB_CHECK_IDL([simple idl, initially empty, no ops],
33   [],
34   [],
35   [000: empty
36 001: done
37 ])
38
39 OVSDB_CHECK_IDL([simple idl, initially empty, various ops],
40   [],
41   [['[{"op": "insert",
42        "table": "simple",
43        "row": {"i": 1,
44                "r": 2.0,
45                "b": true,
46                "s": "mystring",
47                "u": ["uuid", "84f5c8f5-ac76-4dbc-a24f-8860eb407fc1"],
48                "ia": ["set", [1, 2, 3]],
49                "ra": ["set", [-0.5]],
50                "ba": ["set", [true, false]],
51                "sa": ["set", ["abc", "def"]], 
52                "ua": ["set", [["uuid", "69443985-7806-45e2-b35f-574a04e720f9"],
53                               ["uuid", "aad11ef0-816a-4b01-93e6-03b8b4256b98"]]]}},
54       {"op": "insert",
55        "table": "simple",
56        "row": {}}]' \
57     '[{"op": "update",
58        "table": "simple",
59        "where": [],
60        "row": {"b": true}}]' \
61     '[{"op": "update",
62        "table": "simple",
63        "where": [],
64        "row": {"r": 123.5}}]' \
65     '[{"op": "insert",
66        "table": "simple",
67        "row": {"i": -1,
68                "r": 125,
69                "b": false,
70                "s": "",
71                "ia": ["set", [1]],
72                "ra": ["set", [1.5]],
73                "ba": ["set", [false]],
74                "sa": ["set", []], 
75                "ua": ["set", []]}}]' \
76     '[{"op": "update",
77        "table": "simple",
78        "where": [["i", "<", 1]],
79        "row": {"s": "newstring"}}]' \
80     '[{"op": "delete",
81        "table": "simple",
82        "where": [["i", "==", 0]]}]' \
83     'reconnect']],
84   [[000: empty
85 001: {"error":null,"result":[{"uuid":["uuid","<0>"]},{"uuid":["uuid","<1>"]}]}
86 002: i=0 r=0 b=false s= u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
87 002: i=1 r=2 b=true s=mystring u=<3> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<4> <5>] uuid=<0>
88 003: {"error":null,"result":[{"count":2}]}
89 004: i=0 r=0 b=true s= u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
90 004: i=1 r=2 b=true s=mystring u=<3> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<4> <5>] uuid=<0>
91 005: {"error":null,"result":[{"count":2}]}
92 006: i=0 r=123.5 b=true s= u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
93 006: i=1 r=123.5 b=true s=mystring u=<3> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<4> <5>] uuid=<0>
94 007: {"error":null,"result":[{"uuid":["uuid","<6>"]}]}
95 008: i=-1 r=125 b=false s= u=<2> ia=[1] ra=[1.5] ba=[false] sa=[] ua=[] uuid=<6>
96 008: i=0 r=123.5 b=true s= u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
97 008: i=1 r=123.5 b=true s=mystring u=<3> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<4> <5>] uuid=<0>
98 009: {"error":null,"result":[{"count":2}]}
99 010: i=-1 r=125 b=false s=newstring u=<2> ia=[1] ra=[1.5] ba=[false] sa=[] ua=[] uuid=<6>
100 010: i=0 r=123.5 b=true s=newstring u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
101 010: i=1 r=123.5 b=true s=mystring u=<3> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<4> <5>] uuid=<0>
102 011: {"error":null,"result":[{"count":1}]}
103 012: i=-1 r=125 b=false s=newstring u=<2> ia=[1] ra=[1.5] ba=[false] sa=[] ua=[] uuid=<6>
104 012: i=1 r=123.5 b=true s=mystring u=<3> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<4> <5>] uuid=<0>
105 013: reconnect
106 014: i=-1 r=125 b=false s=newstring u=<2> ia=[1] ra=[1.5] ba=[false] sa=[] ua=[] uuid=<6>
107 014: i=1 r=123.5 b=true s=mystring u=<3> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<4> <5>] uuid=<0>
108 015: done
109 ]])
110
111 OVSDB_CHECK_IDL([simple idl, initially populated],
112   [['[{"op": "insert",
113        "table": "simple",
114        "row": {"i": 1,
115                "r": 2.0,
116                "b": true,
117                "s": "mystring",
118                "u": ["uuid", "84f5c8f5-ac76-4dbc-a24f-8860eb407fc1"],
119                "ia": ["set", [1, 2, 3]],
120                "ra": ["set", [-0.5]],
121                "ba": ["set", [true, false]],
122                "sa": ["set", ["abc", "def"]], 
123                "ua": ["set", [["uuid", "69443985-7806-45e2-b35f-574a04e720f9"],
124                               ["uuid", "aad11ef0-816a-4b01-93e6-03b8b4256b98"]]]}},
125       {"op": "insert",
126        "table": "simple",
127        "row": {}}]']],
128   [['[{"op": "update",
129        "table": "simple",
130        "where": [],
131        "row": {"b": true}}]']],
132   [[000: i=0 r=0 b=false s= u=<0> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
133 000: i=1 r=2 b=true s=mystring u=<2> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<3> <4>] uuid=<5>
134 001: {"error":null,"result":[{"count":2}]}
135 002: i=0 r=0 b=true s= u=<0> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
136 002: i=1 r=2 b=true s=mystring u=<2> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<3> <4>] uuid=<5>
137 003: done
138 ]])
139
140 OVSDB_CHECK_IDL([simple idl, writing via IDL],
141   [['[{"op": "insert",
142        "table": "simple",
143        "row": {"i": 1,
144                "r": 2.0,
145                "b": true,
146                "s": "mystring",
147                "u": ["uuid", "84f5c8f5-ac76-4dbc-a24f-8860eb407fc1"],
148                "ia": ["set", [1, 2, 3]],
149                "ra": ["set", [-0.5]],
150                "ba": ["set", [true, false]],
151                "sa": ["set", ["abc", "def"]], 
152                "ua": ["set", [["uuid", "69443985-7806-45e2-b35f-574a04e720f9"],
153                               ["uuid", "aad11ef0-816a-4b01-93e6-03b8b4256b98"]]]}},
154       {"op": "insert",
155        "table": "simple",
156        "row": {}}]']],
157   [['set 0 b 1, set 1 r 3.5' \
158     'insert 2, delete 1']],
159   [[000: i=0 r=0 b=false s= u=<0> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
160 000: i=1 r=2 b=true s=mystring u=<2> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<3> <4>] uuid=<5>
161 001: commit, status=success
162 002: i=0 r=0 b=true s= u=<0> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
163 002: i=1 r=3.5 b=true s=mystring u=<2> ia=[1 2 3] ra=[-0.5] ba=[false true] sa=[abc def] ua=[<3> <4>] uuid=<5>
164 003: commit, status=success
165 004: i=0 r=0 b=true s= u=<0> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
166 004: i=2 r=0 b=false s= u=<0> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<6>
167 005: done
168 ]])
169
170 OVSDB_CHECK_IDL([simple idl, increment operation],
171   [['[{"op": "insert",
172        "table": "simple",
173        "row": {}}]']],
174   [['set 0 r 2.0, increment simple i']],
175   [[000: i=0 r=0 b=false s= u=<0> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
176 001: commit, status=success, increment=1
177 002: i=1 r=2 b=false s= u=<0> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<1>
178 003: done
179 ]])
180
181 OVSDB_CHECK_IDL([self-linking idl, consistent ops],
182   [],
183   [['[{"op": "insert",
184        "table": "link1",
185        "row": {"i": 0, "k": ["named-uuid", "self"]},
186        "uuid-name": "self"}]' \
187     '[{"op": "declare",
188        "uuid-name": "row1"},
189       {"op": "declare",
190        "uuid-name": "row2"},
191       {"op": "insert",
192        "table": "link1",
193        "row": {"i": 1, "k": ["named-uuid", "row2"]},
194        "uuid-name": "row1"},
195       {"op": "insert",
196        "table": "link1",
197        "row": {"i": 2, "k": ["named-uuid", "row1"]},
198        "uuid-name": "row2"}]' \
199     '[{"op": "update",
200        "table": "link1",
201        "where": [["i", "==", 1]],
202        "row": {"k": ["uuid", "#1#"]}}]' \
203     '[{"op": "update",
204        "table": "link1",
205        "where": [],
206        "row": {"k": ["uuid", "#0#"]}}]']],
207   [[000: empty
208 001: {"error":null,"result":[{"uuid":["uuid","<0>"]}]}
209 002: i=0 k=0 ka=[] l2= uuid=<0>
210 003: {"error":null,"result":[{"uuid":"<1>"},{"uuid":"<2>"},{"uuid":["uuid","<1>"]},{"uuid":["uuid","<2>"]}]}
211 004: i=0 k=0 ka=[] l2= uuid=<0>
212 004: i=1 k=2 ka=[] l2= uuid=<1>
213 004: i=2 k=1 ka=[] l2= uuid=<2>
214 005: {"error":null,"result":[{"count":1}]}
215 006: i=0 k=0 ka=[] l2= uuid=<0>
216 006: i=1 k=1 ka=[] l2= uuid=<1>
217 006: i=2 k=1 ka=[] l2= uuid=<2>
218 007: {"error":null,"result":[{"count":3}]}
219 008: i=0 k=0 ka=[] l2= uuid=<0>
220 008: i=1 k=0 ka=[] l2= uuid=<1>
221 008: i=2 k=0 ka=[] l2= uuid=<2>
222 009: done
223 ]])
224
225 OVSDB_CHECK_IDL([self-linking idl, inconsistent ops],
226   [],
227   [['[{"op": "insert",
228        "table": "link1",
229        "row": {"i": 0, "k": ["uuid", "cf197cc5-c8c9-42f5-82d5-c71a9f2cb96b"]}}]' \
230      '[{"op": "update",
231        "table": "link1",
232        "where": [],
233        "row": {"k": ["uuid", "#0#"]}}]' \
234      '[{"op": "update",
235        "table": "link1",
236        "where": [],
237        "row": {"k": ["uuid", "c2fca39a-e69a-42a4-9c56-5eca85839ce9"]}}]' \
238      '[{"op": "insert",
239        "table": "link1",
240        "row": {"i": 1, "k": ["uuid", "52d752a3-b062-4668-9446-d2e0d4a14703"]}}]' \
241      '[{"op": "update",
242        "table": "link1",
243        "where": [],
244        "row": {"k": ["uuid", "#1#"]}}]' \
245 ]],
246   [[000: empty
247 001: {"error":null,"result":[{"uuid":["uuid","<0>"]}]}
248 002: i=0 k= ka=[] l2= uuid=<0>
249 003: {"error":null,"result":[{"count":1}]}
250 004: i=0 k=0 ka=[] l2= uuid=<0>
251 005: {"error":null,"result":[{"count":1}]}
252 006: i=0 k= ka=[] l2= uuid=<0>
253 007: {"error":null,"result":[{"uuid":["uuid","<1>"]}]}
254 008: i=0 k= ka=[] l2= uuid=<0>
255 008: i=1 k= ka=[] l2= uuid=<1>
256 009: {"error":null,"result":[{"count":2}]}
257 010: i=0 k=1 ka=[] l2= uuid=<0>
258 010: i=1 k=1 ka=[] l2= uuid=<1>
259 011: done
260 ]])
261
262 OVSDB_CHECK_IDL([self-linking idl, sets],
263   [],
264   [['[{"op": "insert",
265        "table": "link1",
266        "row": {"i": 0, "ka": ["set", [["named-uuid", "i0"]]]},
267        "uuid-name": "i0"},
268       {"op": "insert",
269        "table": "link1",
270        "row": {"i": 1, "ka": ["set", [["named-uuid", "i1"]]]},
271        "uuid-name": "i1"},
272       {"op": "insert",
273        "table": "link1",
274        "row": {"i": 2, "ka": ["set", [["named-uuid", "i2"]]]},
275        "uuid-name": "i2"},
276       {"op": "insert",
277        "table": "link1",
278        "row": {"i": 3, "ka": ["set", [["named-uuid", "i3"]]]},
279        "uuid-name": "i3"}]' \
280     '[{"op": "update",
281        "table": "link1",
282        "where": [],
283        "row": {"ka": ["set", [["uuid", "#0#"], ["uuid", "#1#"], ["uuid", "#2#"], ["uuid", "#3#"]]]}}]' \
284     '[{"op": "update",
285        "table": "link1",
286        "where": [],
287        "row": {"ka": ["set", [["uuid", "#0#"], ["uuid", "88702e78-845b-4a6e-ad08-cf68922ae84a"], ["uuid", "#2#"], ["uuid", "1ac2b12e-b767-4805-a55d-43976e40c465"]]]}}]']],
288   [[000: empty
289 001: {"error":null,"result":[{"uuid":["uuid","<0>"]},{"uuid":["uuid","<1>"]},{"uuid":["uuid","<2>"]},{"uuid":["uuid","<3>"]}]}
290 002: i=0 k= ka=[0] l2= uuid=<0>
291 002: i=1 k= ka=[1] l2= uuid=<1>
292 002: i=2 k= ka=[2] l2= uuid=<2>
293 002: i=3 k= ka=[3] l2= uuid=<3>
294 003: {"error":null,"result":[{"count":4}]}
295 004: i=0 k= ka=[0 1 2 3] l2= uuid=<0>
296 004: i=1 k= ka=[0 1 2 3] l2= uuid=<1>
297 004: i=2 k= ka=[0 1 2 3] l2= uuid=<2>
298 004: i=3 k= ka=[0 1 2 3] l2= uuid=<3>
299 005: {"error":null,"result":[{"count":4}]}
300 006: i=0 k= ka=[0 2] l2= uuid=<0>
301 006: i=1 k= ka=[0 2] l2= uuid=<1>
302 006: i=2 k= ka=[0 2] l2= uuid=<2>
303 006: i=3 k= ka=[0 2] l2= uuid=<3>
304 007: done
305 ]])
306
307 OVSDB_CHECK_IDL([external-linking idl, consistent ops],
308   [],
309   [['[{"op": "insert",
310        "table": "link2",
311        "row": {"i": 0},
312        "uuid-name": "row0"},
313       {"op": "insert",
314        "table": "link1",
315        "row": {"i": 1, "l2": ["set", [["named-uuid", "row0"]]]},
316        "uuid-name": "row1"}]']],
317   [[000: empty
318 001: {"error":null,"result":[{"uuid":["uuid","<0>"]},{"uuid":["uuid","<1>"]}]}
319 002: i=0 l1= uuid=<0>
320 002: i=1 k= ka=[] l2=0 uuid=<1>
321 003: done
322 ]])