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],
7 AT_CHECK([ovsdb-server --detach --pidfile=$PWD/pid --remote=punix:socket --unixctl=$PWD/unixctl db >/dev/null 2>&1], [0], [ignore], [ignore])])
11 dnl Kills off the database server.
12 m4_define([OVS_VSCTL_CLEANUP], [OVSDB_SERVER_SHUTDOWN])
14 dnl RUN_OVS_VSCTL(COMMAND, ...)
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
20 m4_define([RUN_OVS_VSCTL_ONELINE],
21 [m4_foreach([command], [$@], [ovs-vsctl --no-wait -vreconnect:ANY:emer --db=unix:socket --oneline -- command
24 dnl RUN_OVS_VSCTL_TOGETHER(COMMAND, ...)
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])])
31 dnl CHECK_BRIDGES([BRIDGE, PARENT, VLAN], ...)
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])
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])
50 # Check multiple queries in a single run.
51 AT_CHECK([RUN_OVS_VSCTL_TOGETHER([br-to-parent $1], [br-to-vlan $1])], [0],
54 ], [], [OVS_VSCTL_CLEANUP])])
55 m4_define([CHECK_BRIDGES],
56 [dnl Check that the bridges appear on list-br, without --oneline.
58 [RUN_OVS_VSCTL([list-br])],
60 [m4_foreach([brinfo], [$@], [m4_car(brinfo)
65 dnl Check that the bridges appear on list-br, with --oneline.
67 [RUN_OVS_VSCTL_ONELINE([list-br])],
69 [m4_join([\n], m4_foreach([brinfo], [$@], [m4_car(brinfo),]))
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], [], [],
82 dnl Check that each bridge has the expected parent and VLAN.
83 m4_map([_CHECK_BRIDGE], [$@])])
85 dnl CHECK_PORTS(BRIDGE, PORT[, PORT...])
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
91 m4_define([CHECK_PORTS],
92 [dnl Check ports without --oneline.
94 [RUN_OVS_VSCTL([list-ports $1])],
96 [m4_foreach([port], m4_cdr($@), [port
101 dnl Check ports with --oneline.
103 [RUN_OVS_VSCTL_ONELINE([list-ports $1])],
105 [m4_join([\n], m4_shift($@))
109 AT_CHECK([RUN_OVS_VSCTL([port-to-br $1])], [1], [],
110 [ovs-vsctl: no port named $1
115 [AT_CHECK([RUN_OVS_VSCTL([[port-to-br] port])], [0], [$1
116 ], [], [OVS_VSCTL_CLEANUP])])])
118 dnl CHECK_IFACES(BRIDGE, IFACE[, IFACE...])
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
124 m4_define([CHECK_IFACES],
126 [RUN_OVS_VSCTL([list-ifaces $1])],
128 [m4_foreach([iface], m4_cdr($@), [iface
132 AT_CHECK([RUN_OVS_VSCTL([iface-to-br $1])], [1], [],
133 [ovs-vsctl: no interface named $1
138 [AT_CHECK([RUN_OVS_VSCTL([[iface-to-br] iface])], [0], [$1
140 [], [OVS_VSCTL_CLEANUP])])])
142 dnl ----------------------------------------------------------------------
143 AT_BANNER([ovs-vsctl unit tests -- real bridges])
146 AT_KEYWORDS([ovs-vsctl])
148 AT_CHECK([RUN_OVS_VSCTL([add-br a])], [0], [], [], [OVS_VSCTL_CLEANUP])
149 CHECK_BRIDGES([a, a, 0])
155 AT_SETUP([add-br a, add-br a])
156 AT_KEYWORDS([ovs-vsctl])
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])
165 AT_SETUP([add-br a, add-br b])
166 AT_KEYWORDS([ovs-vsctl])
168 AT_CHECK([RUN_OVS_VSCTL([add-br a], [add-br b])], [0], [], [],
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
174 CHECK_BRIDGES([a, a, 0], [b, b, 0])
182 AT_SETUP([add-br a, add-br b, del-br a])
183 AT_KEYWORDS([ovs-vsctl])
185 AT_CHECK([RUN_OVS_VSCTL([add-br a], [add-br b], [del-br a])], [0], [], [],
187 CHECK_BRIDGES([b, b, 0])
193 AT_SETUP([add-br a, add-port a a1, add-port a a2])
194 AT_KEYWORDS([ovs-vsctl])
196 AT_CHECK([RUN_OVS_VSCTL(
198 [--if-exists del-br b],
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])
207 AT_SETUP([add-br a, add-port a a1, add-port a a1])
208 AT_KEYWORDS([ovs-vsctl])
210 AT_CHECK([RUN_OVS_VSCTL(
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])
219 AT_SETUP([add-br a b, add-port a a1, add-port b b1, del-br a])
220 AT_KEYWORDS([ovs-vsctl])
222 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
227 [--if-exists del-port b b2],
234 ], [], [OVS_VSCTL_CLEANUP])
235 CHECK_BRIDGES([b, b, 0])
236 CHECK_PORTS([b], [b1])
237 CHECK_IFACES([b], [b1])
241 AT_SETUP([add-br a, add-bond a bond0 a1 a2 a3])
242 AT_KEYWORDS([ovs-vsctl])
244 AT_CHECK([RUN_OVS_VSCTL(
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], [], [],
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
253 CHECK_BRIDGES([a, a, 0])
254 CHECK_PORTS([a], [bond0])
255 CHECK_IFACES([a], [a1], [a2], [a3])
259 AT_SETUP([add-br a b, add-port a a1, add-port b b1, del-port a a1])
260 AT_KEYWORDS([ovs-vsctl])
262 AT_CHECK([RUN_OVS_VSCTL(
265 [add-port a a1 tag=9],
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], [], [],
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
276 CHECK_BRIDGES([a, a, 0], [b, b, 0])
279 CHECK_PORTS([b], [b1])
280 CHECK_IFACES([b], [b1])
284 AT_SETUP([add-br a, add-bond a bond0 a1 a2 a3, del-port bond0])
285 AT_KEYWORDS([ovs-vsctl])
287 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
289 [add-bond a bond0 a1 a2 a3 tag=9],
290 [get Port bond0 tag],
291 [del-port bond0])], [0], [
295 ], [], [OVS_VSCTL_CLEANUP])
296 CHECK_BRIDGES([a, a, 0])
301 AT_SETUP([external IDs])
302 AT_KEYWORDS([ovs-vsctl])
304 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
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], [
338 {"key2"="value2", "key3"="value3"}
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],
348 {"key2"="value2", "key3"="value3"}
350 ], [], [OVS_VSCTL_CLEANUP])
351 CHECK_BRIDGES([a, a, 0])
352 CHECK_PORTS([a], [a1], [bond0])
353 CHECK_IFACES([a], [a1], [a2], [a3])
357 AT_SETUP([controllers])
358 AT_KEYWORDS([controller ovs-vsctl])
360 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
363 [set-controller tcp:1.2.3.4],
365 [get-controller default],
366 [get-controller br0],
368 [set-controller br0 tcp:4.5.6.7],
370 [get-controller default],
371 [get-controller br0],
375 [get-controller default],
376 [get-controller br0],
378 [set-controller default tcp:8.9.10.11],
380 [get-controller default],
381 [get-controller br0],
383 [del-controller default],
385 [get-controller default],
386 [get-controller br0],
388 [del-controller br0],
390 [get-controller default],
391 [get-controller br0],
393 [set-controller default tcp:1.2.3.4 tcp:4.5.6.7],
395 [get-controller default],
396 [get-controller br0],
398 [set-controller br0 tcp:8.9.10.11 tcp:5.4.3.2],
400 [get-controller default],
401 [get-controller br0])], [0], [
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
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])
438 dnl ----------------------------------------------------------------------
439 AT_BANNER([ovs-vsctl unit tests -- fake bridges])
441 m4_define([OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF],
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])])
453 AT_SETUP([simple fake bridge])
454 AT_KEYWORDS([ovs-vsctl fake-bridge])
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])
474 AT_SETUP([simple fake bridge + del-br fake bridge])
475 AT_KEYWORDS([ovs-vsctl fake-bridge])
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])
485 AT_SETUP([simple fake bridge + del-br real bridge])
486 AT_KEYWORDS([ovs-vsctl fake-bridge])
488 OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF
489 AT_CHECK([RUN_OVS_VSCTL([del-br xenbr0])], [0], [], [], [OVS_VSCTL_CLEANUP])
494 AT_SETUP([simple fake bridge + external IDs])
495 AT_KEYWORDS([ovs-vsctl fake-bridge])
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], [
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])
519 m4_define([OVS_VSCTL_SETUP_BOND_FAKE_CONF],
523 [add-bond xapi1 bond0 eth0 eth1],
524 [add-br xapi2 xapi1 11],
525 [add-port xapi2 bond0.11])],
526 [0], [], [], [OVS_VSCTL_CLEANUP])])
528 AT_SETUP([fake bridge on bond])
529 AT_KEYWORDS([ovs-vsctl fake-bridge])
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])
540 AT_SETUP([fake bridge on bond + del-br fake bridge])
541 AT_KEYWORDS([ovs-vsctl fake-bridge])
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])
552 AT_SETUP([fake bridge on bond + del-br real bridge])
553 AT_KEYWORDS([ovs-vsctl fake-bridge])
555 OVS_VSCTL_SETUP_BOND_FAKE_CONF
556 AT_CHECK([RUN_OVS_VSCTL([del-br xapi1])])
561 dnl ----------------------------------------------------------------------
562 AT_BANNER([ovs-vsctl unit tests -- database commands])
564 AT_SETUP([database commands -- positive checks])
565 AT_KEYWORDS([ovs-vsctl])
567 AT_CHECK([RUN_OVS_VSCTL([create b name=br0])],
568 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
570 AT_CHECK([RUN_OVS_VSCTL([list b], [get b br0 _uuid])],
571 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
573 AT_CHECK([perl $srcdir/uuidfilt.pl out1 out2], [0],
588 ]], [ignore], [test ! -e pid || kill `cat pid`])
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"
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])],
609 ], [], [OVS_VSCTL_CLEANUP])
610 AT_CHECK([RUN_OVS_VSCTL([clear br br0 external-ids -- get br br0 external_ids])],
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])
620 AT_SETUP([database commands -- negative checks])
621 AT_KEYWORDS([ovs-vsctl])
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],
638 add_id_to_interface : false
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([get b br0 d])],
650 [1], [], [ovs-vsctl: Bridge contains more than one column whose name matches "d"
651 ], [OVS_VSCTL_CLEANUP])
652 AT_CHECK([RUN_OVS_VSCTL([get b br0 x])],
653 [1], [], [ovs-vsctl: Bridge does not contain a column whose name matches "x"
654 ], [OVS_VSCTL_CLEANUP])
655 AT_CHECK([RUN_OVS_VSCTL([get b br0 :y=z])],
656 [1], [], [ovs-vsctl: :y=z: missing column name
657 ], [OVS_VSCTL_CLEANUP])
658 AT_CHECK([RUN_OVS_VSCTL([get b br0 datapath_id:y=z])],
659 [1], [], [ovs-vsctl: datapath_id:y=z: trailing garbage "=z" in argument
660 ], [OVS_VSCTL_CLEANUP])
661 AT_CHECK([RUN_OVS_VSCTL([set b br0 'datapath_id:y>=z'])],
662 [1], [], [ovs-vsctl: datapath_id:y>=z: argument does not end in "=" followed by a value.
663 ], [OVS_VSCTL_CLEANUP])
664 AT_CHECK([RUN_OVS_VSCTL([wait-until b br0 datapath_id:y,z])],
665 [1], [], [ovs-vsctl: datapath_id:y,z: argument does not end in "=", "!=", "<", ">", "<=", or ">=" followed by a value.
666 ], [OVS_VSCTL_CLEANUP])
667 AT_CHECK([RUN_OVS_VSCTL([get b br0 datapath_id::])],
668 [1], [], [ovs-vsctl: datapath_id::: trailing garbage ":" in argument
669 ], [OVS_VSCTL_CLEANUP])
670 AT_CHECK([RUN_OVS_VSCTL([get b br0 datapath_id:x])],
671 [1], [], [ovs-vsctl: cannot specify key to get for non-map column datapath_id
672 ], [OVS_VSCTL_CLEANUP])
673 AT_CHECK([RUN_OVS_VSCTL([get b br0 external_ids:x])],
674 [1], [], [ovs-vsctl: no key "x" in Bridge record "br0" column external_ids
675 ], [OVS_VSCTL_CLEANUP])
676 AT_CHECK([RUN_OVS_VSCTL([set b br0 flood_vlans=-1])],
677 [1], [], [ovs-vsctl: constraint violation: -1 is not in the valid range 0 to 4095 (inclusive)
678 ], [OVS_VSCTL_CLEANUP])
679 AT_CHECK([RUN_OVS_VSCTL([set b br0 flood_vlans=4096])],
680 [1], [], [ovs-vsctl: constraint violation: 4096 is not in the valid range 0 to 4095 (inclusive)
681 ], [OVS_VSCTL_CLEANUP])
682 AT_CHECK([RUN_OVS_VSCTL([set c br1 'connection-mode=xyz'])],
683 [1], [], [[ovs-vsctl: constraint violation: xyz is not one of the allowed values ([in-band, out-of-band])
684 ]], [OVS_VSCTL_CLEANUP])
685 AT_CHECK([RUN_OVS_VSCTL([set c br1 connection-mode:x=y])],
686 [1], [], [ovs-vsctl: cannot specify key to set for non-map column connection_mode
687 ], [OVS_VSCTL_CLEANUP])
688 AT_CHECK([RUN_OVS_VSCTL([add b br1 datapath_id x y])],
689 [1], [], [ovs-vsctl: "add" operation would put 2 values in column datapath_id of table Bridge but the maximum number is 1
690 ], [OVS_VSCTL_CLEANUP])
691 AT_CHECK([RUN_OVS_VSCTL([remove n `cat netflow-uuid` targets '"1.2.3.4:567"'])],
692 [1], [], [ovs-vsctl: "remove" operation would put 0 values in column targets of table NetFlow but the minimum number is 1
693 ], [OVS_VSCTL_CLEANUP])
694 AT_CHECK([RUN_OVS_VSCTL([clear n `cat netflow-uuid` targets])],
695 [1], [], [ovs-vsctl: "clear" operation cannot be applied to column targets of table NetFlow, which is not allowed to be empty
696 ], [OVS_VSCTL_CLEANUP])
697 AT_CHECK([RUN_OVS_VSCTL([destroy b br2])],
698 [1], [], [ovs-vsctl: no row "br2" in table Bridge
699 ], [OVS_VSCTL_CLEANUP])
703 AT_SETUP([database commands -- wait-until immediately true])
704 AT_KEYWORDS([ovs-vsctl])
706 AT_CHECK([RUN_OVS_VSCTL(
708 [add-bond br0 bond0 eth0 eth1],
709 [set port bond0 bond_updelay=500 other-config:abc=def])],
710 [0], [], [], [OVS_VSCTL_CLEANUP])
711 AT_CHECK([RUN_OVS_VSCTL([[wait-until Open_vSwitch . managers=[]]])],
712 [0], [], [], [OVS_VSCTL_CLEANUP])
713 AT_CHECK([RUN_OVS_VSCTL([[wait-until Open_vSwitch . bridges!=[]]])],
714 [0], [], [], [OVS_VSCTL_CLEANUP])
715 AT_CHECK([RUN_OVS_VSCTL([[wait-until Port bond0 other-config:abc=def]])],
716 [0], [], [], [OVS_VSCTL_CLEANUP])
717 AT_CHECK([RUN_OVS_VSCTL([[wait-until port bond0 'bond_updelay>50' 'other-config:abc>d' 'other-config:abc<e']])],
718 [0], [], [], [OVS_VSCTL_CLEANUP])
722 AT_SETUP([database commands -- wait-until must wait])
723 AT_KEYWORDS([ovs-vsctl])
725 # Disable lcov for this test. All the programs running in parallel
726 # race badly on access to profiling data.
732 # Start ovs-vsctls in background.
733 (RUN_OVS_VSCTL([[wait-until o . bridges!=[] -- get bridge br10 other-config:abc]])) > stdout1 &
734 (RUN_OVS_VSCTL([[wait-until bridge br1 -- get bridge br1 other-config:abc]])) > stdout2 &
735 (RUN_OVS_VSCTL([[wait-until b br1 other-config={abc=def} -- get bridge br1 other-config]])) > stdout3 &
736 (RUN_OVS_VSCTL([[wait-until port bond0 'bond_updelay>50' -- get port bond0 bond-updelay]])) > stdout4 &
738 # Give the ovs-vsctls a chance to read the database
741 AT_CHECK([RUN_OVS_VSCTL([add-br br10 -- set bridge br10 other-config:abc=quux])
742 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])],
743 [0], [], [], [OVS_VSCTL_CLEANUP])
745 # Wait for the ovs-vsctls to finish.
749 AT_CHECK([cat stdout1], [0], [quux
750 ], [], [OVS_VSCTL_CLEANUP])
751 AT_CHECK([cat stdout2], [0], [def
752 ], [], [OVS_VSCTL_CLEANUP])
753 AT_CHECK([cat stdout3], [0], [{abc=def}
754 ], [], [OVS_VSCTL_CLEANUP])
755 AT_CHECK([cat stdout4], [0], [500
756 ], [], [OVS_VSCTL_CLEANUP])
761 dnl This test really shows a bug -- "create" followed by "list" in
762 dnl the same execution shows the wrong UUID on the "list" command.
763 dnl The bug is documented in ovs-vsctl.8.
764 AT_SETUP([created row UUID is wrong in same execution])
765 AT_KEYWORDS([ovs-vsctl])
767 AT_CHECK([RUN_OVS_VSCTL([create Bridge name=br0 -- list b])],
768 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
769 AT_CHECK([perl $srcdir/uuidfilt.pl stdout], [0],
783 ]], [ignore], [test ! -e pid || kill `cat pid`])