2010-09-16 14:39:50 +02:00
|
|
|
#!/bin/bash
|
|
|
|
|
2010-09-17 03:56:34 +02:00
|
|
|
NGAMES=${NGAMES:-1}
|
2010-09-17 07:20:43 +02:00
|
|
|
NROOMS=${NROOMS:-1}
|
2010-09-17 03:56:34 +02:00
|
|
|
|
2010-09-18 16:35:02 +02:00
|
|
|
LOGDIR=$(basename $0)_logs
|
|
|
|
mkdir -p $LOGDIR
|
|
|
|
|
2010-09-17 03:56:34 +02:00
|
|
|
USE_GTK=${USE_GTK:-FALSE}
|
|
|
|
|
|
|
|
if [ $USE_GTK = FALSE ]; then
|
|
|
|
PLAT_PARMS="-u -0"
|
|
|
|
else
|
|
|
|
PLAT_PARMS="-z 1:10"
|
|
|
|
fi
|
|
|
|
|
|
|
|
usage() {
|
|
|
|
echo "usage: [env=val *] $0" 1>&2
|
|
|
|
echo " current env variables and their values: " 1>&2
|
2010-09-17 07:20:43 +02:00
|
|
|
for VAR in NGAMES NROOMS USE_GTK; do
|
2010-09-17 03:56:34 +02:00
|
|
|
echo "$VAR:" $(eval "echo \$${VAR}") 1>&2
|
|
|
|
done
|
|
|
|
exit 0
|
|
|
|
}
|
|
|
|
|
2010-09-16 14:39:50 +02:00
|
|
|
do_device() {
|
|
|
|
GAME=$1
|
|
|
|
DEV=$2
|
|
|
|
NDEVS=$3
|
|
|
|
LOG=$4
|
2010-09-17 07:20:43 +02:00
|
|
|
ROOM=ROOM_$((GAME%NROOMS))
|
2010-09-16 14:39:50 +02:00
|
|
|
|
|
|
|
FILE="GAME_${GAME}_${DEV}.xwg"
|
|
|
|
rm -f $FILE
|
|
|
|
for II in $(seq 2 $NDEVS); do
|
|
|
|
OTHERS="-N $OTHERS"
|
|
|
|
done
|
|
|
|
|
|
|
|
while :; do
|
2010-09-17 03:56:34 +02:00
|
|
|
sleep $((RANDOM%5))
|
2010-09-17 07:20:43 +02:00
|
|
|
./obj_linux_memdbg/xwords -C $ROOM -r edd $OTHERS \
|
2010-09-17 03:56:34 +02:00
|
|
|
-d dict.xwd -f $FILE $PLAT_PARMS >/dev/null 2>>$LOG &
|
2010-09-16 14:39:50 +02:00
|
|
|
PID=$!
|
2010-09-17 03:56:34 +02:00
|
|
|
sleep $((RANDOM%10+10))
|
|
|
|
kill $PID 2>/dev/null
|
2010-09-16 14:39:50 +02:00
|
|
|
|
2010-09-18 16:35:02 +02:00
|
|
|
if [ $(grep -c 'all remaining tiles' $LOG) -eq $NDEVS ]; then
|
|
|
|
echo "game for $LOG succeeded"
|
|
|
|
break
|
|
|
|
fi
|
2010-09-17 03:56:34 +02:00
|
|
|
pidof xwrelay > /dev/null || break
|
2010-09-16 14:39:50 +02:00
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
do_game() {
|
|
|
|
INDEX=$1
|
|
|
|
NDEVS=$(($RANDOM%3+2))
|
|
|
|
|
2010-09-18 16:35:02 +02:00
|
|
|
LOG="${LOGDIR}/LOG_${INDEX}.txt"
|
2010-09-16 14:39:50 +02:00
|
|
|
rm -f $LOG
|
|
|
|
|
|
|
|
for DEV in $(seq $NDEVS); do
|
|
|
|
do_device $INDEX $DEV $NDEVS $LOG &
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2010-09-17 03:56:34 +02:00
|
|
|
while [ -n "$1" ]; do
|
|
|
|
case $1 in
|
|
|
|
*) usage
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
for GAME in $(seq 1 $NGAMES); do
|
2010-09-16 14:39:50 +02:00
|
|
|
do_game $GAME
|
|
|
|
done
|
2010-09-17 03:56:34 +02:00
|
|
|
|
|
|
|
wait
|