rsyslog/tests/sndrcv_relp_tls_chainedcert.sh
Rainer Gerhards 2ed8a931eb
testbench bugfix: some tests did not work in make distcheck
- certificate file missing in dist tarball
- some test cases did not properly specify path to cert file
- also bumping some zookeeper component versions

Thanks to Michael Biebl for alerting us and providing part of
the fix.

closes https://github.com/rsyslog/rsyslog/issues/4446
2020-12-07 12:34:59 +01:00

71 lines
1.9 KiB
Bash
Executable File

#!/bin/bash
# addd 2020-08-25 by alorbach, released under ASL 2.0
. ${srcdir:=.}/diag.sh init
require_relpEngineVersion "1.7.0"
export NUMMESSAGES=1000
export TB_TEST_MAX_RUNTIME=30
# uncomment for debugging support:
# export RSYSLOG_DEBUG="debug nostdout noprintmutexaction"
# export RSYSLOG_DEBUGLOG="log"
generate_conf
export PORT_RCVR="$(get_free_port)"
add_conf '
module( load="../plugins/imrelp/.libs/imrelp"
tls.tlslib="openssl")
# then SENDER sends to this port (not tcpflood!)
input(type="imrelp" port="'$PORT_RCVR'"
tls="on"
tls.mycert="'$srcdir'/tls-certs/certchained.pem"
tls.myprivkey="'$srcdir'/tls-certs/key.pem"
tls.authmode="certvalid"
tls.permittedpeer="rsyslog")
$template outfmt,"%msg:F,58:2%\n"
:msg, contains, "msgnum:" action(type="omfile" file="'$RSYSLOG_OUT_LOG'" template="outfmt")
'
startup
export RSYSLOG_DEBUGLOG="log2"
#valgrind="valgrind"
generate_conf 2
add_conf '
module( load="../plugins/omrelp/.libs/omrelp"
tls.tlslib="openssl")
:msg, contains, "msgnum:" action(type="omrelp"
target="127.0.0.1" port="'$PORT_RCVR'"
tls="on"
tls.mycert="'$srcdir'/tls-certs/certchained.pem"
tls.myprivkey="'$srcdir'/tls-certs/key.pem"
tls.authmode="certvalid"
tls.permittedpeer="rsyslog")
action(type="omfile" file="'$RSYSLOG_DYNNAME.errmsgs'")
' 2
startup 2
if grep "omrelp error: invalid authmode" < "$RSYSLOG_DYNNAME.errmsgs" ; then
echo "SKIP: librelp does not support "certvalid" auth mode"
# mini-cleanup to not leave dangling processes
shutdown_immediate 2
shutdown_immediate
rm $RSYSLOG_DYNNAME* &> /dev/null
exit 77
fi
# now inject the messages into instance 2. It will connect to instance 1,
# and that instance will record the data.
injectmsg2 1 $NUMMESSAGES
# shut down sender
shutdown_when_empty 2
wait_shutdown 2
# now it is time to stop the receiver as well
shutdown_when_empty
wait_shutdown
seq_check 1 $NUMMESSAGES
exit_test