ovs-vsctl: Add "wait-until" command.
[sliver-openvswitch.git] / tests / ovs-vsctl.at
1 dnl OVS_VSCTL_SETUP
2 dnl
3 dnl Creates an empty database in the current directory and then starts
4 dnl an ovsdb-server on it for ovs-vsctl to connect to.
5 m4_define([OVS_VSCTL_SETUP],
6   [OVSDB_INIT([db])
7    AT_CHECK([ovsdb-server --detach --pidfile=$PWD/pid --remote=punix:socket --unixctl=$PWD/unixctl db >/dev/null 2>&1], [0], [ignore], [ignore])])
8
9 dnl OVS_VSCTL_CLEANUP
10 dnl
11 dnl Kills off the database server.
12 m4_define([OVS_VSCTL_CLEANUP], [OVSDB_SERVER_SHUTDOWN])
13
14 dnl RUN_OVS_VSCTL(COMMAND, ...)
15 dnl
16 dnl Executes each ovs-vsctl COMMAND.
17 m4_define([RUN_OVS_VSCTL],
18   [m4_foreach([command], [$@], [ovs-vsctl --no-wait -vreconnect:ANY:emer --db=unix:socket -- command
19 ])])
20 m4_define([RUN_OVS_VSCTL_ONELINE],
21   [m4_foreach([command], [$@], [ovs-vsctl --no-wait -vreconnect:ANY:emer --db=unix:socket --oneline -- command
22 ])])
23
24 dnl RUN_OVS_VSCTL_TOGETHER(COMMAND, ...)
25 dnl
26 dnl Executes each ovs-vsctl COMMAND in a single run of ovs-vsctl.
27 m4_define([RUN_OVS_VSCTL_TOGETHER],
28   [ovs-vsctl --no-wait -vreconnect:ANY:emer --db=unix:socket --oneline dnl
29 m4_foreach([command], [$@], [ -- command])])
30
31 dnl CHECK_BRIDGES([BRIDGE, PARENT, VLAN], ...)
32 dnl
33 dnl Verifies that "ovs-vsctl list-br" prints the specified list of bridges,
34 dnl which must be in alphabetical order.  Also checks that each BRIDGE has the
35 dnl specified PARENT and is on the given VLAN.
36 m4_define([_CHECK_BRIDGE],
37   [AT_CHECK([RUN_OVS_VSCTL([br-to-parent $1])], [0], [$2
38 ], [], [OVS_VSCTL_CLEANUP])
39
40    # Check br-to-vlan, without --oneline.
41    AT_CHECK([RUN_OVS_VSCTL([br-to-vlan $1])], [0], [$3
42 ], [], [OVS_VSCTL_CLEANUP])
43    # Check br-to-vlan, with --oneline.
44    # (This particular test is interesting with --oneline because it returns
45    # an integer instead of a string and that can cause type mismatches inside
46    # python if not done carefully.)
47    AT_CHECK([RUN_OVS_VSCTL_ONELINE([br-to-vlan $1])], [0], [$3
48 ], [], [OVS_VSCTL_CLEANUP])
49
50    # Check multiple queries in a single run.
51    AT_CHECK([RUN_OVS_VSCTL_TOGETHER([br-to-parent $1], [br-to-vlan $1])], [0],
52 [$2
53 $3
54 ], [], [OVS_VSCTL_CLEANUP])])
55 m4_define([CHECK_BRIDGES],
56   [dnl Check that the bridges appear on list-br, without --oneline.
57    AT_CHECK(
58      [RUN_OVS_VSCTL([list-br])],
59      [0],
60      [m4_foreach([brinfo], [$@], [m4_car(brinfo)
61 ])],
62      [],
63      [OVS_VSCTL_CLEANUP])
64
65    dnl Check that the bridges appear on list-br, with --oneline.
66    AT_CHECK(
67      [RUN_OVS_VSCTL_ONELINE([list-br])],
68      [0],
69      [m4_join([\n], m4_foreach([brinfo], [$@], [m4_car(brinfo),]))
70 ],
71      [],
72      [OVS_VSCTL_CLEANUP])
73
74    dnl Check that each bridge exists according to br-exists and that
75    dnl a bridge that should not exist does not.
76    m4_foreach([brinfo], [$@], 
77               [AT_CHECK([RUN_OVS_VSCTL([br-exists m4_car(brinfo)])], [0], [],
78                         [], [OVS_VSCTL_CLEANUP])])
79    AT_CHECK([RUN_OVS_VSCTL([br-exists nonexistent])], [2], [], [],
80             [OVS_VSCTL_CLEANUP])
81
82    dnl Check that each bridge has the expected parent and VLAN.
83    m4_map([_CHECK_BRIDGE], [$@])])
84
85 dnl CHECK_PORTS(BRIDGE, PORT[, PORT...])
86 dnl
87 dnl Verifies that "ovs-vsctl list-ports BRIDGE" prints the specified
88 dnl list of ports, which must be in alphabetical order.  Also checks
89 dnl that "ovs-vsctl port-to-br" reports that each port is
90 dnl in BRIDGE.
91 m4_define([CHECK_PORTS],
92   [dnl Check ports without --oneline.
93    AT_CHECK(
94      [RUN_OVS_VSCTL([list-ports $1])],
95      [0],
96      [m4_foreach([port], m4_cdr($@), [port
97 ])],
98      [],
99      [OVS_VSCTL_CLEANUP])
100
101    dnl Check ports with --oneline.
102    AT_CHECK(
103      [RUN_OVS_VSCTL_ONELINE([list-ports $1])],
104      [0],
105      [m4_join([\n], m4_shift($@))
106 ],
107      [],
108      [OVS_VSCTL_CLEANUP])
109    AT_CHECK([RUN_OVS_VSCTL([port-to-br $1])], [1], [],
110             [ovs-vsctl: no port named $1
111 ],
112             [OVS_VSCTL_CLEANUP])
113    m4_foreach(
114      [port], m4_cdr($@), 
115      [AT_CHECK([RUN_OVS_VSCTL([[port-to-br] port])], [0], [$1
116 ], [], [OVS_VSCTL_CLEANUP])])])
117
118 dnl CHECK_IFACES(BRIDGE, IFACE[, IFACE...])
119 dnl
120 dnl Verifies that "ovs-vsctl list-ifaces BRIDGE" prints the specified
121 dnl list of ifaces, which must be in alphabetical order.  Also checks
122 dnl that "ovs-vsctl iface-to-br" reports that each interface is
123 dnl in BRIDGE.
124 m4_define([CHECK_IFACES],
125   [AT_CHECK(
126      [RUN_OVS_VSCTL([list-ifaces $1])],
127      [0],
128      [m4_foreach([iface], m4_cdr($@), [iface
129 ])],
130      [],
131      [OVS_VSCTL_CLEANUP])
132    AT_CHECK([RUN_OVS_VSCTL([iface-to-br $1])], [1], [],
133             [ovs-vsctl: no interface named $1
134 ],
135             [OVS_VSCTL_CLEANUP])
136    m4_foreach(
137      [iface], m4_cdr($@), 
138      [AT_CHECK([RUN_OVS_VSCTL([[iface-to-br] iface])], [0], [$1
139 ],
140                [], [OVS_VSCTL_CLEANUP])])])
141
142 dnl ----------------------------------------------------------------------
143 AT_BANNER([ovs-vsctl unit tests -- real bridges])
144
145 AT_SETUP([add-br a])
146 AT_KEYWORDS([ovs-vsctl])
147 OVS_VSCTL_SETUP
148 AT_CHECK([RUN_OVS_VSCTL([add-br a])], [0], [], [], [OVS_VSCTL_CLEANUP])
149 CHECK_BRIDGES([a, a, 0])
150 CHECK_PORTS([a])
151 CHECK_IFACES([a])
152 OVS_VSCTL_CLEANUP
153 AT_CLEANUP
154
155 AT_SETUP([add-br a, add-br a])
156 AT_KEYWORDS([ovs-vsctl])
157 OVS_VSCTL_SETUP
158 AT_CHECK([RUN_OVS_VSCTL([add-br a])], [0], [], [], [OVS_VSCTL_CLEANUP])
159 AT_CHECK([RUN_OVS_VSCTL([add-br a])], [1], [],
160   [ovs-vsctl: cannot create a bridge named a because a bridge named a already exists
161 ], [OVS_VSCTL_CLEANUP])
162 OVS_VSCTL_CLEANUP
163 AT_CLEANUP
164
165 AT_SETUP([add-br a, add-br b])
166 AT_KEYWORDS([ovs-vsctl])
167 OVS_VSCTL_SETUP
168 AT_CHECK([RUN_OVS_VSCTL([add-br a], [add-br b])], [0], [], [],
169          [OVS_VSCTL_CLEANUP])
170 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-br a b 9])], [1], [],
171   [ovs-vsctl: "--may-exist add-br a b 9" but a is not a VLAN bridge
172 ],
173   [OVS_VSCTL_CLEANUP])
174 CHECK_BRIDGES([a, a, 0], [b, b, 0])
175 CHECK_PORTS([a])
176 CHECK_IFACES([a])
177 CHECK_PORTS([b])
178 CHECK_IFACES([b])
179 OVS_VSCTL_CLEANUP
180 AT_CLEANUP
181
182 AT_SETUP([add-br a, add-br b, del-br a])
183 AT_KEYWORDS([ovs-vsctl])
184 OVS_VSCTL_SETUP
185 AT_CHECK([RUN_OVS_VSCTL([add-br a], [add-br b], [del-br a])], [0], [], [],
186          [OVS_VSCTL_CLEANUP])
187 CHECK_BRIDGES([b, b, 0])
188 CHECK_PORTS([b])
189 CHECK_IFACES([b])
190 OVS_VSCTL_CLEANUP
191 AT_CLEANUP
192
193 AT_SETUP([add-br a, add-port a a1, add-port a a2])
194 AT_KEYWORDS([ovs-vsctl])
195 OVS_VSCTL_SETUP
196 AT_CHECK([RUN_OVS_VSCTL(
197    [add-br a],
198    [--if-exists del-br b],
199    [add-port a a1],
200    [add-port a a2])], [0], [], [], [OVS_VSCTL_CLEANUP])
201 CHECK_BRIDGES([a, a, 0])
202 CHECK_PORTS([a], [a1], [a2])
203 CHECK_IFACES([a], [a1], [a2])
204 OVS_VSCTL_CLEANUP
205 AT_CLEANUP
206
207 AT_SETUP([add-br a, add-port a a1, add-port a a1])
208 AT_KEYWORDS([ovs-vsctl])
209 OVS_VSCTL_SETUP
210 AT_CHECK([RUN_OVS_VSCTL(
211    [add-br a], 
212    [add-port a a1])], [0], [], [], [OVS_VSCTL_CLEANUP])
213 AT_CHECK([RUN_OVS_VSCTL([add-port a a1])], [1], [],
214   [ovs-vsctl: cannot create a port named a1 because a port named a1 already exists on bridge a
215 ], [OVS_VSCTL_CLEANUP])
216 OVS_VSCTL_CLEANUP
217 AT_CLEANUP
218
219 AT_SETUP([add-br a b, add-port a a1, add-port b b1, del-br a])
220 AT_KEYWORDS([ovs-vsctl])
221 OVS_VSCTL_SETUP
222 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
223    [add-br a], 
224    [add-br b], 
225    [add-port a a1],
226    [add-port b b1],
227    [--if-exists del-port b b2],
228    [del-br a])], [0], [
229
230
231
232
233
234 ], [], [OVS_VSCTL_CLEANUP])
235 CHECK_BRIDGES([b, b, 0])
236 CHECK_PORTS([b], [b1])
237 CHECK_IFACES([b], [b1])
238 OVS_VSCTL_CLEANUP
239 AT_CLEANUP
240
241 AT_SETUP([add-br a, add-bond a bond0 a1 a2 a3])
242 AT_KEYWORDS([ovs-vsctl])
243 OVS_VSCTL_SETUP
244 AT_CHECK([RUN_OVS_VSCTL(
245    [add-br a], 
246    [add-bond a bond0 a1 a2 a3])], [0], [], [], [OVS_VSCTL_CLEANUP])
247 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-bond a bond0 a3 a1 a2])], [0], [], [],
248   [OVS_VSCTL_CLEANUP])
249 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-bond a bond0 a2 a1])], [1], [], 
250   [ovs-vsctl: "--may-exist add-bond a bond0 a2 a1" but bond0 actually has interface(s) a1, a2, a3
251 ],
252   [OVS_VSCTL_CLEANUP])
253 CHECK_BRIDGES([a, a, 0])
254 CHECK_PORTS([a], [bond0])
255 CHECK_IFACES([a], [a1], [a2], [a3])
256 OVS_VSCTL_CLEANUP
257 AT_CLEANUP
258
259 AT_SETUP([add-br a b, add-port a a1, add-port b b1, del-port a a1])
260 AT_KEYWORDS([ovs-vsctl])
261 OVS_VSCTL_SETUP
262 AT_CHECK([RUN_OVS_VSCTL(
263   [add-br a], 
264   [add-br b], 
265   [add-port a a1 tag=9],
266   [get port a1 tag],
267   [--may-exist add-port b b1],
268   [del-port a a1])], [0], [9
269 ], [], [OVS_VSCTL_CLEANUP])
270 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-port b b1])], [0], [], [],
271   [OVS_VSCTL_CLEANUP])
272 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-port a b1])], [1], [], 
273   [ovs-vsctl: "--may-exist add-port a b1" but b1 is actually attached to bridge b
274 ],
275   [OVS_VSCTL_CLEANUP])
276 CHECK_BRIDGES([a, a, 0], [b, b, 0])
277 CHECK_PORTS([a])
278 CHECK_IFACES([a])
279 CHECK_PORTS([b], [b1])
280 CHECK_IFACES([b], [b1])
281 OVS_VSCTL_CLEANUP
282 AT_CLEANUP
283
284 AT_SETUP([add-br a, add-bond a bond0 a1 a2 a3, del-port bond0])
285 AT_KEYWORDS([ovs-vsctl])
286 OVS_VSCTL_SETUP
287 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
288   [add-br a], 
289   [add-bond a bond0 a1 a2 a3 tag=9],
290   [get Port bond0 tag],
291   [del-port bond0])], [0], [
292
293 9
294
295 ], [], [OVS_VSCTL_CLEANUP])
296 CHECK_BRIDGES([a, a, 0])
297 CHECK_PORTS([a])
298 OVS_VSCTL_CLEANUP
299 AT_CLEANUP
300
301 AT_SETUP([external IDs])
302 AT_KEYWORDS([ovs-vsctl])
303 OVS_VSCTL_SETUP
304 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
305   [add-br a], 
306   [add-port a a1],
307   [add-bond a bond0 a2 a3],
308   [br-set-external-id a key0 value0],
309   [set port a1 external-ids:key1=value1],
310   [set interface a2 external-ids:key2=value2],
311   [set interface a2 external-ids:key3=value3],
312   [set interface a3 external-ids:key4=value4],
313   [br-get-external-id a],
314   [br-get-external-id a key0],
315   [br-get-external-id a key1],
316   [br-set-external-id a key0 othervalue],
317   [br-get-external-id a],
318   [br-set-external-id a key0],
319   [br-get-external-id a],
320   [get port a1 external-ids],
321   [get interface a2 external-ids],
322   [get interface a3 external-ids])], [0], [
323
324
325
326
327
328
329
330 key0=value0
331 value0
332
333
334 key0=othervalue
335
336
337 {"key1"="value1"}
338 {"key2"="value2", "key3"="value3"}
339 {"key4"="value4"}
340 ], [], [OVS_VSCTL_CLEANUP])
341 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
342   [br-get-external-id a],
343   [get port a1 external-ids],
344   [get interface a2 external-ids],
345   [get interface a3 external-ids])], [0],
346 [
347 {"key1"="value1"}
348 {"key2"="value2", "key3"="value3"}
349 {"key4"="value4"}
350 ], [], [OVS_VSCTL_CLEANUP])
351 CHECK_BRIDGES([a, a, 0])
352 CHECK_PORTS([a], [a1], [bond0])
353 CHECK_IFACES([a], [a1], [a2], [a3])
354 OVS_VSCTL_CLEANUP
355 AT_CLEANUP
356
357 AT_SETUP([controllers])
358 AT_KEYWORDS([controller ovs-vsctl])
359 OVS_VSCTL_SETUP
360 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
361   [add-br br0], 
362
363   [set-controller tcp:1.2.3.4],
364   [get-controller],
365   [get-controller default],
366   [get-controller br0],
367
368   [set-controller br0 tcp:4.5.6.7],
369   [get-controller],
370   [get-controller default],
371   [get-controller br0],
372
373   [del-controller],
374   [get-controller],
375   [get-controller default],
376   [get-controller br0],
377
378   [set-controller default tcp:8.9.10.11],
379   [get-controller],
380   [get-controller default],
381   [get-controller br0],
382
383   [del-controller default],
384   [get-controller],
385   [get-controller default],
386   [get-controller br0],
387
388   [del-controller br0],
389   [get-controller],
390   [get-controller default],
391   [get-controller br0],
392
393   [set-controller default tcp:1.2.3.4 tcp:4.5.6.7],
394   [get-controller],
395   [get-controller default],
396   [get-controller br0],
397
398   [set-controller br0 tcp:8.9.10.11 tcp:5.4.3.2],
399   [get-controller],
400   [get-controller default],
401   [get-controller br0])], [0], [
402
403 tcp:1.2.3.4
404 tcp:1.2.3.4
405 tcp:1.2.3.4
406
407 tcp:1.2.3.4
408 tcp:1.2.3.4
409 tcp:4.5.6.7
410
411
412
413 tcp:4.5.6.7
414
415 tcp:8.9.10.11
416 tcp:8.9.10.11
417 tcp:4.5.6.7
418
419
420
421 tcp:4.5.6.7
422
423
424
425
426
427 tcp:1.2.3.4\ntcp:4.5.6.7
428 tcp:1.2.3.4\ntcp:4.5.6.7
429 tcp:1.2.3.4\ntcp:4.5.6.7
430
431 tcp:1.2.3.4\ntcp:4.5.6.7
432 tcp:1.2.3.4\ntcp:4.5.6.7
433 tcp:5.4.3.2\ntcp:8.9.10.11
434 ], [], [OVS_VSCTL_CLEANUP])
435 OVS_VSCTL_CLEANUP
436 AT_CLEANUP
437
438 dnl ----------------------------------------------------------------------
439 AT_BANNER([ovs-vsctl unit tests -- fake bridges])
440
441 m4_define([OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF],
442   [AT_CHECK(
443      [RUN_OVS_VSCTL(
444         [add-br xenbr0],
445         [--may-exist add-br xenbr0],
446         [add-port xenbr0 eth0],
447         [--may-exist add-port xenbr0 eth0],
448         [add-br xapi1 xenbr0 9],
449         [--may-exist add-br xapi1 xenbr0 9],
450         [add-port xapi1 eth0.9])],
451      [0], [], [], [OVS_VSCTL_CLEANUP])])
452
453 AT_SETUP([simple fake bridge])
454 AT_KEYWORDS([ovs-vsctl fake-bridge])
455 OVS_VSCTL_SETUP
456 OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF
457 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-br xapi1])], [1], [],
458   [ovs-vsctl: "--may-exist add-br xapi1" but xapi1 is a VLAN bridge for VLAN 9
459 ], [OVS_VSCTL_CLEANUP])
460 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-br xapi1 xxx 9])], [1], [],
461   [ovs-vsctl: "--may-exist add-br xapi1 xxx 9" but xapi1 has the wrong parent xenbr0
462 ], [OVS_VSCTL_CLEANUP])
463 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-br xapi1 xenbr0 10])], [1], [],
464   [ovs-vsctl: "--may-exist add-br xapi1 xenbr0 10" but xapi1 is a VLAN bridge for the wrong VLAN 9
465 ], [OVS_VSCTL_CLEANUP])
466 CHECK_BRIDGES([xapi1, xenbr0, 9], [xenbr0, xenbr0, 0])
467 CHECK_PORTS([xenbr0], [eth0])
468 CHECK_IFACES([xenbr0], [eth0])
469 CHECK_PORTS([xapi1], [eth0.9])
470 CHECK_IFACES([xapi1], [eth0.9])
471 OVS_VSCTL_CLEANUP
472 AT_CLEANUP
473
474 AT_SETUP([simple fake bridge + del-br fake bridge])
475 AT_KEYWORDS([ovs-vsctl fake-bridge])
476 OVS_VSCTL_SETUP
477 OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF
478 AT_CHECK([RUN_OVS_VSCTL([del-br xapi1])], [0], [], [], [OVS_VSCTL_CLEANUP])
479 CHECK_BRIDGES([xenbr0, xenbr0, 0])
480 CHECK_PORTS([xenbr0], [eth0])
481 CHECK_IFACES([xenbr0], [eth0])
482 OVS_VSCTL_CLEANUP
483 AT_CLEANUP
484
485 AT_SETUP([simple fake bridge + del-br real bridge])
486 AT_KEYWORDS([ovs-vsctl fake-bridge])
487 OVS_VSCTL_SETUP
488 OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF
489 AT_CHECK([RUN_OVS_VSCTL([del-br xenbr0])], [0], [], [], [OVS_VSCTL_CLEANUP])
490 CHECK_BRIDGES
491 OVS_VSCTL_CLEANUP
492 AT_CLEANUP
493
494 AT_SETUP([simple fake bridge + external IDs])
495 AT_KEYWORDS([ovs-vsctl fake-bridge])
496 OVS_VSCTL_SETUP
497 OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF
498 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
499   [br-set-external-id xenbr0 key0 value0],
500   [br-set-external-id xapi1 key1 value1],
501   [br-get-external-id xenbr0],
502   [br-get-external-id xenbr0 key0],
503   [br-get-external-id xapi1],
504   [br-get-external-id xapi1 key1])], [0], [
505
506 key0=value0
507 value0
508 key1=value1
509 value1
510 ], [], [OVS_VSCTL_CLEANUP])
511 CHECK_BRIDGES([xapi1, xenbr0, 9], [xenbr0, xenbr0, 0])
512 CHECK_PORTS([xenbr0], [eth0])
513 CHECK_IFACES([xenbr0], [eth0])
514 CHECK_PORTS([xapi1], [eth0.9])
515 CHECK_IFACES([xapi1], [eth0.9])
516 OVS_VSCTL_CLEANUP
517 AT_CLEANUP
518
519 m4_define([OVS_VSCTL_SETUP_BOND_FAKE_CONF],
520   [AT_CHECK(
521      [RUN_OVS_VSCTL(
522         [add-br xapi1],
523         [add-bond xapi1 bond0 eth0 eth1],
524         [add-br xapi2 xapi1 11],
525         [add-port xapi2 bond0.11])],
526      [0], [], [], [OVS_VSCTL_CLEANUP])])
527
528 AT_SETUP([fake bridge on bond])
529 AT_KEYWORDS([ovs-vsctl fake-bridge])
530 OVS_VSCTL_SETUP
531 OVS_VSCTL_SETUP_BOND_FAKE_CONF
532 CHECK_BRIDGES([xapi1, xapi1, 0], [xapi2, xapi1, 11])
533 CHECK_PORTS([xapi1], [bond0])
534 CHECK_IFACES([xapi1], [eth0], [eth1])
535 CHECK_PORTS([xapi2], [bond0.11])
536 CHECK_IFACES([xapi2], [bond0.11])
537 OVS_VSCTL_CLEANUP
538 AT_CLEANUP
539
540 AT_SETUP([fake bridge on bond + del-br fake bridge])
541 AT_KEYWORDS([ovs-vsctl fake-bridge])
542 OVS_VSCTL_SETUP
543 OVS_VSCTL_SETUP_BOND_FAKE_CONF
544 AT_CHECK([RUN_OVS_VSCTL_ONELINE([del-br xapi2])], [0], [
545 ], [], [OVS_VSCTL_CLEANUP])
546 CHECK_BRIDGES([xapi1, xapi1, 0])
547 CHECK_PORTS([xapi1], [bond0])
548 CHECK_IFACES([xapi1], [eth0], [eth1])
549 OVS_VSCTL_CLEANUP
550 AT_CLEANUP
551
552 AT_SETUP([fake bridge on bond + del-br real bridge])
553 AT_KEYWORDS([ovs-vsctl fake-bridge])
554 OVS_VSCTL_SETUP
555 OVS_VSCTL_SETUP_BOND_FAKE_CONF
556 AT_CHECK([RUN_OVS_VSCTL([del-br xapi1])])
557 CHECK_BRIDGES
558 OVS_VSCTL_CLEANUP
559 AT_CLEANUP
560
561 dnl ----------------------------------------------------------------------
562 AT_BANNER([ovs-vsctl unit tests -- database commands])
563
564 AT_SETUP([database commands -- positive checks])
565 AT_KEYWORDS([ovs-vsctl])
566 OVS_VSCTL_SETUP
567 AT_CHECK([RUN_OVS_VSCTL([create b name=br0])], 
568   [0], [stdout], [], [OVS_VSCTL_CLEANUP])
569 cp stdout out1
570 AT_CHECK([RUN_OVS_VSCTL([list b], [get b br0 _uuid])], 
571   [0], [stdout], [], [OVS_VSCTL_CLEANUP])
572 cp stdout out2
573 AT_CHECK([perl $srcdir/uuidfilt.pl out1 out2], [0], 
574   [[<0>
575 _uuid               : <0>
576 controller          : []
577 datapath_id         : []
578 datapath_type       : ""
579 external_ids        : {}
580 flood_vlans         : []
581 mirrors             : []
582 name                : "br0"
583 netflow             : []
584 other_config        : {}
585 ports               : []
586 sflow               : []
587 <0>
588 ]], [ignore], [test ! -e pid || kill `cat pid`])
589 AT_CHECK(
590   [RUN_OVS_VSCTL(
591     [set bridge br0 \
592       'other_config:datapath_id="0123456789ab"' \
593       'other_config:hwaddr="00:11:22:33:44:55"' \
594       'external-ids={"uuids"="9c45f225-a7cf-439d-976d-83db6271fda1"}' -- \
595      add bridge br0 external_ids '"roles"="local; remote; cloud"'])], 
596   [0], [], [], [OVS_VSCTL_CLEANUP])
597 AT_CHECK([RUN_OVS_VSCTL_ONELINE([get bridge br0 other_config external-ids])], 
598   [0], [{datapath_id="0123456789ab", hwaddr="00:11:22:33:44:55"}\n{roles="local; remote; cloud", uuids="9c45f225-a7cf-439d-976d-83db6271fda1"}
599 ], [], [OVS_VSCTL_CLEANUP])
600 AT_CHECK([RUN_OVS_VSCTL([get bridge br0 other_config:hwaddr -- --if-exists get bridge br0 other-config:nonexistent])], 
601   [0], ["00:11:22:33:44:55"
602
603 ], [], [OVS_VSCTL_CLEANUP])
604 AT_CHECK([RUN_OVS_VSCTL([remove br br0 other_config hwaddr 'datapath_id=""' -- get br br0 other_config])], 
605   [0], [{datapath_id="0123456789ab"}
606 ], [], [OVS_VSCTL_CLEANUP])
607 AT_CHECK([RUN_OVS_VSCTL([remove br br0 other_config 'datapath_id="0123456789ab"' -- get br br0 other_config])], 
608   [0], [{}
609 ], [], [OVS_VSCTL_CLEANUP])
610 AT_CHECK([RUN_OVS_VSCTL([clear br br0 external-ids -- get br br0 external_ids])], 
611   [0], [{}
612 ], [], [OVS_VSCTL_CLEANUP])
613 AT_CHECK([RUN_OVS_VSCTL([destroy b br0])], 
614   [0], [stdout], [], [OVS_VSCTL_CLEANUP])
615 AT_CHECK([RUN_OVS_VSCTL([list b])], 
616   [0], [], [], [OVS_VSCTL_CLEANUP])
617 OVS_VSCTL_CLEANUP
618 AT_CLEANUP
619
620 AT_SETUP([database commands -- negative checks])
621 AT_KEYWORDS([ovs-vsctl])
622 OVS_VSCTL_SETUP
623 AT_CHECK([RUN_OVS_VSCTL([create b name=br0])], 
624   [0], [ignore], [], [OVS_VSCTL_CLEANUP])
625 AT_CHECK([RUN_OVS_VSCTL([add-br br1])], 
626   [0], [ignore], [], [OVS_VSCTL_CLEANUP])
627 AT_CHECK([RUN_OVS_VSCTL([set-controller br1 tcp:127.0.0.1])], 
628   [0], [ignore], [], [OVS_VSCTL_CLEANUP])
629 AT_CHECK([RUN_OVS_VSCTL([create n targets='"1.2.3.4:567"'])], 
630   [0], [stdout], [], [OVS_VSCTL_CLEANUP])
631 cp stdout netflow-uuid
632 AT_CHECK([RUN_OVS_VSCTL([list n `cat netflow-uuid`])],
633   [0], [stdout], [], [OVS_VSCTL_CLEANUP])
634 AT_CHECK([perl $srcdir/uuidfilt.pl netflow-uuid stdout], [0], 
635   [[<0>
636 _uuid               : <0>
637 active_timeout      : 0
638 add_id_to_interface : false
639 engine_id           : []
640 engine_type         : []
641 targets             : ["1.2.3.4:567"]
642 ]], [ignore], [test ! -e pid || kill `cat pid`])
643 AT_CHECK([RUN_OVS_VSCTL([list interx x])], 
644   [1], [], [ovs-vsctl: unknown table "interx"
645 ], [OVS_VSCTL_CLEANUP])
646 AT_CHECK([RUN_OVS_VSCTL([list b x])], 
647   [1], [], [ovs-vsctl: no row "x" in table Bridge
648 ], [OVS_VSCTL_CLEANUP])
649 AT_CHECK([RUN_OVS_VSCTL([list b br])], 
650   [1], [], [ovs-vsctl: multiple rows in Bridge match "br"
651 ], [OVS_VSCTL_CLEANUP])
652 AT_CHECK([RUN_OVS_VSCTL([get b br0 d])], 
653   [1], [], [ovs-vsctl: Bridge contains more than one column whose name matches "d"
654 ], [OVS_VSCTL_CLEANUP])
655 AT_CHECK([RUN_OVS_VSCTL([get b br0 x])], 
656   [1], [], [ovs-vsctl: Bridge does not contain a column whose name matches "x"
657 ], [OVS_VSCTL_CLEANUP])
658 AT_CHECK([RUN_OVS_VSCTL([get b br0 :y=z])], 
659   [1], [], [ovs-vsctl: :y=z: missing column name
660 ], [OVS_VSCTL_CLEANUP])
661 AT_CHECK([RUN_OVS_VSCTL([get b br0 datapath_id:y=z])], 
662   [1], [], [ovs-vsctl: datapath_id:y=z: trailing garbage "=z" in argument
663 ], [OVS_VSCTL_CLEANUP])
664 AT_CHECK([RUN_OVS_VSCTL([set b br0 'datapath_id:y>=z'])], 
665   [1], [], [ovs-vsctl: datapath_id:y>=z: argument does not end in "=" followed by a value.
666 ], [OVS_VSCTL_CLEANUP])
667 AT_CHECK([RUN_OVS_VSCTL([wait-until b br0 datapath_id:y,z])], 
668   [1], [], [ovs-vsctl: datapath_id:y,z: argument does not end in "=", "!=", "<", ">", "<=", or ">=" followed by a value.
669 ], [OVS_VSCTL_CLEANUP])
670 AT_CHECK([RUN_OVS_VSCTL([get b br0 datapath_id::])], 
671   [1], [], [ovs-vsctl: datapath_id::: trailing garbage ":" in argument
672 ], [OVS_VSCTL_CLEANUP])
673 AT_CHECK([RUN_OVS_VSCTL([get b br0 datapath_id:x])], 
674   [1], [], [ovs-vsctl: cannot specify key to get for non-map column datapath_id
675 ], [OVS_VSCTL_CLEANUP])
676 AT_CHECK([RUN_OVS_VSCTL([get b br0 external_ids:x])], 
677   [1], [], [ovs-vsctl: no key "x" in Bridge record "br0" column external_ids
678 ], [OVS_VSCTL_CLEANUP])
679 AT_CHECK([RUN_OVS_VSCTL([set b br0 flood_vlans=-1])], 
680   [1], [], [ovs-vsctl: constraint violation: -1 is not in the valid range 0 to 4095 (inclusive)
681 ], [OVS_VSCTL_CLEANUP])
682 AT_CHECK([RUN_OVS_VSCTL([set b br0 flood_vlans=4096])], 
683   [1], [], [ovs-vsctl: constraint violation: 4096 is not in the valid range 0 to 4095 (inclusive)
684 ], [OVS_VSCTL_CLEANUP])
685 AT_CHECK([RUN_OVS_VSCTL([set c br1 'connection-mode=xyz'])], 
686   [1], [], [[ovs-vsctl: constraint violation: xyz is not one of the allowed values ([in-band, out-of-band])
687 ]], [OVS_VSCTL_CLEANUP])
688 AT_CHECK([RUN_OVS_VSCTL([set c br1 connection-mode:x=y])], 
689   [1], [], [ovs-vsctl: cannot specify key to set for non-map column connection_mode
690 ], [OVS_VSCTL_CLEANUP])
691 AT_CHECK([RUN_OVS_VSCTL([add b br1 datapath_id x y])], 
692   [1], [], [ovs-vsctl: "add" operation would put 2 values in column datapath_id of table Bridge but the maximum number is 1
693 ], [OVS_VSCTL_CLEANUP])
694 AT_CHECK([RUN_OVS_VSCTL([remove n `cat netflow-uuid` targets '"1.2.3.4:567"'])], 
695   [1], [], [ovs-vsctl: "remove" operation would put 0 values in column targets of table NetFlow but the minimum number is 1
696 ], [OVS_VSCTL_CLEANUP])
697 AT_CHECK([RUN_OVS_VSCTL([clear n `cat netflow-uuid` targets])], 
698   [1], [], [ovs-vsctl: "clear" operation cannot be applied to column targets of table NetFlow, which is not allowed to be empty
699 ], [OVS_VSCTL_CLEANUP])
700 AT_CHECK([RUN_OVS_VSCTL([destroy b br2])], 
701   [1], [], [ovs-vsctl: no row "br2" in table Bridge
702 ], [OVS_VSCTL_CLEANUP])
703 OVS_VSCTL_CLEANUP
704 AT_CLEANUP
705
706 AT_SETUP([database commands -- wait-until immediately true])
707 AT_KEYWORDS([ovs-vsctl])
708 OVS_VSCTL_SETUP
709 AT_CHECK([RUN_OVS_VSCTL(
710     [add-br br0], 
711     [add-bond br0 bond0 eth0 eth1],
712     [set port bond0 bond_updelay=500 other-config:abc=def])],
713   [0], [], [], [OVS_VSCTL_CLEANUP])
714 AT_CHECK([RUN_OVS_VSCTL([[wait-until Open_vSwitch . managers=[]]])],
715   [0], [], [], [OVS_VSCTL_CLEANUP])
716 AT_CHECK([RUN_OVS_VSCTL([[wait-until Open_vSwitch . bridges!=[]]])],
717   [0], [], [], [OVS_VSCTL_CLEANUP])
718 AT_CHECK([RUN_OVS_VSCTL([[wait-until Port bond0 other-config:abc=def]])],
719   [0], [], [], [OVS_VSCTL_CLEANUP])
720 AT_CHECK([RUN_OVS_VSCTL([[wait-until port bond0 'bond_updelay>50' 'other-config:abc>d' 'other-config:abc<e']])],
721   [0], [], [], [OVS_VSCTL_CLEANUP])
722 OVS_VSCTL_CLEANUP
723 AT_CLEANUP
724
725 AT_SETUP([database commands -- wait-until must wait])
726 AT_KEYWORDS([ovs-vsctl])
727 OVS_VSCTL_SETUP
728
729 # Start ovs-vsctls in background.
730 (RUN_OVS_VSCTL([[wait-until o . bridges!=[] -- get bridge br10 other-config:abc]])) > stdout1 &
731 (RUN_OVS_VSCTL([[wait-until bridge br1 -- get bridge br1 other-config:abc]])) > stdout2 &
732 (RUN_OVS_VSCTL([[wait-until b br1 other-config={abc=def} -- get bridge br1 other-config]])) > stdout3 &
733 (RUN_OVS_VSCTL([[wait-until port bond0 'bond_updelay>50' -- get port bond0 bond-updelay]])) > stdout4 &
734
735 # Give the ovs-vsctls a chance to read the database
736 sleep 1
737
738 AT_CHECK([RUN_OVS_VSCTL([add-br br10 -- set bridge br1 other-config:abc=quux])
739 RUN_OVS_VSCTL([add-br br1 -- set bridge br1 other-config:abc=def -- add-bond br1 bond0 eth0 eth1 -- set port bond0 bond_updelay=500])],
740   [0], [], [], [OVS_VSCTL_CLEANUP])
741
742 # Wait for the ovs-vsctls to finish.
743 wait
744
745 # Check output
746 AT_CHECK([cat stdout1], [0], [quux
747 ], [], [OVS_VSCTL_CLEANUP])
748 AT_CHECK([cat stdout2], [0], [def
749 ], [], [OVS_VSCTL_CLEANUP])
750 AT_CHECK([cat stdout3], [0], [{abc=def}
751 ], [], [OVS_VSCTL_CLEANUP])
752 AT_CHECK([cat stdout4], [0], [500
753 ], [], [OVS_VSCTL_CLEANUP])
754
755 OVS_VSCTL_CLEANUP
756 AT_CLEANUP
757
758 dnl This test really shows a bug -- "create" followed by "list" in
759 dnl the same execution shows the wrong UUID on the "list" command.
760 dnl The bug is documented in ovs-vsctl.8.
761 AT_SETUP([created row UUID is wrong in same execution])
762 AT_KEYWORDS([ovs-vsctl])
763 OVS_VSCTL_SETUP
764 AT_CHECK([RUN_OVS_VSCTL([create Bridge name=br0 -- list b])], 
765   [0], [stdout], [], [OVS_VSCTL_CLEANUP])
766 AT_CHECK([perl $srcdir/uuidfilt.pl stdout], [0], 
767   [[<0>
768 _uuid               : <1>
769 controller          : []
770 datapath_id         : []
771 datapath_type       : ""
772 external_ids        : {}
773 flood_vlans         : []
774 mirrors             : []
775 name                : "br0"
776 netflow             : []
777 other_config        : {}
778 ports               : []
779 sflow               : []
780 ]], [ignore], [test ! -e pid || kill `cat pid`])
781 OVS_VSCTL_CLEANUP
782 AT_CLEANUP