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