summaryrefslogtreecommitdiffstats
path: root/tests/gzipwr_hup_multi_file.sh
blob: 3083820752c1e885b43f40150099d7319719ae51 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#!/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