rsyslog/tests/pmlastmsg.sh
Rainer Gerhards 42a8051ad9
testbench: make most tests use a port file and assign listen port 0
This makes the test much more robust against heavily loaded test
systems.
2019-08-16 17:31:52 +02:00

45 lines
1.7 KiB
Bash
Executable File

#!/bin/bash
# add 2018-06-29 by Pascal Withopf, released under ASL 2.0
. ${srcdir:=.}/diag.sh init
generate_conf
add_conf '
module(load="../plugins/pmlastmsg/.libs/pmlastmsg")
module(load="../plugins/imtcp/.libs/imtcp")
input(type="imtcp" port="0" listenPortFileName="'$RSYSLOG_DYNNAME'.tcpflood_port" ruleset="ruleset1")
template(name="outfmt" type="string" string="%msg%\n")
ruleset(name="ruleset1" parser=["rsyslog.lastline","rsyslog.rfc5424","rsyslog.rfc3164"]) {
action(type="omfile" file=`echo $RSYSLOG_OUT_LOG`
template="outfmt")
}
'
startup
tcpflood -m1 -M "\"<13>last message repeated 5 times\""
tcpflood -m1 -M "\"<13>last message repeated 0090909787348927349875 times\""
tcpflood -m1 -M "\"<13>last message repeated 5 times\""
tcpflood -m1 -M "\"<13>last message repeated 5 times -- more data\""
tcpflood -m1 -M "\"<13>last message repeated 5.2 times\""
tcpflood -m1 -M "\"<167>Mar 6 16:57:54 172.20.245.8 TAG: Rest of message...\""
tcpflood -m1 -M "\"<167>Mar 6 16:57:54 172.20.245.8 TAG long message ================================================================================\""
tcpflood -m1 -M "\"<34>1 2003-11-11T22:14:15.003Z mymachine.example.com su - ID47 last message repeated 5 times\""
shutdown_when_empty
wait_shutdown
echo 'last message repeated 5 times
last message repeated 0090909787348927349875 times
repeated 5 times
repeated 5 times -- more data
repeated 5.2 times
Rest of message...
long message ================================================================================
last message repeated 5 times' | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid response generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
error_exit 1
fi;
exit_test