testbench: check MsgDup() properly duplicates all properties

see also https://github.com/rsyslog/rsyslog/issues/3716
This commit is contained in:
Rainer Gerhards 2019-06-26 12:53:52 +02:00
parent 9545a26796
commit 7a0fe5ac4f
No known key found for this signature in database
GPG Key ID: 0CB6B2A8BE80B499
2 changed files with 66 additions and 0 deletions

View File

@ -225,6 +225,7 @@ TESTS += \
da-mainmsg-q.sh \
validation-run.sh \
msgdup.sh \
msgdup_props.sh \
empty-ruleset.sh \
imtcp-discard-truncated-msg.sh \
imtcp-basic.sh \
@ -1824,6 +1825,7 @@ EXTRA_DIST= \
da-mainmsg-q.sh \
diskqueue-fsync.sh \
msgdup.sh \
msgdup_props.sh \
empty-ruleset.sh \
imtcp-discard-truncated-msg.sh \
imtcp-basic.sh \

64
tests/msgdup_props.sh Executable file
View File

@ -0,0 +1,64 @@
#!/bin/bash
# This test checks the MsgDup() properly copies all properties.
# added 2019-06-26 by Rgerhards. Released under ASL 2.0
# create the pipe and start a background process that copies data from
# it to the "regular" work file
. ${srcdir:=.}/diag.sh init
generate_conf
add_conf '
$MainMsgQueueTimeoutShutdown 10000
template(name="all_properties" type="list") {
property(format="jsonf" name="fromhost") constant(value="\n")
property(format="jsonf" name="fromhost-ip") constant(value="\n")
property(format="jsonf" name="hostname") constant(value="\n")
property(format="jsonf" name="inputname") constant(value="\n")
property(format="jsonf" name="msg") constant(value="\n")
property(format="jsonf" name="msgid") constant(value="\n")
property(format="jsonf" name="$!" outname="globalvar") constant(value="\n")
property(format="jsonf" name="$." outname="localvar") constant(value="\n")
property(format="jsonf" name="pri") constant(value="\n")
property(format="jsonf" name="pri-text") constant(value="\n")
property(format="jsonf" name="procid") constant(value="\n")
property(format="jsonf" name="protocol-version") constant(value="\n")
property(format="jsonf" name="rawmsg-after-pri") constant(value="\n")
property(format="jsonf" name="rawmsg") constant(value="\n")
property(format="jsonf" name="structured-data") constant(value="\n")
property(format="jsonf" name="syslogtag") constant(value="\n")
property(format="jsonf" name="timegenerated") constant(value="\n")
property(format="jsonf" name="timegenerated" dateformat="rfc3339") constant(value="\n")
property(format="jsonf" name="timereported") constant(value="\n")
property(format="jsonf" name="timereported" dateformat="rfc3339") constant(value="\n")
}
ruleset(name="rs_with_queue" queue.type="LinkedList" queue.size="10000") {
action(type="omfile" file="'$RSYSLOG_OUT_LOG'" template="all_properties")
# works on a duplicated message thanks to the queue
}
set $!var="msg var";
set $.var="local var";
if $msg contains "msgnum:" then {
call rs_with_queue
action(type="omfile" file="'$RSYSLOG2_OUT_LOG'" template="all_properties")
# works on original, non-duplicated, message
}
'
startup
injectmsg 0 1 # we need only one message to check the properties
shutdown_when_empty
wait_shutdown
cmp "$RSYSLOG_OUT_LOG" "$RSYSLOG2_OUT_LOG"
if [ $? -ne 0 ]; then
printf 'ERROR: output files do not match!\n'
printf '################# %s is:\n' "$RSYSLOG_OUT_LOG"
cat -n "$RSYSLOG_OUT_LOG"
printf '################# %s is:\n' "$RSYSLOG2_OUT_LOG"
cat -n "$RSYSLOG2_OUT_LOG"
printf '\n#################### diff is:\n'
diff "$RSYSLOG_OUT_LOG" "$RSYSLOG2_OUT_LOG"
error_exit 1
fi;
exit_test