rsyslog/tests/pmrfc3164-json.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

33 lines
923 B
Bash
Executable File

#!/bin/bash
# add 2017-12-12 by Rainer Gerhards, released under ASL 2.0
. ${srcdir:=.}/diag.sh init
generate_conf
add_conf '
module(load="../plugins/imtcp/.libs/imtcp")
input(type="imtcp" port="0" listenPortFileName="'$RSYSLOG_DYNNAME'.tcpflood_port" ruleset="rs")
template(name="outfmt" type="string" string="%msg%---%rawmsg%\n")
ruleset(name="rs") {
action(type="omfile" template="outfmt" file=`echo $RSYSLOG_OUT_LOG`)
}
'
startup
tcpflood -m1 -M "\"{ \\\"c1\\\":1 }\""
tcpflood -m1 -M "\" { \\\"c2\\\":2 }\""
tcpflood -m1 -M "\" [{ \\\"c3\\\":3 }]\""
shutdown_when_empty
wait_shutdown
export EXPECTED='{ "c1":1 }---{ "c1":1 }
{ "c2":2 }--- { "c2":2 }
[{ "c3":3 }]--- [{ "c3":3 }]'
echo "$EXPECTED" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid response generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
printf 'expected was\n'
echo "$EXPECTED"
error_exit 1
fi;
exit_test