rsyslog/tests/gzipwr_hup_multi_file.sh
2019-08-17 18:24:54 +02:00

47 lines
1.2 KiB
Bash
Executable File

#!/bin/bash
# This file is part of the rsyslog project, released under ASL 2.0
# Written 2019-06-12 by Rainer Gerhards
export TEST_MAX_RUNTIME=7200
. ${srcdir:=.}/diag.sh init
export NUMMESSAGES=100000
generate_conf
add_conf '
module(load="../plugins/imtcp/.libs/imtcp")
main_queue(queue.workerThreads="10" queue.workerThreadMinimumMessages="200")
input(type="imtcp" port="0" listenPortFileName="'$RSYSLOG_DYNNAME'.tcpflood_port")
template(name="outfmt" type="string"
string="%msg:F,58:2%,%msg:F,58:3%,%msg:F,58:4%\n")
template(name="dynfile" type="string" string="'$RSYSLOG_OUT_LOG'.%$/file%")
:msg, contains, "msgnum:" action(type="omfile" template="outfmt"
zipLevel="9" ioBufferSize="16" flushOnTXEnd="on"
dynafile="dynfile" dynaFileCacheSize="5"
asyncWriting="on")
if $msg contains "msgnum" then {
set $/file = cnum($/file) + 1;
if $/file >= 10 then {
set $/file = 0;
}
}
'
startup
./tcpflood -p$TCPFLOOD_PORT -m$NUMMESSAGES & # TCPFlood needs to run async!
for i in $(seq 0 20); do
printf '\nsending HUP %d\n' $i
issue_HUP
./msleep 10
done
shutdown_when_empty
wait_shutdown
ls -l ${RSYSLOG_OUT_LOG}.*
for f in "${RSYSLOG_OUT_LOG}".*; do
echo unzipping $f
gunzip < "$f" >> $RSYSLOG_OUT_LOG
done
seq_check
exit_test