2018-02-14 14:42:14 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
2019-03-14 17:15:27 +00:00
|
|
|
PIDFILE=/tmp/dumper.pid
|
2018-02-15 15:07:23 +00:00
|
|
|
TESTCASE=$1
|
2018-06-18 04:18:34 +00:00
|
|
|
VERDICT="$2"
|
|
|
|
|
2019-02-26 04:03:22 +00:00
|
|
|
date
|
|
|
|
|
2018-06-18 04:18:34 +00:00
|
|
|
if [ x"$VERDICT" = x"pass" ]; then
|
|
|
|
echo "\033[1;32m====== $TESTCASE $VERDICT ======\033[0m"
|
|
|
|
else
|
|
|
|
echo "\033[1;31m------ $TESTCASE $VERDICT ------\033[0m"
|
|
|
|
fi
|
|
|
|
echo
|
2018-02-15 15:07:23 +00:00
|
|
|
|
|
|
|
if [ "z$TTCN3_PCAP_PATH" = "z" ]; then
|
|
|
|
TTCN3_PCAP_PATH=/tmp
|
|
|
|
fi
|
|
|
|
|
2019-03-14 17:15:27 +00:00
|
|
|
# Wait for up to 2 seconds if we keep receiving traffinc from packet dumper,
|
2018-02-15 15:07:23 +00:00
|
|
|
# otherwise we might lose last packets from test.
|
|
|
|
i=0
|
|
|
|
prev_count=-1
|
|
|
|
count=$(stat --format="%s" "$TTCN3_PCAP_PATH/$TESTCASE.pcap")
|
|
|
|
while [ $count -gt $prev_count ] && [ $i -lt 2 ]
|
|
|
|
do
|
2019-03-14 17:15:27 +00:00
|
|
|
echo "Waiting for packet dumper to finish... $i (prev_count=$prev_count, count=$count)"
|
2018-02-15 15:07:23 +00:00
|
|
|
sleep 1
|
|
|
|
prev_count=$count
|
|
|
|
count=$(stat --format="%s" "$TTCN3_PCAP_PATH/$TESTCASE.pcap")
|
|
|
|
i=$((i+1))
|
|
|
|
done
|
2018-02-14 14:42:14 +00:00
|
|
|
|
|
|
|
if [ -e $PIDFILE ]; then
|
2019-03-18 13:18:31 +00:00
|
|
|
DUMPER="$(ps -q "$(cat "$PIDFILE")" -o comm=)"
|
|
|
|
if [ "$DUMPER" != "sudo" ]; then
|
2018-02-14 14:42:14 +00:00
|
|
|
kill "$(cat "$PIDFILE")"
|
|
|
|
else
|
2019-03-14 17:15:27 +00:00
|
|
|
# NOTE: This requires you to be root or something like
|
|
|
|
# "laforge ALL=NOPASSWD: /usr/sbin/tcpdump, /bin/kill" in your sudoers file
|
2018-02-14 14:42:14 +00:00
|
|
|
sudo kill "$(cat "$PIDFILE")"
|
|
|
|
fi
|
|
|
|
rm $PIDFILE
|
|
|
|
fi
|