#!/bin/sh
# $Id: t-ssrestart-0.sh,v 1.1 2007/05/05 14:45:09 ca Exp $
#
# ----------------------------------------
# test killing and restarting smtps; check whether id is reused
# ----------------------------------------
#
test -s stop && exit 1
#
if test X"${MTA_NO_SLOW_TEST}" != "X"
then
echo "SKIPPED: $0: MTA_NO_SLOW_TEST is set"
exit 0
fi
if test X"`uname`" = "XLinux"
then
echo "SKIPPED: $0: on Linux, needs POSIX conformant pthread implementation"
exit 0
fi
SD=`dirname $0`
if test "${SD}" = "."
then
SD=../chkmts
fi
ERRS=0
OUT="t-ssrestart-0.out"
OUT1="t-ssrestart-0-1.out"
# debug flags
D="-d 7"
if test X"`uname`" != "XOSF1"
then
while getopts s:V FLAG
do
case "${FLAG}" in
s) SKIP="${SKIP} ${OPTARG}";;
V) VERBOSE=true;;
esac
done
shift `expr ${OPTIND} - 1`
fi
# cd to working directory
cd ../qmgr || exit 1
rm -f ${MTMAP}
# setup/initialize system
. ${SD}/mta-setup.sh
SRCPRG=${STE}/smtpc
rm -f ${QMGRCONFMAP} ${ALIMAP} ${ACCMAP} ${OUT} ${OUT1}
killit()
{
if test -s ${PIDS}
then
# stop MTA components
for i in `${CAT} ${PIDS}`
do
kill ${i}
done
fi
# ----------------
# thanks kids for not following the POSIX standard...
if test X"`uname`" = "XLinux"
then
killall qmgr smar
fi
if test X"${SRVPID}" != "X"
then
kill -TERM ${SRVPID}
fi
exit 1
}
# version of output files
V=0
# path to programs
P=..
export P
rm -f ${PIDS}
trap killit 2 15
${P}/smar/smar ${D} > a${V}.log 2>&1 &
echo $! >> ${PIDS}
${P}/qmgr/qmgr -D 20 -w ${W4S} -W ${W4C} ${D} > q${V}.log 2>&1 &
QMGRPID=$!
echo $! >> ${PIDS}
${P}/smtpc/smtpc -v 12 -w ${W4S} -P ${SNKPORT} > c${V}.log 2>&1 &
echo $! >> ${PIDS}
${P}/smtps/smtps -w ${W4S} ${D} -b localhost:${SRVPORT} > s${V}.log 2>&1 &
SMTPSPID=$!
echo $! >> ${PIDS}
# check that the MTA is running
${CHKD}/mta-running.sh ${SRVPORT} || killit
# ----------------------------------------
# test: send a message, kill SMTPS, start SMTPS, send another message
# don't run a sink, so messages are "stuck" in queue
TEST=1
if echo " ${SKIP} X" | ${GREP} -v " ${TEST} " > /dev/null
then
ERR=false
if ${SRCPRG} -r ${H}:${SRVPORT} -f"s1@b.c" -R"r1@y.z" > ${CLTL} 2>&1
then
sleep 4
kill ${SMTPSPID}
sleep 3
${P}/smtps/smtps -w ${W4S} ${D} -b localhost:${SRVPORT} >> s${V}.log 2>&1 &
SMTPSPID=$!
echo $! >> ${PIDS}
sleep 6
if ${SRCPRG} -r ${H}:${SRVPORT} -f"s2@b.c" -R"r2@y.z" >> ${CLTL} 2>&1
then
C=`grep -c 'func=sm_q_nseid, ss_sess=S000000000000000100' q${V}.log`
if test $C -ge 2
then
echo "$0: ERROR: found same session id twice"
ERR=true
fi
else
${CAT} ${CLTL}
ERR=true
fi
else
${CAT} ${CLTL}
ERR=true
fi
if ${ERR}
then
echo "$0: test ${TEST} failed"
ERRS=`expr ${ERRS} + 1 `
fi
fi
# ----------------------------------------
# stop system
if test -s ${PIDS}
then
# stop MTA components
for i in `${CAT} ${PIDS}`
do
kill ${i}
done
fi
# ----------------
# thanks kids for not following the POSIX standard...
if test X"`uname`" = "XLinux"
then
killall qmgr smar
fi
rm -f ${PIDS}
# ----------------------------------------
# end
if test "${ERRS}" = "0"
then
exit 0
else
echo "${ERRS} error(s)"
exit 1
fi
syntax highlighted by Code2HTML, v. 0.9.1