1 m4_define([STRIP_XIDS], [[sed 's/ (xid=0x[0-9a-fA-F]*)//']])
2 m4_define([STRIP_DURATION], [[sed 's/\bduration=[0-9.]*s/duration=?s/']])
3 m4_define([TESTABLE_LOG], [-vPATTERN:ANY:'%c|%p|%m'])
5 m4_define([OVS_VSWITCHD_START],
6 [dnl Skip this test if running as root. Otherwise ovs-vswitchd will tear
7 dnl down any existing datapaths if the kernel module is loaded.
8 AT_SKIP_IF([test "`id -u`" = 0])
10 OVS_RUNDIR=$PWD; export OVS_RUNDIR
11 OVS_LOGDIR=$PWD; export OVS_LOGDIR
12 OVS_SYSCONFDIR=$PWD; export OVS_SYSCONFDIR
13 trap 'kill `cat ovsdb-server.pid ovs-vswitchd.pid`' 0
17 touch openvswitch/.conf.db.~lock~
18 AT_CHECK([ovsdb-tool create openvswitch/conf.db $abs_top_srcdir/vswitchd/vswitch.ovsschema])
20 dnl Start ovsdb-server.
21 AT_CHECK([ovsdb-server --detach --pidfile --log-file --remote=punix:$OVS_RUNDIR/db.sock], [0], [], [stderr])
22 AT_CHECK([[sed < stderr '/vlog|INFO|opened log file/d']])
23 AT_CAPTURE_FILE([ovsdb-server.log])
25 dnl Initialize database.
26 AT_CHECK([ovs-vsctl --no-wait init])
28 dnl Start ovs-vswitchd.
29 AT_CHECK([ovs-vswitchd --detach --pidfile --enable-dummy --log-file], [0], [], [stderr])
30 AT_CAPTURE_FILE([ovs-vswitchd.log])
31 AT_CHECK([[sed < stderr '
32 /vlog|INFO|opened log file/d
34 /dpif_linux|ERR|Generic Netlink family.*does not exist/d
35 /dpif|WARN|failed to enumerate system datapaths: No such file or directory/d
36 /ofproto|INFO|using datapath ID/d
37 /ofproto|INFO|datapath ID changed to fedcba9876543210/d']])
39 dnl Add bridges, ports, etc.
40 AT_CHECK([ovs-vsctl -- add-br br0 -- set bridge br0 datapath-type=dummy other-config:datapath-id=fedcba9876543210 other-config:hwaddr=aa:55:aa:55:00:00 fail-mode=secure -- $1])
43 m4_define([OVS_VSWITCHD_STOP],
44 [AT_CHECK([ovs-appctl -t ovs-vswitchd exit])
45 AT_CHECK([ovs-appctl -t ovsdb-server exit])