netdev-dpdk: fix mbuf leaks
[cascardo/ovs.git] / tests / ovs-xapi-sync.at
1 AT_BANNER([ovs-xapi-sync])
2
3 AT_SETUP([ovs-xapi-sync])
4 AT_SKIP_IF([test $HAVE_PYTHON = no])
5
6 # Mock up the XenAPI.
7 cp "$top_srcdir/tests/MockXenAPI.py" XenAPI.py
8 PYTHONPATH=`pwd`:$PYTHONPATH
9 export PYTHONPATH
10
11 cp "$top_srcdir/vswitchd/vswitch.ovsschema" .
12
13 cp "$top_srcdir/xenserver/usr_share_openvswitch_scripts_ovs-xapi-sync" \
14    ovs-xapi-sync
15
16 on_exit 'kill `cat pid ovs-xapi-sync.pid`'
17
18 mkdir var var/run
19 touch var/run/xapi_init_complete.cookie
20
21 ovs_vsctl () {
22     ovs-vsctl --no-wait -vreconnect:emer --db=unix:socket "$@"
23 }
24
25 # Start ovsdb-server.
26 OVS_VSCTL_SETUP
27
28 # Start ovs-xapi-sync.
29 AT_CHECK([$PYTHON ./ovs-xapi-sync "--pidfile=`pwd`/ovs-xapi-sync.pid" \
30                   "--root-prefix=`pwd`" unix:socket >log 2>&1 &])
31 AT_CAPTURE_FILE([log])
32
33 # Add bridges and check ovs-xapi-sync's work.
34 AT_CHECK([ovs_vsctl -- add-br xenbr0 -- add-br xenbr1])
35 OVS_WAIT_UNTIL([test "X`ovs_vsctl get bridge xenbr0 fail-mode`" != "X[[]]"])
36 AT_CHECK([ovs_vsctl \
37                 -- get bridge xenbr0 fail-mode other-config external-ids \
38                 -- get bridge xenbr1 fail-mode other-config external-ids], [0],
39          [[secure
40 {}
41 {bridge-id="custom bridge ID"}
42 secure
43 {disable-in-band="true"}
44 {}
45 ]])
46
47 # Add vif and check daemon's work.
48 AT_CHECK([ovs_vsctl \
49                 -- add-port xenbr0 vif1.0 \
50                 -- set Interface vif1.0 'external-ids={attached-mac="00:11:22:33:44:55", xs-network-uuid="9b66c68b-a74e-4d34-89a5-20a8ab352d1e", xs-vif-uuid="6ab1b260-398e-49ba-827b-c7696108964c", xs-vm-uuid="fcb8a3f6-dc04-41d2-8b8a-55afd2b755b8"'}])
51 OVS_WAIT_UNTIL([ovs_vsctl get interface vif1.0 external-ids:iface-id >/dev/null 2>&1])
52 AT_CHECK([ovs_vsctl get interface vif1.0 external-ids], [0],
53   [{attached-mac="00:11:22:33:44:55", iface-id="custom iface ID", iface-status=active, vm-id="custom vm ID", xs-network-uuid="9b66c68b-a74e-4d34-89a5-20a8ab352d1e", xs-vif-uuid="6ab1b260-398e-49ba-827b-c7696108964c", xs-vm-uuid="fcb8a3f6-dc04-41d2-8b8a-55afd2b755b8"}
54 ])
55
56 # Add corresponding tap and check daemon's work.
57 AT_CHECK([ovs_vsctl add-port xenbr0 tap1.0])
58 OVS_WAIT_UNTIL([ovs_vsctl get interface tap1.0 external-ids:iface-id >/dev/null 2>&1])
59 AT_CHECK([ovs_vsctl \
60                 -- get interface vif1.0 external-ids \
61                 -- get interface tap1.0 external-ids], [0],
62   [{attached-mac="00:11:22:33:44:55", iface-id="custom iface ID", iface-status=inactive, vm-id="custom vm ID", xs-network-uuid="9b66c68b-a74e-4d34-89a5-20a8ab352d1e", xs-vif-uuid="6ab1b260-398e-49ba-827b-c7696108964c", xs-vm-uuid="fcb8a3f6-dc04-41d2-8b8a-55afd2b755b8"}
63 {attached-mac="00:11:22:33:44:55", iface-id="custom iface ID", iface-status=active, vm-id="custom vm ID", xs-network-uuid="9b66c68b-a74e-4d34-89a5-20a8ab352d1e", xs-vif-uuid="6ab1b260-398e-49ba-827b-c7696108964c", xs-vm-uuid="fcb8a3f6-dc04-41d2-8b8a-55afd2b755b8"}
64 ])
65
66 # Remove corresponding tap and check daemon's work.
67 AT_CHECK([ovs_vsctl del-port tap1.0])
68 OVS_WAIT_UNTIL([test `ovs_vsctl get interface vif1.0 external-ids:iface-status` = active])
69 AT_CHECK([ovs_vsctl get interface vif1.0 external-ids], [0],
70   [{attached-mac="00:11:22:33:44:55", iface-id="custom iface ID", iface-status=active, vm-id="custom vm ID", xs-network-uuid="9b66c68b-a74e-4d34-89a5-20a8ab352d1e", xs-vif-uuid="6ab1b260-398e-49ba-827b-c7696108964c", xs-vm-uuid="fcb8a3f6-dc04-41d2-8b8a-55afd2b755b8"}
71 ])
72
73 OVSDB_SERVER_SHUTDOWN
74
75 AT_CLEANUP