No functional change. Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
205 lines
4.1 KiB
Bash
205 lines
4.1 KiB
Bash
export EMPIREHOST=127.0.0.1 LOGNAME=tester
|
|
|
|
if [ -x ./config.status ] && ./config.status --version | grep -q '^Wolfpack Empire'
|
|
then :
|
|
else echo "$0: Must be run in root of build tree" >&2; exit 1
|
|
fi
|
|
|
|
test=${0##*/}
|
|
test=${test%-test}
|
|
|
|
# Abbreviations
|
|
testdir="$srcdir/tests/$test"
|
|
econfig=sandbox/etc/empire/econfig
|
|
schedule=sandbox/etc/empire/schedule
|
|
data=sandbox/var/empire
|
|
empdump="src/util/empdump -e $econfig"
|
|
files="src/util/files -e $econfig"
|
|
fairland="src/util/fairland -e $econfig"
|
|
|
|
empthread=`sed -n 's/empthread *:= *\(.*\)/\1/p' <GNUmakefile`
|
|
warn_empthread=y
|
|
|
|
check_empthread()
|
|
{
|
|
if [ "$warn_empthread" ] && [ "$empthread" != "LWP" ]
|
|
then
|
|
echo "Warning: test not expected to work with thread package $empthread!" >&2
|
|
warn_empthread=
|
|
fi
|
|
}
|
|
|
|
create_sandbox()
|
|
{
|
|
rm -rf sandbox
|
|
mkdir -p sandbox/etc/empire sandbox/share/empire/builtin $data
|
|
touch $schedule
|
|
cat >$econfig <<EOF
|
|
data "../../var/empire"
|
|
info "../../../../info.nr"
|
|
builtin "../../share/empire/builtin"
|
|
listen_addr "$EMPIREHOST"
|
|
keep_journal 2
|
|
GODNEWS 0
|
|
running_test_suite 1
|
|
EOF
|
|
cp `git ls-files "$srcdir"/src/lib/global | uniq | grep '\.config$'` sandbox/share/empire/builtin
|
|
}
|
|
|
|
now()
|
|
{
|
|
# date +%s isn't portable...
|
|
perl -e 'printf "%s\n", time'
|
|
}
|
|
|
|
start_server()
|
|
{
|
|
local pidfile=$data/server.pid
|
|
local timeout
|
|
|
|
#
|
|
# Currently expected to work only with thread package LWP,
|
|
# because:
|
|
#
|
|
# - Thread scheduling is reliably deterministic only with LWP
|
|
# - Shell builtin kill appears not to do the job in MinGW
|
|
# - The Windows server tries to run as service when -d isn't
|
|
# specified
|
|
# - The Windows server does not implement -E crash-dump
|
|
#
|
|
# TODO address these shortcomings.
|
|
#
|
|
check_empthread
|
|
|
|
pid=
|
|
trap 'if [ "$pid" ]; then kill -9 "$pid" 2>/dev/null || true; fi' EXIT
|
|
src/server/emp_server -e $econfig -R 1 -s -E crash-dump
|
|
timeout=$((`now`+5))
|
|
until pid=`cat $pidfile 2>/dev/null` && [ -n "$pid" ]
|
|
do
|
|
if [ `now` -gt $timeout ]
|
|
then
|
|
echo "Timed out waiting for server to create $pidfile" >&2
|
|
exit 1
|
|
fi
|
|
done
|
|
while src/client/empire red herring 2>&1 | grep -q "Connection refused"
|
|
do
|
|
if [ `now` -gt $timeout ]
|
|
then
|
|
echo "Timed out waiting for server to accept connections" >&2
|
|
exit 1
|
|
fi
|
|
done
|
|
}
|
|
|
|
stop_server()
|
|
{
|
|
local timeout
|
|
kill "$pid"
|
|
timeout=$((`now`+5))
|
|
while kill -0 "$pid" 2>/dev/null
|
|
do
|
|
if [ `now` -gt $timeout ]
|
|
then
|
|
echo "Timed out waiting for server to terminate" >&2
|
|
exit 1
|
|
fi
|
|
done
|
|
}
|
|
|
|
feed_input()
|
|
{
|
|
c=$1
|
|
r=$2
|
|
shift 2
|
|
sed '/^|/d' "$@" | src/client/empire "$c" "$r" >/dev/null
|
|
}
|
|
|
|
feed_files()
|
|
{
|
|
for i
|
|
do
|
|
c="${i##*/*-}"
|
|
r=`echo $c | sed 's/^POGO$/peter/'`
|
|
feed_input "$c" "$r" "$i"
|
|
done
|
|
}
|
|
|
|
feed_dir()
|
|
{
|
|
feed_files `git ls-files "$@" | uniq | grep '/[0-9][0-9]-[^/]*$'`
|
|
}
|
|
|
|
begin_test()
|
|
{
|
|
$files -f >/dev/null
|
|
local xd=
|
|
case "$1" in
|
|
*.xdump)
|
|
xd="$1"
|
|
$empdump -i "$xd"
|
|
shift
|
|
;;
|
|
esac
|
|
if [ -z "$xd" ] || [ "$#" -ne 0 ]
|
|
then
|
|
cp -r $data/tel $data/empty.tel
|
|
start_server
|
|
if [ "$#" -eq 0 ]
|
|
then feed_input POGO peter
|
|
else feed_files "$@"
|
|
fi
|
|
echo 'edit c * ?tgms>0 t 0' | feed_input POGO peter
|
|
stop_server
|
|
mv $data/tel $data/setup.tel
|
|
mv $data/empty.tel $data/tel
|
|
mv $data/news $data/setup.news
|
|
>$data/news
|
|
mv $data/lostitems $data/setup.lostitems
|
|
>$data/lostitems
|
|
mv $data/journal.log $data/setup.journal.log
|
|
mv $data/server.log $data/setup.server.log
|
|
fi
|
|
start_server
|
|
}
|
|
|
|
end_test ()
|
|
{
|
|
stop_server
|
|
$empdump -x >sandbox/final.xdump
|
|
}
|
|
|
|
cmp_logs_xdump()
|
|
{
|
|
cmp_out var/empire/server.log var/empire/journal.log final.xdump
|
|
}
|
|
|
|
cmp_out()
|
|
{
|
|
local opt exp act nrm ret=0
|
|
for i
|
|
do
|
|
case "$i" in
|
|
*/journal.log) opt=-j ;;
|
|
*/server.log) opt=-s ;;
|
|
*) opt= ;;
|
|
esac
|
|
exp="$testdir/${i##*/}"
|
|
act="sandbox/$i"
|
|
nrm="sandbox/normalized-${i##*/}"
|
|
perl "$srcdir"/tests/normalize.pl $opt "$act" >"$nrm"
|
|
if diff -u "$exp" "$nrm" >"$nrm.diff"
|
|
then
|
|
echo "$i OK"
|
|
elif [ "$EMPIRE_CHECK_ACCEPT" ]
|
|
then
|
|
echo "$i CHANGED"
|
|
cp "$nrm" "$exp"
|
|
else
|
|
ret=$?
|
|
echo "$i FAIL"
|
|
fi
|
|
done
|
|
return $ret
|
|
}
|