ofproto-dpif: Add tests for VLAN handling.
[sliver-openvswitch.git] / tests / ofproto-macros.at
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'])
4
5 m4_define([OFPROTO_START],
6   [OVS_RUNDIR=$PWD; export OVS_RUNDIR
7    OVS_LOGDIR=$PWD; export OVS_LOGDIR
8    trap 'kill `cat test-openflowd.pid`' 0
9    AT_CAPTURE_FILE([test-openflowd.log])
10    AT_CHECK(
11      [test-openflowd --detach --pidfile --enable-dummy --log-file --fail=closed dummy@br0 none --datapath-id=fedcba9876543210 $1],
12      [0], [], [stderr])
13    AT_CHECK([[sed < stderr '
14 /vlog|INFO|opened log file/d
15 /openflowd|INFO|Open vSwitch version/d
16 /openflowd|INFO|OpenFlow protocol version/d
17 /ofproto|INFO|using datapath ID/d
18 /ofproto|INFO|datapath ID changed to fedcba9876543210/d']])
19 ])
20
21 m4_define([OFPROTO_STOP],
22   [AT_CHECK([ovs-appctl -t test-openflowd exit])
23    trap '' 0])
24
25 m4_define([OVS_VSWITCHD_START],
26   [dnl Skip this test if running as root.  Otherwise ovs-vswitchd will tear
27    dnl down any existing datapaths if the kernel module is loaded.
28    AT_SKIP_IF([test "`id -u`" = 0])
29
30    OVS_RUNDIR=$PWD; export OVS_RUNDIR
31    OVS_LOGDIR=$PWD; export OVS_LOGDIR
32    OVS_SYSCONFDIR=$PWD; export OVS_SYSCONFDIR
33    trap 'kill `cat ovsdb-server.pid ovs-vswitchd.pid`' 0
34
35    dnl Create database.
36    mkdir openvswitch
37    touch openvswitch/.conf.db.~lock~
38    AT_CHECK([ovsdb-tool create openvswitch/conf.db $abs_top_srcdir/vswitchd/vswitch.ovsschema])
39
40    dnl Start ovsdb-server.
41    AT_CHECK([ovsdb-server --detach --pidfile --log-file --remote=punix:$OVS_RUNDIR/db.sock], [0], [], [stderr])
42    AT_CHECK([[sed < stderr '/vlog|INFO|opened log file/d']])
43    AT_CAPTURE_FILE([ovsdb-server.log])
44
45    dnl Initialize database.
46    AT_CHECK([ovs-vsctl --no-wait init])
47
48    dnl Start ovs-vswitchd.
49    AT_CHECK([ovs-vswitchd --detach --pidfile --enable-dummy --log-file], [0], [], [stderr])
50    AT_CAPTURE_FILE([ovs-vswitchd.log])
51    AT_CHECK([[sed < stderr '
52 /vlog|INFO|opened log file/d
53 /reconnect|INFO|/d
54 /dpif_linux|ERR|Generic Netlink family.*does not exist/d
55 /dpif|WARN|failed to enumerate system datapaths: No such file or directory/d
56 /ofproto|INFO|using datapath ID/d
57 /ofproto|INFO|datapath ID changed to fedcba9876543210/d']])
58
59    dnl Add bridges, ports, etc.
60    AT_CHECK([ovs-vsctl -- add-br br0 -- set bridge br0 datapath-type=dummy other-config:datapath-id=fedcba9876543210 -- $1])
61 ])
62
63 m4_define([OVS_VSWITCHD_STOP],
64   [AT_CHECK([ovs-appctl -t ovs-vswitchd exit])
65    AT_CHECK([ovs-appctl -t ovsdb-server exit])
66    trap '' 0])