libdb/test/xa/src3/run.sh

122 lines
2.3 KiB
Bash
Raw Normal View History

2011-09-13 17:44:24 +00:00
#! /bin/sh
#
# Run test 3.
msg()
{
test "$DVERBOSE" == 1 && {
echo "========"
echo "======== $1"
echo "========"
}
}
init_tmadmin()
{
tmadmin << END_OF_TMADMIN
crdl -z $TLOGDEVICE -b 500
crlog -m cluster3
END_OF_TMADMIN
}
# Everything else is done in run/bin.
cd $RUN/bin
# The CFLAGS variable defines the pre-processor defines -- start with
# whatever the user set, and add our own stuff.
#
# For debugging output, add -DDVERBOSE
test "$DVERBOSE" == 1 && {
COMPILE_FLAGS="-DDVERBOSE"
DVERBOSE_FLAG="-v"
}
COMPILE_FLAGS="$CFLAGS $COMPILE_FLAGS -g -I../../.."
msg "BUILDING CLIENT"
CFLAGS="$COMPILE_FLAGS"; export CFLAGS
buildclient -r BERKELEY-DB $DVERBOSE_FLAG -o client \
-f ../../src3/client.c
test "$?" -eq 0 || {
echo "FAIL: buildclient failed."
exit 1
}
msg "BUILDING SERVER #1"
CFLAGS="$COMPILE_FLAGS -DSERVER1"; export CFLAGS
buildserver -r BERKELEY-DB $DVERBOSE_FLAG -t -o server1 \
-s TestThread1:TestThread1 -f ../../src3/server.c
test "$?" -eq 0 || {
echo "FAIL: buildserver failed."
exit 1
}
msg "BUILDING SERVER #2"
CFLAGS="$COMPILE_FLAGS -DSERVER2"; export CFLAGS
buildserver -r BERKELEY-DB $DVERBOSE_FLAG -t -o server2 \
-s TestThread2:TestThread2 -f ../../src3/server.c
test "$?" -eq 0 || {
echo "FAIL: buildserver failed."
exit 1
}
msg "BUILDING THE RESOURCE MANAGER."
buildtms -o DBRM -r BERKELEY-DB
init_tmadmin
# Boot Tuxedo.
# You should see something like:
#
# Booting admin processes ...
#
# exec BBL -A :
# process id=13845 ... Started.
#
# Booting server processes ...
#
# exec DBRM -A :
# process id=13846 ... Started.
# exec DBRM -A :
# process id=13847 ... Started.
# exec server1 -A :
# process id=13848 ... Started.
# exec server2 -A :
# process id=13849 ... Started.
# 5 processes started.
msg "BOOTING TUXEDO."
tmboot -y
exitval=0
if [ $1 == 1 ]; then
kill_thread=-k
fi
./client $kill_thread $DVERBOSE_FLAG
test "$?" -ne 0 && {
echo "FAIL: client failed"
exitval=1
break;
}
msg "SHUTTING DOWN THE TRANSACTION MANAGER."
echo 'y' | tmshutdown
# Copy out any server output.
echo "STDOUT:"
cat stdout
# Killing a thread can result in expected database "run recovery" errors
if [ $1 == 1 ]; then
exit $exitval
fi
# Copy out any server errors.
test -s stderr && {
echo "STDERR:"
cat stderr
echo "FAIL: stderr file not empty"
exitval=1
}
exit $exitval