1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150
|
#! /bin/sh
run () {
echo "$@"
"$@" || exit 1
}
# Put built tools early in $PATH.
builddir=`pwd`
if test ! -e vswitchd/ovs-vswitchd; then
echo >&2 'not in build directory, please change directory or run via \"make check-ryu'
exit 1
fi
PATH=$builddir/ovsdb:$builddir/vswitchd:$builddir/utilities:$PATH; export PATH
# Find srcdir.
case $srcdir in
'') srcdir=$builddir ;;
/*) ;;
*) srcdir=`pwd`/$srcdir ;;
esac
if test ! -e "$srcdir"/WHY-OVS; then
echo >&2 'source directory not found, please set $srcdir or run via \"make check-ryu'
exit 1
fi
# Make sure ryu is available.
if test X"$RYUDIR" = X; then
RYUDIR=$srcdir/../ryu
fi
PYTHONPATH=$RYUDIR:$PYTHONPATH; export PYTHONPATH
PATH=$RYUDIR/bin:$PATH; export PATH
if (ryu-manager --version) >/dev/null 2>&1; then
:
else
echo >&2 '"ryu-manager" binary not found or cannot be run, please set $RYUDIR'
exit 1
fi
# Create sandbox.
rm -rf sandbox
mkdir sandbox
cd sandbox
sandbox=`pwd`
# Set up environment for OVS programs to sandbox themselves.
OVS_RUNDIR=$sandbox; export OVS_RUNDIR
OVS_LOGDIR=$sandbox; export OVS_LOGDIR
OVS_DBDIR=$sandbox; export OVS_DBDIR
OVS_SYSCONFDIR=$sandbox; export OVS_SYSCONFDIR
for signal in 0 1 2 3 13 14 15; do
trap 'kill `cat $sandbox/*.pid`; trap - $signal; kill -$signal $$' $signal
done
# Create database and start ovsdb-server.
touch .conf.db.~lock~
rm -f conf.db
run ovsdb-tool create conf.db "$srcdir"/vswitchd/vswitch.ovsschema
run ovsdb-server --detach --no-chdir --pidfile -vconsole:off --log-file \
--remote=punix:"$sandbox"/db.sock
# Start ovs-vswitchd.
run ovs-vswitchd --detach --no-chdir --pidfile -vconsole:off --log-file \
--enable-dummy --disable-system -vvconn -vnetdev_dummy
# Add bridges for Ryu to use, and configure them to connect to Ryu.
for config in \
'br0 0000000000000001 a b pstream=punix' \
'br1 0000000000000002 c d stream=unix'
do
set $config
bridge=$1 dpid=$2 port1=$3 port2=$4 stream_mode=$5
run ovs-vsctl --no-wait \
-- add-br $bridge \
-- set bridge $bridge \
datapath-type=dummy fail-mode=secure \
protocols='[OpenFlow10,OpenFlow11,OpenFlow12,OpenFlow13]' \
other-config:datapath-id=$dpid \
-- set-controller $bridge tcp:127.0.0.1:6633 \
-- set controller $bridge connection-mode=out-of-band \
max-backoff=1000 \
-- add-port $bridge $port1 \
-- set interface $port1 ofport_request=1 type=dummy \
options:${stream_mode}:"$sandbox"/p1.sock \
-- add-port $bridge $port2 \
-- set interface $port2 ofport_request=2 type=dummy \
options:${stream_mode}:"$sandbox"/p2.sock
done
logs=
run_app() {
app=$1
cat <<EOF
--- Running $app...
EOF
logfile=$sandbox/`echo $app | sed 's,/,.,g'`.log
logs="$logs
$logfile"
ryu-manager "$app" --log-file="$logfile" & pid=$!
echo $pid > "$sandbox/ryu.pid"
i=0
while sleep 1; do
if grep -q -E 'TEST_FINISHED|Test end|uncaught exception' "$logfile" \
>/dev/null
then
break
fi
i=`expr $i + 1`
if test $i -ge 600; then
echo "--- TIMEOUT after $i seconds"
break
fi
done
kill $pid
wait
}
# Run Ryu.
cd $RYUDIR
for app in \
ryu/tests/switch/tester.py
do
run_app $app
done
# tweak OVS setup because the following tests assume single bridge.
run ovs-vsctl -- del-br br1
for app in \
ryu/tests/integrated/test_add_flow_v10.py \
ryu/tests/integrated/test_request_reply_v12.py \
ryu/tests/integrated/test_add_flow_v12_actions.py \
ryu/tests/integrated/test_add_flow_v12_matches.py
do
run_app $app
done
cat <<EOF
----------------------------------------------------------------------
Logs may be found under $sandbox, e.g.:$logs
$sandbox/ovs-vswitchd.log
$sandbox/ovsdb-server.log
----------------------------------------------------------------------
EOF
|