rsyslog/tests/da-mainmsg-q.sh
Rainer Gerhards fc3e56941c fixing an issue during DA mode queue shutdown
also changed DA queue mode in that the regular workers now run
concurrently.
2009-05-28 11:57:30 +02:00

35 lines
1.6 KiB
Bash
Executable File

# Test for DA mode on the main message queue
# This test checks if DA mode operates correctly. To do so,
# it uses a small in-memory queue size, so that DA mode is initiated
# rather soon, and disk spooling used. There is some uncertainty (based
# on machine speeds), but in general the test should work rather well.
# We add a few messages after the initial run, just so that we can
# check everything recovers from DA mode correctly.
# added 2009-04-22 by Rgerhards
# This file is part of the rsyslog project, released under GPLv3
echo "testing main message queue in DA mode (going to disk)"
source $srcdir/diag.sh init
source $srcdir/diag.sh startup da-mainmsg-q.conf
# part1: send first 50 messages (in memory, only)
#source $srcdir/diag.sh tcpflood 127.0.0.1 13514 1 50
source $srcdir/diag.sh injectmsg 0 50
source $srcdir/diag.sh wait-queueempty # let queue drain for this test case
# part 2: send bunch of messages. This should trigger DA mode
#source $srcdir/diag.sh injectmsg 50 20000
source $srcdir/diag.sh injectmsg 50 2000
ls -l test-spool # for manual review
# send another handful
source $srcdir/diag.sh injectmsg 2050 50
#sleep 1 # we need this so that rsyslogd can receive all outstanding messages
# clean up and check test result
source $srcdir/diag.sh shutdown-when-empty # shut down rsyslogd when done processing messages
### currently, we get a stable abort if we use the former kill logic. With shutdown-when-empty, it hangs (but that still tells us there is a bug ;)) ###
#kill `cat rsyslog.pid`
echo seqchk?
source $srcdir/diag.sh seq-check 2099
source $srcdir/diag.sh exit