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 --no-chdir --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:emer --db=unix:socket command
20 m4_define([RUN_OVS_VSCTL_ONELINE],
21 [m4_foreach([command], [$@], [ovs-vsctl --no-wait -vreconnect: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: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])
145 AT_SETUP([ovs-vsctl connection retry])
146 OVS_RUNDIR=$PWD; export OVS_RUNDIR
148 dnl Without --retry, there should be no retry for active connections.
149 AT_CHECK([ovs-vsctl --db=unix:foo --timeout=10 -vreconnect:emer -- init],
151 AT_CHECK([[sed 's/([^()]*)/(...reason...)/' stderr]], [0],
152 [ovs-vsctl: unix:foo: database connection failed (...reason...)
155 dnl With --retry, we should retry for active connections.
157 [ovs-vsctl --db=unix:foo --timeout=1 --retry -vreconnect:emer -vPATTERN:console:'%c|%p|%m' -- init
160 AT_CHECK([grep -c 'terminating with signal' stderr], [0], [1
162 if test "$IS_WIN32" = "yes"; then
163 AT_CHECK([cat status], [0], [3
167 AT_CHECK([cat status], [0], [142
171 dnl Without --retry, we should retry for passive connections.
173 [ovs-vsctl --db=punix:foo --timeout=1 -vreconnect:emer -vPATTERN:console:'%c|%p|%m' -- init
176 AT_CHECK([grep -c 'terminating with signal' stderr], [0], [1
178 if test "$IS_WIN32" = "yes"; then
179 AT_CHECK([cat status], [0], [3
183 AT_CHECK([cat status], [0], [142
188 dnl ----------------------------------------------------------------------
189 AT_BANNER([ovs-vsctl unit tests -- real bridges])
192 AT_KEYWORDS([ovs-vsctl])
194 AT_CHECK([RUN_OVS_VSCTL([add-br a])], [0], [], [], [OVS_VSCTL_CLEANUP])
195 CHECK_BRIDGES([a, a, 0])
201 AT_SETUP([add-br a, add-br a])
202 AT_KEYWORDS([ovs-vsctl])
204 AT_CHECK([RUN_OVS_VSCTL([add-br a])], [0], [], [], [OVS_VSCTL_CLEANUP])
205 AT_CHECK([RUN_OVS_VSCTL([add-br a])], [1], [],
206 [ovs-vsctl: cannot create a bridge named a because a bridge named a already exists
207 ], [OVS_VSCTL_CLEANUP])
211 AT_SETUP([add-br a, add-br b])
212 AT_KEYWORDS([ovs-vsctl])
214 AT_CHECK([RUN_OVS_VSCTL([add-br a], [add-br b])], [0], [], [],
216 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-br a b 9])], [1], [],
217 [ovs-vsctl: "--may-exist add-br a b 9" but a is not a VLAN bridge
220 CHECK_BRIDGES([a, a, 0], [b, b, 0])
228 AT_SETUP([add-br a, add-br b, del-br a])
229 AT_KEYWORDS([ovs-vsctl])
231 AT_CHECK([RUN_OVS_VSCTL([add-br a], [add-br b], [del-br a])], [0], [], [],
233 CHECK_BRIDGES([b, b, 0])
239 AT_SETUP([add-br a, del-br a, add-br a])
240 AT_KEYWORDS([ovs-vsctl])
242 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
246 [set Interface a other_config:key=value],
247 [get Interface a other_config:key])], [0], [
252 ], [], [OVS_VSCTL_CLEANUP])
253 CHECK_BRIDGES([a, a, 0])
259 AT_SETUP([add-br a, add-port a a1, add-port a a2])
260 AT_KEYWORDS([ovs-vsctl])
262 AT_CHECK([RUN_OVS_VSCTL(
264 [--if-exists del-br b],
266 [add-port a a2])], [0], [], [], [OVS_VSCTL_CLEANUP])
267 CHECK_BRIDGES([a, a, 0])
268 CHECK_PORTS([a], [a1], [a2])
269 CHECK_IFACES([a], [a1], [a2])
273 AT_SETUP([add-br a, add-port a a1, add-port a a1])
274 AT_KEYWORDS([ovs-vsctl])
276 AT_CHECK([RUN_OVS_VSCTL(
278 [add-port a a1])], [0], [], [], [OVS_VSCTL_CLEANUP])
279 AT_CHECK([RUN_OVS_VSCTL([add-port a a1])], [1], [],
280 [ovs-vsctl: cannot create a port named a1 because a port named a1 already exists on bridge a
281 ], [OVS_VSCTL_CLEANUP])
285 AT_SETUP([add-br a b, add-port a a1, add-port b b1, del-br a])
286 AT_KEYWORDS([ovs-vsctl])
288 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
293 [--if-exists del-port b b2],
300 ], [], [OVS_VSCTL_CLEANUP])
301 CHECK_BRIDGES([b, b, 0])
302 CHECK_PORTS([b], [b1])
303 CHECK_IFACES([b], [b1])
307 AT_SETUP([add-br a, add-bond a bond0 a1 a2 a3])
308 AT_KEYWORDS([ovs-vsctl])
310 AT_CHECK([RUN_OVS_VSCTL(
312 [add-bond a bond0 a1 a2 a3])], [0], [], [], [OVS_VSCTL_CLEANUP])
313 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-bond a bond0 a3 a1 a2])], [0], [], [],
315 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-bond a bond0 a2 a1])], [1], [],
316 [ovs-vsctl: "--may-exist add-bond a bond0 a2 a1" but bond0 actually has interface(s) a1, a2, a3
319 CHECK_BRIDGES([a, a, 0])
320 CHECK_PORTS([a], [bond0])
321 CHECK_IFACES([a], [a1], [a2], [a3])
325 AT_SETUP([add-br a b, add-port a a1, add-port b b1, del-port a a1])
326 AT_KEYWORDS([ovs-vsctl])
328 AT_CHECK([RUN_OVS_VSCTL(
331 [add-port a a1 tag=9],
333 [--may-exist add-port b b1],
334 [del-port a a1])], [0], [9
335 ], [], [OVS_VSCTL_CLEANUP])
336 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-port b b1])], [0], [], [],
338 AT_CHECK([RUN_OVS_VSCTL([del-port a])], [1], [],
339 [ovs-vsctl: cannot delete port a because it is the local port for bridge a (deleting this port requires deleting the entire bridge)
342 AT_CHECK([RUN_OVS_VSCTL([--if-exists del-port a])], [0], [], [],
344 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-port a b1])], [1], [],
345 [ovs-vsctl: "--may-exist add-port a b1" but b1 is actually attached to bridge b
348 CHECK_BRIDGES([a, a, 0], [b, b, 0])
351 CHECK_PORTS([b], [b1])
352 CHECK_IFACES([b], [b1])
356 AT_SETUP([add-br a, add-bond a bond0 a1 a2 a3, del-port bond0])
357 AT_KEYWORDS([ovs-vsctl])
359 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
361 [add-bond a bond0 a1 a2 a3 tag=9],
362 [get Port bond0 tag],
363 [del-port bond0])], [0], [
367 ], [], [OVS_VSCTL_CLEANUP])
368 CHECK_BRIDGES([a, a, 0])
373 AT_SETUP([external IDs])
374 AT_KEYWORDS([ovs-vsctl])
376 AT_CHECK([RUN_OVS_VSCTL_ONELINE(
379 [add-bond a bond0 a2 a3],
380 [br-set-external-id a key0 value0],
381 [set port a1 external-ids:key1=value1],
382 [set interface a2 external-ids:key2=value2],
383 [set interface a2 external-ids:key3=value3],
384 [set interface a3 external-ids:key4=value4],
385 [br-get-external-id a],
386 [br-get-external-id a key0],
387 [br-get-external-id a key1],
388 [br-set-external-id a key0 othervalue],
389 [br-get-external-id a],
390 [br-set-external-id a key0],
391 [br-get-external-id a],
392 [get port a1 external-ids],
393 [get interface a2 external-ids],
394 [get interface a3 external-ids])], [0], [
410 {"key2"="value2", "key3"="value3"}
412 ], [], [OVS_VSCTL_CLEANUP])
413 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
414 [br-get-external-id a],
415 [get port a1 external-ids],
416 [get interface a2 external-ids],
417 [get interface a3 external-ids])], [0],
420 {"key2"="value2", "key3"="value3"}
422 ], [], [OVS_VSCTL_CLEANUP])
423 CHECK_BRIDGES([a, a, 0])
424 CHECK_PORTS([a], [a1], [bond0])
425 CHECK_IFACES([a], [a1], [a2], [a3])
429 AT_SETUP([controllers])
430 AT_KEYWORDS([controller ovs-vsctl])
432 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
435 [get-controller br0],
436 [set-controller br0 tcp:4.5.6.7],
437 [get-controller br0],
439 [del-controller br0],
440 [get-controller br0],
442 [set-controller br0 tcp:8.9.10.11 tcp:5.4.3.2],
443 [get-controller br0])], [0], [
450 tcp:5.4.3.2\ntcp:8.9.10.11
451 ], [], [OVS_VSCTL_CLEANUP])
455 dnl ----------------------------------------------------------------------
456 dnl OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF([VLAN])
457 m4_define([OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF],
461 [--may-exist add-br xenbr0],
462 [add-port xenbr0 eth0],
463 [--may-exist add-port xenbr0 eth0],
464 [add-br xapi1 xenbr0 $1],
465 [--may-exist add-br xapi1 xenbr0 $1],
466 [add-port xapi1 eth0.$1])],
467 [0], [], [], [OVS_VSCTL_CLEANUP])])
469 dnl OVS_VSCTL_FAKE_BRIDGE_TESTS([VLAN])
470 m4_define([OVS_VSCTL_FAKE_BRIDGE_TESTS], [
471 AT_BANNER([ovs-vsctl unit tests -- fake bridges (VLAN $1)])
473 AT_SETUP([simple fake bridge (VLAN $1)])
474 AT_KEYWORDS([ovs-vsctl fake-bridge])
476 OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF([$1])
477 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-br xapi1])], [1], [],
478 [ovs-vsctl: "--may-exist add-br xapi1" but xapi1 is a VLAN bridge for VLAN $1
479 ], [OVS_VSCTL_CLEANUP])
480 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-br xapi1 xxx $1])], [1], [],
481 [ovs-vsctl: "--may-exist add-br xapi1 xxx $1" but xapi1 has the wrong parent xenbr0
482 ], [OVS_VSCTL_CLEANUP])
483 AT_CHECK([RUN_OVS_VSCTL([--may-exist add-br xapi1 xenbr0 10])], [1], [],
484 [ovs-vsctl: "--may-exist add-br xapi1 xenbr0 10" but xapi1 is a VLAN bridge for the wrong VLAN $1
485 ], [OVS_VSCTL_CLEANUP])
486 CHECK_BRIDGES([xapi1, xenbr0, $1], [xenbr0, xenbr0, 0])
487 CHECK_PORTS([xenbr0], [eth0])
488 CHECK_IFACES([xenbr0], [eth0])
489 CHECK_PORTS([xapi1], [eth0.$1])
490 CHECK_IFACES([xapi1], [eth0.$1])
494 AT_SETUP([list bridges -- real and fake (VLAN $1)])
495 AT_KEYWORDS([ovs-vsctl fake-bridge])
497 OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF([$1])
498 AT_CHECK([RUN_OVS_VSCTL_ONELINE([-- list-br])], [0],
500 ], [], [OVS_VSCTL_CLEANUP])
501 AT_CHECK([RUN_OVS_VSCTL_ONELINE([-- --real list-br])], [0],
503 ], [], [OVS_VSCTL_CLEANUP])
504 AT_CHECK([RUN_OVS_VSCTL_ONELINE([-- --fake list-br])], [0],
506 ], [], [OVS_VSCTL_CLEANUP])
510 AT_SETUP([simple fake bridge + del-br fake bridge (VLAN $1)])
511 AT_KEYWORDS([ovs-vsctl fake-bridge])
513 OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF([$1])
514 AT_CHECK([RUN_OVS_VSCTL([del-br xapi1])], [0], [], [], [OVS_VSCTL_CLEANUP])
515 CHECK_BRIDGES([xenbr0, xenbr0, 0])
516 CHECK_PORTS([xenbr0], [eth0])
517 CHECK_IFACES([xenbr0], [eth0])
521 AT_SETUP([simple fake bridge + del-br real bridge (VLAN $1)])
522 AT_KEYWORDS([ovs-vsctl fake-bridge])
524 OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF([$1])
525 AT_CHECK([RUN_OVS_VSCTL([del-br xenbr0])], [0], [], [], [OVS_VSCTL_CLEANUP])
530 AT_SETUP([simple fake bridge + external IDs (VLAN $1)])
531 AT_KEYWORDS([ovs-vsctl fake-bridge])
533 OVS_VSCTL_SETUP_SIMPLE_FAKE_CONF([$1])
534 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
535 [br-set-external-id xenbr0 key0 value0],
536 [br-set-external-id xapi1 key1 value1],
537 [br-get-external-id xenbr0],
538 [br-get-external-id xenbr0 key0],
539 [br-get-external-id xapi1],
540 [br-get-external-id xapi1 key1])], [0], [
546 ], [], [OVS_VSCTL_CLEANUP])
547 CHECK_BRIDGES([xapi1, xenbr0, $1], [xenbr0, xenbr0, 0])
548 CHECK_PORTS([xenbr0], [eth0])
549 CHECK_IFACES([xenbr0], [eth0])
550 CHECK_PORTS([xapi1], [eth0.$1])
551 CHECK_IFACES([xapi1], [eth0.$1])
554 ]) # OVS_VSCTL_FAKE_BRIDGE_TESTS
556 OVS_VSCTL_FAKE_BRIDGE_TESTS([9])
557 OVS_VSCTL_FAKE_BRIDGE_TESTS([0])
559 dnl OVS_VSCTL_SETUP_BOND_FAKE_CONF([VLAN])
560 m4_define([OVS_VSCTL_SETUP_BOND_FAKE_CONF],
564 [add-bond xapi1 bond0 eth0 eth1],
565 [add-br xapi2 xapi1 $1],
566 [add-port xapi2 bond0.$1])],
567 [0], [], [], [OVS_VSCTL_CLEANUP])])
569 AT_SETUP([fake bridge on bond])
570 AT_KEYWORDS([ovs-vsctl fake-bridge])
572 OVS_VSCTL_SETUP_BOND_FAKE_CONF([11])
573 CHECK_BRIDGES([xapi1, xapi1, 0], [xapi2, xapi1, 11])
574 CHECK_PORTS([xapi1], [bond0])
575 CHECK_IFACES([xapi1], [eth0], [eth1])
576 CHECK_PORTS([xapi2], [bond0.11])
577 CHECK_IFACES([xapi2], [bond0.11])
581 AT_SETUP([fake bridge on bond + del-br fake bridge])
582 AT_KEYWORDS([ovs-vsctl fake-bridge])
584 OVS_VSCTL_SETUP_BOND_FAKE_CONF([11])
585 AT_CHECK([RUN_OVS_VSCTL_ONELINE([del-br xapi2])], [0], [
586 ], [], [OVS_VSCTL_CLEANUP])
587 CHECK_BRIDGES([xapi1, xapi1, 0])
588 CHECK_PORTS([xapi1], [bond0])
589 CHECK_IFACES([xapi1], [eth0], [eth1])
593 AT_SETUP([fake bridge on bond + del-br real bridge])
594 AT_KEYWORDS([ovs-vsctl fake-bridge])
596 OVS_VSCTL_SETUP_BOND_FAKE_CONF([11])
597 AT_CHECK([RUN_OVS_VSCTL([del-br xapi1])])
602 dnl ----------------------------------------------------------------------
603 AT_BANNER([ovs-vsctl unit tests -- manager commands])
606 AT_KEYWORDS([manager ovs-vsctl])
608 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
611 [set-manager tcp:4.5.6.7],
613 [set-manager tcp:8.9.10.11 tcp:5.4.3.2],
616 [get-manager])], [0], [
621 tcp:5.4.3.2\ntcp:8.9.10.11
624 ], [], [OVS_VSCTL_CLEANUP])
628 dnl ----------------------------------------------------------------------
629 AT_BANNER([ovs-vsctl unit tests -- database commands])
631 AT_SETUP([database commands -- positive checks])
632 AT_KEYWORDS([ovs-vsctl])
635 [RUN_OVS_VSCTL_TOGETHER([--id=@br0 create bridge name=br123],
636 [set b br123 name=br0],
637 [set o . bridges=@br0])],
638 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
640 AT_CHECK([RUN_OVS_VSCTL([list bridge], [get bridge br0 _uuid])],
641 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
643 AT_CHECK([${PERL} $srcdir/uuidfilt.pl out1 out2], [0],
651 datapath_version : ""
657 mcast_snooping_enable: false
670 ]], [ignore], [test ! -e pid || kill `cat pid`])
672 [RUN_OVS_VSCTL([--columns=fail_mode,name,datapath_type list bridge])],
677 ]], [ignore], [test ! -e pid || kill `cat pid`])
679 [RUN_OVS_VSCTL([--columns=fail_mode,name,datapath_type find bridge])],
684 ]], [ignore], [test ! -e pid || kill `cat pid`])
686 RUN_OVS_VSCTL_TOGETHER([--id=@br1 create bridge name=br1 datapath_type="foo"],
687 [--id=@br2 create bridge name=br2 external-ids:bar=quux],
688 [add o . bridges @br1 @br2])],
689 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
691 [RUN_OVS_VSCTL([--columns=name find bridge datapath_type!=foo])], [0], [stdout],
692 [ignore], [test ! -e pid || kill `cat pid`])
693 AT_CHECK([sed -n '/./p' stdout | sort], [0],
700 'other_config:datapath_id="0123456789ab"' \
701 'other_config:hwaddr="00:11:22:33:44:55"' \
702 'external-ids={"uuids"="9c45f225-a7cf-439d-976d-83db6271fda1"}' -- \
703 add bridge br0 external_ids '"roles"="local; remote; cloud"'])],
704 [0], [], [], [OVS_VSCTL_CLEANUP])
705 AT_CHECK([RUN_OVS_VSCTL_ONELINE([get bridge br0 other_config external-ids])],
706 [0], [{datapath_id="0123456789ab", hwaddr="00:11:22:33:44:55"}\n{roles="local; remote; cloud", uuids="9c45f225-a7cf-439d-976d-83db6271fda1"}
707 ], [], [OVS_VSCTL_CLEANUP])
708 AT_CHECK([RUN_OVS_VSCTL([get bridge br0 other_config:hwaddr -- --if-exists get bridge br0 other-config:nonexistent])],
709 [0], ["00:11:22:33:44:55"
711 ], [], [OVS_VSCTL_CLEANUP])
712 AT_CHECK([RUN_OVS_VSCTL([remove bridge br0 other_config hwaddr 'datapath_id=""' -- get bridge br0 other_config])],
713 [0], [{datapath_id="0123456789ab"}
714 ], [], [OVS_VSCTL_CLEANUP])
715 AT_CHECK([RUN_OVS_VSCTL([remove bridge br0 other_config 'datapath_id="0123456789ab"' -- get bridge br0 other_config])],
717 ], [], [OVS_VSCTL_CLEANUP])
718 AT_CHECK([RUN_OVS_VSCTL([clear bridge br0 external-ids -- get bridge br0 external_ids])],
720 ], [], [OVS_VSCTL_CLEANUP])
721 AT_CHECK([RUN_OVS_VSCTL_TOGETHER([destroy bridge br0],
722 [destroy bridge br1],
723 [destroy bridge br2],
724 [clear o . bridges])],
725 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
726 AT_CHECK([RUN_OVS_VSCTL([list bridge])],
727 [0], [], [], [OVS_VSCTL_CLEANUP])
728 AT_CHECK([RUN_OVS_VSCTL([--if-exists get bridge x datapath_id])],
729 [0], [], [], [OVS_VSCTL_CLEANUP])
730 AT_CHECK([RUN_OVS_VSCTL([--if-exists list bridge x])],
731 [0], [], [], [OVS_VSCTL_CLEANUP])
732 AT_CHECK([RUN_OVS_VSCTL([--if-exists set controller x connection_mode=standalone])],
733 [0], [], [], [OVS_VSCTL_CLEANUP])
735 [RUN_OVS_VSCTL([--if-exists remove netflow x targets '"1.2.3.4:567"'])],
736 [0], [], [], [OVS_VSCTL_CLEANUP])
738 [RUN_OVS_VSCTL([--if-exists clear netflow x targets])],
739 [0], [], [], [OVS_VSCTL_CLEANUP])
743 AT_SETUP([database commands -- negative checks])
744 AT_KEYWORDS([ovs-vsctl])
747 AT_CHECK([ovs-vsctl --may-exist],
748 [1], [ignore], [ovs-vsctl: missing command name (use --help for help)
749 ], [OVS_VSCTL_CLEANUP])
750 AT_CHECK([ovs-vsctl --may-exist --],
751 [1], [ignore], [ovs-vsctl: missing command name (use --help for help)
752 ], [OVS_VSCTL_CLEANUP])
753 AT_CHECK([ovs-vsctl -- --may-exist],
754 [1], [ignore], [ovs-vsctl: missing command name (use --help for help)
755 ], [OVS_VSCTL_CLEANUP])
757 AT_CHECK([RUN_OVS_VSCTL([add-br br0])],
758 [0], [ignore], [], [OVS_VSCTL_CLEANUP])
759 AT_CHECK([RUN_OVS_VSCTL([add-br br1])],
760 [0], [ignore], [], [OVS_VSCTL_CLEANUP])
761 AT_CHECK([RUN_OVS_VSCTL([set-controller br1 tcp:127.0.0.1])],
762 [0], [ignore], [], [OVS_VSCTL_CLEANUP])
764 RUN_OVS_VSCTL_TOGETHER([--id=@n create netflow targets='"1.2.3.4:567"'],
765 [set bridge br0 netflow=@n])],
766 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
767 cp stdout netflow-uuid
768 AT_CHECK([RUN_OVS_VSCTL([list netflow `cat netflow-uuid`])],
769 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
770 AT_CHECK([${PERL} $srcdir/uuidfilt.pl netflow-uuid stdout], [0],
775 add_id_to_interface : false
779 targets : ["1.2.3.4:567"]
780 ]], [ignore], [test ! -e pid || kill `cat pid`])
781 AT_CHECK([RUN_OVS_VSCTL([list interx x])],
782 [1], [], [ovs-vsctl: unknown table "interx"
783 ], [OVS_VSCTL_CLEANUP])
784 AT_CHECK([RUN_OVS_VSCTL([list bridge x])],
785 [1], [], [ovs-vsctl: no row "x" in table Bridge
786 ], [OVS_VSCTL_CLEANUP])
787 AT_CHECK([RUN_OVS_VSCTL([get bridge x datapath_id])],
788 [1], [], [ovs-vsctl: no row "x" in table Bridge
789 ], [OVS_VSCTL_CLEANUP])
790 AT_CHECK([RUN_OVS_VSCTL([get bridge br0 d])],
791 [1], [], [ovs-vsctl: Bridge contains more than one column whose name matches "d"
792 ], [OVS_VSCTL_CLEANUP])
793 AT_CHECK([RUN_OVS_VSCTL([get bridge br0 x])],
794 [1], [], [ovs-vsctl: Bridge does not contain a column whose name matches "x"
795 ], [OVS_VSCTL_CLEANUP])
796 AT_CHECK([RUN_OVS_VSCTL([get bridge br0 :y=z])],
797 [1], [], [ovs-vsctl: :y=z: missing column name
798 ], [OVS_VSCTL_CLEANUP])
799 AT_CHECK([RUN_OVS_VSCTL([get bridge br0 datapath_id:y=z])],
800 [1], [], [ovs-vsctl: datapath_id:y=z: trailing garbage "=z" in argument
801 ], [OVS_VSCTL_CLEANUP])
802 AT_CHECK([RUN_OVS_VSCTL([set bridge br0 'datapath_id:y>=z'])],
803 [1], [], [ovs-vsctl: datapath_id:y>=z: argument does not end in "=" followed by a value.
804 ], [OVS_VSCTL_CLEANUP])
805 AT_CHECK([RUN_OVS_VSCTL([set controller x connection_mode=standalone])],
806 [1], [], [ovs-vsctl: no row "x" in table Controller
807 ], [OVS_VSCTL_CLEANUP])
808 AT_CHECK([RUN_OVS_VSCTL([wait-until bridge br0 datapath_id:y,z])],
809 [1], [], [ovs-vsctl: datapath_id:y,z: argument does not end in "=", "!=", "<", ">", "<=", ">=", "{=}", "{!=}", "{<}", "{>}", "{<=}", or "{>=}" followed by a value.
810 ], [OVS_VSCTL_CLEANUP])
811 AT_CHECK([RUN_OVS_VSCTL([get bridge br0 datapath_id::])],
812 [1], [], [ovs-vsctl: datapath_id::: trailing garbage ":" in argument
813 ], [OVS_VSCTL_CLEANUP])
814 AT_CHECK([RUN_OVS_VSCTL([get bridge br0 datapath_id:x])],
815 [1], [], [ovs-vsctl: cannot specify key to get for non-map column datapath_id
816 ], [OVS_VSCTL_CLEANUP])
817 AT_CHECK([RUN_OVS_VSCTL([get bridge br0 external_ids:x])],
818 [1], [], [ovs-vsctl: no key "x" in Bridge record "br0" column external_ids
819 ], [OVS_VSCTL_CLEANUP])
820 AT_CHECK([RUN_OVS_VSCTL([set bridge br0 flood_vlans=-1])],
821 [1], [], [ovs-vsctl: constraint violation: -1 is not in the valid range 0 to 4095 (inclusive)
822 ], [OVS_VSCTL_CLEANUP])
823 AT_CHECK([RUN_OVS_VSCTL([set bridge br0 flood_vlans=4096])],
824 [1], [], [ovs-vsctl: constraint violation: 4096 is not in the valid range 0 to 4095 (inclusive)
825 ], [OVS_VSCTL_CLEANUP])
826 AT_CHECK([RUN_OVS_VSCTL([set c br1 'connection-mode=xyz'])],
827 [1], [], [[ovs-vsctl: constraint violation: xyz is not one of the allowed values ([in-band, out-of-band])
828 ]], [OVS_VSCTL_CLEANUP])
829 AT_CHECK([RUN_OVS_VSCTL([set c br1 connection-mode:x=y])],
830 [1], [], [ovs-vsctl: cannot specify key to set for non-map column connection_mode
831 ], [OVS_VSCTL_CLEANUP])
832 AT_CHECK([RUN_OVS_VSCTL([add bridge br1 datapath_id x y])],
833 [1], [], [ovs-vsctl: "add" operation would put 2 values in column datapath_id of table Bridge but the maximum number is 1
834 ], [OVS_VSCTL_CLEANUP])
835 AT_CHECK([RUN_OVS_VSCTL([remove netflow `cat netflow-uuid` targets '"1.2.3.4:567"'])],
836 [1], [], [ovs-vsctl: "remove" operation would put 0 values in column targets of table NetFlow but the minimum number is 1
837 ], [OVS_VSCTL_CLEANUP])
838 AT_CHECK([RUN_OVS_VSCTL([remove netflow x targets '"1.2.3.4:567"'])],
839 [1], [], [ovs-vsctl: no row "x" in table NetFlow
840 ], [OVS_VSCTL_CLEANUP])
841 AT_CHECK([RUN_OVS_VSCTL([clear netflow x targets])],
842 [1], [], [ovs-vsctl: no row "x" in table NetFlow
843 ], [OVS_VSCTL_CLEANUP])
844 AT_CHECK([RUN_OVS_VSCTL([clear netflow `cat netflow-uuid` targets])],
845 [1], [], [ovs-vsctl: "clear" operation cannot be applied to column targets of table NetFlow, which is not allowed to be empty
846 ], [OVS_VSCTL_CLEANUP])
847 AT_CHECK([RUN_OVS_VSCTL([destroy bridge br2])],
848 [1], [], [ovs-vsctl: no row "br2" in table Bridge
849 ], [OVS_VSCTL_CLEANUP])
850 AT_CHECK([RUN_OVS_VSCTL([add in br1 name x])],
851 [1], [], [ovs-vsctl: cannot modify read-only column name in table Interface
852 ], [OVS_VSCTL_CLEANUP])
853 AT_CHECK([RUN_OVS_VSCTL([set port br0 name=br2])],
854 [1], [], [ovs-vsctl: cannot modify read-only column name in table Port
855 ], [OVS_VSCTL_CLEANUP])
856 AT_CHECK([RUN_OVS_VSCTL([remove bridge br0 name br1])],
857 [1], [], [ovs-vsctl: cannot modify read-only column name in table Bridge
858 ], [OVS_VSCTL_CLEANUP])
859 AT_CHECK([RUN_OVS_VSCTL([remove bridge br1 flood-vlans true])],
860 [1], [], [ovs-vsctl: "true" is not a valid integer
861 ], [OVS_VSCTL_CLEANUP])
862 AT_CHECK([RUN_OVS_VSCTL([clear bridge br1 name])],
863 [1], [], [ovs-vsctl: cannot modify read-only column name in table Bridge
864 ], [OVS_VSCTL_CLEANUP])
868 AT_SETUP([database commands -- conditions])
869 AT_KEYWORDS([ovs-vsctl])
870 ON_EXIT([kill `cat pid`])
873 [RUN_OVS_VSCTL_TOGETHER(
875 [add-br br1], [set bridge br1 flood_vlans=0 other-config:x='""'],
876 [add-br br2], [set bridge br2 flood_vlans=1 other-config:x=y],
877 [add-br br3], [set bridge br3 flood_vlans=0,1 other-config:x=z],
878 [add-br br4], [set bridge br4 flood_vlans=2],
879 [add-br br5], [set bridge br5 flood_vlans=0,2],
880 [add-br br6], [set bridge br6 flood_vlans=1,2],
881 [add-br br7], [set bridge br7 flood_vlans=0,1,2])], [0], [
897 m4_define([VSCTL_CHECK_FIND],
898 [AT_CHECK([echo `ovs-vsctl --bare --no-wait -vreconnect:emer --db=unix:socket -- --columns=name find bridge '$1' | sort`], [0], [$2
901 # Arithmetic relational operators without keys.
902 VSCTL_CHECK_FIND([flood_vlans=0], [br1])
903 VSCTL_CHECK_FIND([flood_vlans=1], [br2])
904 VSCTL_CHECK_FIND([flood_vlans=0,2], [br5])
905 VSCTL_CHECK_FIND([flood_vlans=0,1,2], [br7])
906 VSCTL_CHECK_FIND([flood_vlans=3], [])
908 VSCTL_CHECK_FIND([flood_vlans!=0], [br0 br2 br3 br4 br5 br6 br7])
909 VSCTL_CHECK_FIND([flood_vlans!=1], [br0 br1 br3 br4 br5 br6 br7])
910 VSCTL_CHECK_FIND([flood_vlans!=0,2], [br0 br1 br2 br3 br4 br6 br7])
911 VSCTL_CHECK_FIND([flood_vlans!=0,1,2], [br0 br1 br2 br3 br4 br5 br6])
912 VSCTL_CHECK_FIND([flood_vlans!=3], [br0 br1 br2 br3 br4 br5 br6 br7])
914 VSCTL_CHECK_FIND([flood_vlans<2], [br0 br1 br2])
915 VSCTL_CHECK_FIND([flood_vlans<0,2], [br0 br1 br2 br3 br4])
916 VSCTL_CHECK_FIND([flood_vlans>1], [br3 br4 br5 br6 br7])
917 VSCTL_CHECK_FIND([flood_vlans>0,1], [br5 br6 br7])
918 VSCTL_CHECK_FIND([flood_vlans<=2], [br0 br1 br2 br4])
919 VSCTL_CHECK_FIND([flood_vlans<=0,2], [br0 br1 br2 br3 br4 br5])
920 VSCTL_CHECK_FIND([flood_vlans>=1], [br2 br3 br4 br5 br6 br7])
921 VSCTL_CHECK_FIND([flood_vlans>=0,1], [br3 br5 br6 br7])
923 # Set relational operators without keys.
924 VSCTL_CHECK_FIND([flood_vlans{=}0], [br1])
925 VSCTL_CHECK_FIND([flood_vlans{=}1], [br2])
926 VSCTL_CHECK_FIND([flood_vlans{=}0,2], [br5])
927 VSCTL_CHECK_FIND([flood_vlans{=}0,1,2], [br7])
928 VSCTL_CHECK_FIND([flood_vlans{=}3], [])
930 VSCTL_CHECK_FIND([flood_vlans{!=}0], [br0 br2 br3 br4 br5 br6 br7])
931 VSCTL_CHECK_FIND([flood_vlans{!=}1], [br0 br1 br3 br4 br5 br6 br7])
932 VSCTL_CHECK_FIND([flood_vlans{!=}0,2], [br0 br1 br2 br3 br4 br6 br7])
933 VSCTL_CHECK_FIND([flood_vlans{!=}0,1,2], [br0 br1 br2 br3 br4 br5 br6])
934 VSCTL_CHECK_FIND([flood_vlans{!=}3], [br0 br1 br2 br3 br4 br5 br6 br7])
936 VSCTL_CHECK_FIND([flood_vlans{<}[[]]], [])
937 VSCTL_CHECK_FIND([flood_vlans{<=}[[]]], [br0])
938 VSCTL_CHECK_FIND([flood_vlans{<}0], [br0])
939 VSCTL_CHECK_FIND([flood_vlans{<=}0], [br0 br1])
940 VSCTL_CHECK_FIND([flood_vlans{<}1,2], [br0 br2 br4])
941 VSCTL_CHECK_FIND([flood_vlans{<=}1,2], [br0 br2 br4 br6])
943 VSCTL_CHECK_FIND([flood_vlans{>}[[]]], [br1 br2 br3 br4 br5 br6 br7])
944 VSCTL_CHECK_FIND([flood_vlans{>=}[[]]], [br0 br1 br2 br3 br4 br5 br6 br7])
945 VSCTL_CHECK_FIND([flood_vlans{>}0], [br3 br5 br7])
946 VSCTL_CHECK_FIND([flood_vlans{>=}0], [br1 br3 br5 br7])
947 VSCTL_CHECK_FIND([flood_vlans{>}0,2], [br7])
948 VSCTL_CHECK_FIND([flood_vlans{>=}1,2], [br6 br7])
949 VSCTL_CHECK_FIND([flood_vlans{>=}0,2], [br5 br7])
951 # Arithmetic relational operators with keys.
952 VSCTL_CHECK_FIND([other-config:x=""], [br1])
953 VSCTL_CHECK_FIND([other-config:x=y], [br2])
954 VSCTL_CHECK_FIND([other-config:x=z], [br3])
956 VSCTL_CHECK_FIND([other-config:x!=""], [br2 br3])
957 VSCTL_CHECK_FIND([other-config:x!=y], [br1 br3])
958 VSCTL_CHECK_FIND([other-config:x!=z], [br1 br2])
960 VSCTL_CHECK_FIND([other-config:x>y], [br3])
961 VSCTL_CHECK_FIND([other-config:x>=y], [br2 br3])
962 VSCTL_CHECK_FIND([other-config:x<y], [br1])
963 VSCTL_CHECK_FIND([other-config:x<=y], [br1 br2])
965 # Set relational operators with keys.
966 VSCTL_CHECK_FIND([other-config:x{=}[[]]], [br0 br4 br5 br6 br7])
967 VSCTL_CHECK_FIND([other-config:x{=}""], [br1])
968 VSCTL_CHECK_FIND([other-config:x{=}y], [br2])
969 VSCTL_CHECK_FIND([other-config:x{=}z], [br3])
971 VSCTL_CHECK_FIND([other-config:x{!=}[[]]], [br1 br2 br3])
972 VSCTL_CHECK_FIND([other-config:x{!=}""], [br0 br2 br3 br4 br5 br6 br7])
973 VSCTL_CHECK_FIND([other-config:x{!=}y], [br0 br1 br3 br4 br5 br6 br7])
974 VSCTL_CHECK_FIND([other-config:x{!=}z], [br0 br1 br2 br4 br5 br6 br7])
976 VSCTL_CHECK_FIND([other-config:x{<=}[[]]], [br0 br4 br5 br6 br7])
977 VSCTL_CHECK_FIND([other-config:x{<=}x], [br0 br4 br5 br6 br7])
978 VSCTL_CHECK_FIND([other-config:x{<=}""], [br0 br1 br4 br5 br6 br7])
979 VSCTL_CHECK_FIND([other-config:x{<=}y], [br0 br2 br4 br5 br6 br7])
980 VSCTL_CHECK_FIND([other-config:x{<=}z], [br0 br3 br4 br5 br6 br7])
981 VSCTL_CHECK_FIND([other-config:x{<=}x,y,z], [br0 br2 br3 br4 br5 br6 br7])
983 VSCTL_CHECK_FIND([other-config:x{<}[[]]], [])
984 VSCTL_CHECK_FIND([other-config:x{<}x], [br0 br4 br5 br6 br7])
985 VSCTL_CHECK_FIND([other-config:x{<}""], [br0 br4 br5 br6 br7])
986 VSCTL_CHECK_FIND([other-config:x{<}y], [br0 br4 br5 br6 br7])
987 VSCTL_CHECK_FIND([other-config:x{<}z], [br0 br4 br5 br6 br7])
989 VSCTL_CHECK_FIND([other-config:x{>=}[[]]], [br0 br1 br2 br3 br4 br5 br6 br7])
990 VSCTL_CHECK_FIND([other-config:x{>=}x], [])
991 VSCTL_CHECK_FIND([other-config:x{>=}""], [br1])
992 VSCTL_CHECK_FIND([other-config:x{>=}y], [br2])
993 VSCTL_CHECK_FIND([other-config:x{>=}z], [br3])
995 VSCTL_CHECK_FIND([other-config:x{>}[[]]], [br1 br2 br3])
996 VSCTL_CHECK_FIND([other-config:x{>}x], [])
997 VSCTL_CHECK_FIND([other-config:x{>}""], [])
998 VSCTL_CHECK_FIND([other-config:x{>}y], [])
999 VSCTL_CHECK_FIND([other-config:x{>}z], [])
1003 AT_SETUP([database commands -- wait-until immediately true])
1004 AT_KEYWORDS([ovs-vsctl])
1006 AT_CHECK([RUN_OVS_VSCTL(
1008 [add-bond br0 bond0 eth0 eth1],
1009 [set port bond0 bond_updelay=500 other-config:abc=def])],
1010 [0], [], [], [OVS_VSCTL_CLEANUP])
1011 AT_CHECK([RUN_OVS_VSCTL([[wait-until Open_vSwitch . manager_options=[]]])],
1012 [0], [], [], [OVS_VSCTL_CLEANUP])
1013 AT_CHECK([RUN_OVS_VSCTL([[wait-until Open_vSwitch . bridges!=[]]])],
1014 [0], [], [], [OVS_VSCTL_CLEANUP])
1015 AT_CHECK([RUN_OVS_VSCTL([[wait-until Port bond0 other-config:abc=def]])],
1016 [0], [], [], [OVS_VSCTL_CLEANUP])
1017 AT_CHECK([RUN_OVS_VSCTL([[wait-until port bond0 'bond_updelay>50' 'other-config:abc>d' 'other-config:abc<e']])],
1018 [0], [], [], [OVS_VSCTL_CLEANUP])
1022 AT_SETUP([database commands -- wait-until must wait])
1023 AT_KEYWORDS([ovs-vsctl])
1027 # Start ovs-vsctls in background.
1028 (RUN_OVS_VSCTL([[wait-until o . bridges!=[] -- get bridge br10 other-config:abc]])) > stdout1 &
1029 (RUN_OVS_VSCTL([[wait-until bridge br1 -- get bridge br1 other-config:abc]])) > stdout2 &
1030 (RUN_OVS_VSCTL([[wait-until bridge br1 other-config={abc=def} -- get bridge br1 other-config]])) > stdout3 &
1031 (RUN_OVS_VSCTL([[wait-until port bond0 'bond_updelay>50' -- get port bond0 bond-updelay]])) > stdout4 &
1033 # Give the ovs-vsctls a chance to read the database
1036 AT_CHECK([RUN_OVS_VSCTL([add-br br10 -- set bridge br10 other-config:abc=quux])
1037 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])],
1038 [0], [], [], [OVS_VSCTL_CLEANUP])
1040 # Wait for the ovs-vsctls to finish.
1044 AT_CHECK([cat stdout1], [0], [quux
1045 ], [], [OVS_VSCTL_CLEANUP])
1046 AT_CHECK([cat stdout2], [0], [def
1047 ], [], [OVS_VSCTL_CLEANUP])
1048 AT_CHECK([cat stdout3], [0], [{abc=def}
1049 ], [], [OVS_VSCTL_CLEANUP])
1050 AT_CHECK([cat stdout4], [0], [500
1051 ], [], [OVS_VSCTL_CLEANUP])
1056 AT_SETUP([--id option on create, get commands])
1057 AT_KEYWORDS([ovs-vsctl])
1059 AT_CHECK([RUN_OVS_VSCTL([add-br br0],
1060 [add-port br0 eth0],
1061 [add-port br0 eth1])])
1063 [RUN_OVS_VSCTL_TOGETHER(
1064 [set bridge br0 mirrors=@m],
1065 [--id=@eth0 get port eth0],
1066 [--id=@eth1 get port eth1],
1067 [--id=@m create mirror name=mymirror select-dst-port=@eth0 select-src-port=@eth0 output-port=@eth1])],
1068 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
1070 [${PERL} $srcdir/uuidfilt.pl stdout], [0], [dnl
1076 [], [OVS_VSCTL_CLEANUP])
1079 [list port eth0 eth1],
1081 [list bridge br0])],
1082 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
1084 [sed -n -e '/uuid/p' -e '/name/p' -e '/mirrors/p' -e '/select/p' -e '/output/p' < stdout | ${PERL} $srcdir/uuidfilt.pl], [0], [dnl
1094 select_dst_port : [<0>]
1095 select_src_port : [<0>]
1101 [], [OVS_VSCTL_CLEANUP])
1105 AT_SETUP([unreferenced record warnings])
1106 AT_KEYWORDS([ovs-vsctl])
1109 [ovs-vsctl -vPATTERN:console:'%c|%p|%m' --no-wait -vreconnect:emer --db=unix:socket \
1110 -- create Bridge name=br0 | ${PERL} $srcdir/uuidfilt.pl],
1112 ], [vsctl|WARN|applying "create" command to table Bridge without --id option will have no effect
1113 ], [OVS_VSCTL_CLEANUP])
1115 [ovs-vsctl -vPATTERN:console:'%c|%p|%m' --no-wait -vreconnect:emer --db=unix:socket \
1116 -- --id=@br0 create Bridge name=br0 | ${PERL} $srcdir/uuidfilt.pl],
1118 ], [vsctl|WARN|row id "@br0" was created but no reference to it was inserted, so it will not actually appear in the database
1119 ], [OVS_VSCTL_CLEANUP])
1121 [ovs-vsctl -vPATTERN:console:'%c|%p|%m' --no-wait -vreconnect:emer --db=unix:socket \
1122 -- --id=@eth0_iface create Interface name=eth0 \
1123 -- --id=@eth0 create Port name=eth0 interfaces=@eth0_iface \
1124 -- --id=@m0 create Mirror name=m0 output_port=@eth0 \
1125 -- --id=@br0 create Bridge name=br0 mirrors=@m0 \
1126 -- set Open_vSwitch . bridges=@br0 | ${PERL} $srcdir/uuidfilt.pl],
1131 ], [vsctl|WARN|row id "@eth0" was created but only a weak reference to it was inserted, so it will not actually appear in the database
1132 ], [OVS_VSCTL_CLEANUP])
1136 dnl This test really shows a bug -- "create" followed by "list" in
1137 dnl the same execution shows the wrong UUID on the "list" command.
1138 dnl The bug is documented in ovs-vsctl.8.
1139 AT_SETUP([created row UUID is wrong in same execution])
1140 AT_KEYWORDS([ovs-vsctl])
1142 AT_CHECK([RUN_OVS_VSCTL([--id=@br0 create Bridge name=br0 -- add Open_vSwitch . bridges @br0 -- list bridge])],
1143 [0], [stdout], [], [OVS_VSCTL_CLEANUP])
1144 AT_CHECK([${PERL} $srcdir/uuidfilt.pl stdout], [0],
1150 datapath_version : ""
1156 mcast_snooping_enable: false
1168 ]], [ignore], [test ! -e pid || kill `cat pid`])
1172 dnl This test will create a linux-htb QoS record that
1173 dnl points to a few queues and use it on a1 and a2 port.
1174 dnl It also destroys all records from Qos and Queue table.
1175 AT_SETUP([--all option on destroy command])
1176 AT_KEYWORDS([ovs-vsctl])
1178 AT_CHECK([RUN_OVS_VSCTL(
1181 [add-port a a2])], [0], [], [], [OVS_VSCTL_CLEANUP])
1182 CHECK_BRIDGES([a, a, 0])
1183 CHECK_PORTS([a], [a1], [a2])
1184 CHECK_IFACES([a], [a1], [a2])
1185 AT_CHECK([RUN_OVS_VSCTL_TOGETHER(
1186 [set Port a1 qos=@newqos],
1187 [set Port a2 qos=@newqos],
1188 [--id=@newqos create QoS type=linux-htb other-config:max-rate=1000000000 queues=0=@q0,1=@q1],
1189 [--id=@q0 create Queue other-config:min-rate=100000000 other-config:max-rate=100000000],
1190 [--id=@q1 create Queue other-config:min-rate=500000000])], [0], [ignore], [], [OVS_VSCTL_CLEANUP])
1191 AT_CHECK([RUN_OVS_VSCTL(
1192 [--columns=other_config,type list Qos])], [0],
1193 [other_config : {max-rate="1000000000"}
1195 ], [], [OVS_VSCTL_CLEANUP])
1196 AT_CHECK([RUN_OVS_VSCTL(
1197 [--columns=other_config list Queue | sort | sed '/^$/d'])], [0],
1198 [other_config : {max-rate="100000000", min-rate="100000000"}
1199 other_config : {min-rate="500000000"}
1200 ], [], [OVS_VSCTL_CLEANUP])
1201 AT_CHECK([RUN_OVS_VSCTL(
1202 [clear Port a1 qos],
1203 [clear Port a2 qos])], [0], [], [], [OVS_VSCTL_CLEANUP])
1204 AT_CHECK([RUN_OVS_VSCTL(
1205 [--columns=qos list Port a1 a2])], [0],
1209 ]], [], [OVS_VSCTL_CLEANUP])
1210 AT_CHECK([RUN_OVS_VSCTL(
1211 [--all destroy Qos])], [0], [], [], [OVS_VSCTL_CLEANUP])
1212 AT_CHECK([RUN_OVS_VSCTL(
1213 [-- list Qos])], [0], [], [], [OVS_VSCTL_CLEANUP])
1214 AT_CHECK([RUN_OVS_VSCTL(
1215 [--all destroy Queue])], [0], [], [], [OVS_VSCTL_CLEANUP])
1216 AT_CHECK([RUN_OVS_VSCTL(
1217 [-- list Queue])], [0], [], [], [OVS_VSCTL_CLEANUP])
1221 dnl ----------------------------------------------------------------------
1222 AT_BANNER([ovs-vsctl add-port -- reserved port names])
1224 AT_SETUP([add-port -- reserved names 1])
1227 # Test creating all reserved port names
1238 # Try creating the port
1239 AT_CHECK([ovs-vsctl add-port br0 reserved_name], [0], [], [dnl
1240 ovs-vsctl: Error detected while setting up 'reserved_name'. See ovs-vswitchd log for details.
1242 # Detect the warning log message
1243 AT_CHECK([sed -n "s/^.*\(|bridge|WARN|.*\)$/\1/p" ovs-vswitchd.log], [0], [dnl
1244 |bridge|WARN|could not create interface reserved_name, name is reserved
1246 # Delete the warning log message
1247 AT_CHECK([sed "/|bridge|WARN|/d" ovs-vswitchd.log > ovs-vswitchd.log], [0], [], [])
1249 AT_CHECK([ovs-vsctl del-port br0 reserved_name], [0], [], [])])
1253 AT_SETUP([add-port -- reserved names 2])
1254 # Creates all type of tunnel ports
1255 OVS_VSWITCHD_START([add-port br0 p1 -- set Interface p1 type=gre \
1256 options:remote_ip=1.1.1.1 ofport_request=1\
1257 -- add-port br0 p2 -- set Interface p2 type=gre64 \
1258 options:local_ip=2.2.2.2 options:remote_ip=1.1.1.1 \
1260 -- add-port br0 p3 -- set Interface p3 type=lisp \
1261 options:remote_ip=2.2.2.2 ofport_request=3 \
1262 -- add-port br0 p4 -- set Interface p4 type=vxlan \
1263 options:remote_ip=2.2.2.2 ofport_request=4 \
1264 -- add-port br0 p5 -- set Interface p5 type=geneve \
1265 options:remote_ip=2.2.2.2 ofport_request=5])
1267 # Test creating all reserved tunnel port names
1276 # Try creating the port
1277 AT_CHECK([ovs-vsctl add-port br0 reserved_name], [0], [], [dnl
1278 ovs-vsctl: Error detected while setting up 'reserved_name'. See ovs-vswitchd log for details.
1280 # Detect the warning log message
1281 AT_CHECK([sed -n "s/^.*\(|bridge|WARN|.*\)$/\1/p" ovs-vswitchd.log], [0], [dnl
1282 |bridge|WARN|could not create interface reserved_name, name is reserved
1284 # Delete the warning log message
1285 AT_CHECK([sed "/|bridge|WARN|/d" ovs-vswitchd.log > ovs-vswitchd.log], [0], [], [])
1287 AT_CHECK([ovs-vsctl del-port br0 reserved_name], [0], [], [])])
1291 AT_SETUP([naming in db commands])
1294 dnl First check that the database commands can refer to row by database UUID.
1295 AT_CHECK([RUN_OVS_VSCTL([add-br br0])])
1296 uuid=`[]RUN_OVS_VSCTL(get port br0 _uuid)`
1297 AT_CHECK([RUN_OVS_VSCTL([get port $uuid name])], [0], ["br0"
1300 dnl Next check that, if a database row is given a name that has the same form
1301 dnl as the database UUIDs, the name can still be used to refer to rows.
1302 AT_CHECK([RUN_OVS_VSCTL([add-br 0fcd11a1-2ba8-4b38-a358-4bccf2bf3057])])
1303 AT_CHECK([RUN_OVS_VSCTL([get interface 0fcd11a1-2ba8-4b38-a358-4bccf2bf3057 type])], [0], [internal