#!/bin/bash # This file is part of the rsyslog project, released under ASL 2.0 # Similar to the 'omprog-single-instance.sh' test, using the 'output' # parameter. Checks that the output of the program is correctly captured # when the 'forceSingleInstance' flag is enabled. NUMBER_OF_MESSAGES=10000 # number of logs to send . ${srcdir:=.}/diag.sh init uname if [ $(uname) = "SunOS" ] ; then # On Solaris, this test causes rsyslog to hang for unknown reasons echo "Solaris: FIX ME" exit 77 fi generate_conf add_conf ' module(load="../plugins/imtcp/.libs/imtcp") module(load="../plugins/omprog/.libs/omprog") input(type="imtcp" port="0" listenPortFileName="'$RSYSLOG_DYNNAME'.tcpflood_port") template(name="outfmt" type="string" string="%msg%\n") main_queue( queue.timeoutShutdown="30000" # long shutdown timeout for the main queue ) :msg, contains, "msgnum:" { action( type="omprog" binary=`echo $srcdir/testsuites/omprog-single-instance-bin.sh` template="outfmt" name="omprog_action" confirmMessages="on" forceSingleInstance="on" queue.type="LinkedList" # use a dedicated queue queue.workerThreads="10" # ...with multiple workers queue.size="10000" # ...high capacity (default is 1000) queue.timeoutShutdown="30000" # ...and a long shutdown timeout output=`echo $RSYSLOG2_OUT_LOG` ) } ' startup tcpflood -m$NUMBER_OF_MESSAGES shutdown_when_empty wait_shutdown EXPECTED_LINE_LENGTH=34 # example line: '[stderr] Received msgnum:00009880:' line_num=0 while IFS= read -r line; do ((line_num++)) if [[ $line_num == 1 ]]; then if [[ "$line" != "[stderr] Starting" ]]; then echo "unexpected first line in captured stderr: $line" error_exit 1 fi elif [[ $line_num == $(($NUMBER_OF_MESSAGES + 2)) ]]; then if [[ "$line" != "[stderr] Terminating" ]]; then echo "unexpected last line in captured stderr: $line" error_exit 1 fi elif [[ ${#line} != $EXPECTED_LINE_LENGTH ]]; then echo "unexpected line in captured stderr (line $line_num): $line" error_exit 1 fi done < $RSYSLOG2_OUT_LOG if (( $line_num != $(($NUMBER_OF_MESSAGES + 2)) )); then echo "unexpected line count in captured stderr: $line_num (expected: $(($NUMBER_OF_MESSAGES + 2)))" error_exit 1 fi # Note: we use awk here to remove leading spaces returned by wc on FreeBSD line_count=$(wc -l < ${RSYSLOG_OUT_LOG} | awk '{print $1}') if (( $line_count != $(($NUMBER_OF_MESSAGES + 2)) )); then echo "unexpected line count in output: $line_count (expected: $(($NUMBER_OF_MESSAGES + 2)))" error_exit 1 fi exit_test