X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=tests%2Fofproto-macros.at;h=229e014b3d9a8acafd7d1031464035b2a946f4a2;hb=5dab8eced8eeb7faf193e2a96d75b9ee30b4c3eb;hp=d5ff2ad6a0f89a3b32f6b4b11a3dab8da393b6e8;hpb=007948177581f3b3dad188221593d0e4bdca6ba0;p=openvswitch diff --git a/tests/ofproto-macros.at b/tests/ofproto-macros.at index d5ff2ad6..229e014b 100644 --- a/tests/ofproto-macros.at +++ b/tests/ofproto-macros.at @@ -1,16 +1,66 @@ m4_define([STRIP_XIDS], [[sed 's/ (xid=0x[0-9a-fA-F]*)//']]) m4_define([STRIP_DURATION], [[sed 's/\bduration=[0-9.]*s/duration=?s/']]) +m4_define([TESTABLE_LOG], [-vPATTERN:ANY:'%c|%p|%m']) m4_define([OFPROTO_START], [OVS_RUNDIR=$PWD; export OVS_RUNDIR OVS_LOGDIR=$PWD; export OVS_LOGDIR - trap 'kill `cat ovs-openflowd.pid`' 0 - AT_CAPTURE_FILE([ovs-openflowd.log]) + trap 'kill `cat test-openflowd.pid`' 0 + AT_CAPTURE_FILE([test-openflowd.log]) AT_CHECK( - [ovs-openflowd --detach --pidfile --enable-dummy --log-file --fail=closed dummy@br0 none --datapath-id=fedcba9876543210 $1], - [0], [ignore], [ignore]) + [test-openflowd --detach --pidfile --enable-dummy --log-file --fail=closed dummy@br0 none --datapath-id=fedcba9876543210 $1], + [0], [], [stderr]) + AT_CHECK([[sed < stderr ' +/vlog|INFO|opened log file/d +/openflowd|INFO|Open vSwitch version/d +/openflowd|INFO|OpenFlow protocol version/d +/ofproto|INFO|using datapath ID/d +/ofproto|INFO|datapath ID changed to fedcba9876543210/d']]) ]) m4_define([OFPROTO_STOP], - [AT_CHECK([ovs-appctl -t ovs-openflowd exit]) + [AT_CHECK([ovs-appctl -t test-openflowd exit]) + trap '' 0]) + +m4_define([OVS_VSWITCHD_START], + [dnl Skip this test if running as root. Otherwise ovs-vswitchd will tear + dnl down any existing datapaths if the kernel module is loaded. + AT_SKIP_IF([test "`id -u`" = 0]) + + OVS_RUNDIR=$PWD; export OVS_RUNDIR + OVS_LOGDIR=$PWD; export OVS_LOGDIR + OVS_SYSCONFDIR=$PWD; export OVS_SYSCONFDIR + trap 'kill `cat ovsdb-server.pid ovs-vswitchd.pid`' 0 + + dnl Create database. + mkdir openvswitch + touch openvswitch/.conf.db.~lock~ + AT_CHECK([ovsdb-tool create openvswitch/conf.db $abs_top_srcdir/vswitchd/vswitch.ovsschema]) + + dnl Start ovsdb-server. + AT_CHECK([ovsdb-server --detach --pidfile --log-file --remote=punix:$OVS_RUNDIR/db.sock], [0], [], [stderr]) + AT_CHECK([[sed < stderr '/vlog|INFO|opened log file/d']]) + AT_CAPTURE_FILE([ovsdb-server.log]) + + dnl Initialize database. + AT_CHECK([ovs-vsctl --no-wait init]) + + dnl Start ovs-vswitchd. + AT_CHECK([ovs-vswitchd --detach --pidfile --enable-dummy --log-file], [0], [], [stderr]) + AT_CAPTURE_FILE([ovs-vswitchd.log]) + AT_CHECK([[sed < stderr ' +/vlog|INFO|opened log file/d +/reconnect|INFO|/d +/dpif_linux|ERR|Generic Netlink family.*does not exist/d +/dpif|WARN|failed to enumerate system datapaths: No such file or directory/d +/ofproto|INFO|using datapath ID/d +/ofproto|INFO|datapath ID changed to fedcba9876543210/d']]) + + dnl Add bridges, ports, etc. + AT_CHECK([ovs-vsctl -- add-br br0 -- set bridge br0 datapath-type=dummy other-config:datapath-id=fedcba9876543210 -- $1]) +]) + +m4_define([OVS_VSWITCHD_STOP], + [AT_CHECK([ovs-appctl -t ovs-vswitchd exit]) + AT_CHECK([ovs-appctl -t ovsdb-server exit]) trap '' 0])