summaryrefslogtreecommitdiffstats
path: root/tests/omprog-transactions.sh
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 16:28:20 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 16:28:20 +0000
commitdcc721a95bef6f0d8e6d8775b8efe33e5aecd562 (patch)
tree66a2774cd0ee294d019efd71d2544c70f42b2842 /tests/omprog-transactions.sh
parentInitial commit. (diff)
downloadrsyslog-dcc721a95bef6f0d8e6d8775b8efe33e5aecd562.tar.xz
rsyslog-dcc721a95bef6f0d8e6d8775b8efe33e5aecd562.zip
Adding upstream version 8.2402.0.upstream/8.2402.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/omprog-transactions.sh')
-rwxr-xr-xtests/omprog-transactions.sh140
1 files changed, 140 insertions, 0 deletions
diff --git a/tests/omprog-transactions.sh b/tests/omprog-transactions.sh
new file mode 100755
index 0000000..1937d0f
--- /dev/null
+++ b/tests/omprog-transactions.sh
@@ -0,0 +1,140 @@
+#!/bin/bash
+# This file is part of the rsyslog project, released under ASL 2.0
+
+# This test tests omprog with the confirmMessages=on and useTransactions=on
+# parameters, with the external program successfully confirming all messages
+# and transactions.
+
+. ${srcdir:=.}/diag.sh init
+generate_conf
+add_conf '
+module(load="../plugins/omprog/.libs/omprog")
+
+template(name="outfmt" type="string" string="%msg%\n")
+
+:msg, contains, "msgnum:" {
+ action(
+ type="omprog"
+ binary=`echo $srcdir/testsuites/omprog-transactions-bin.sh`
+ template="outfmt"
+ name="omprog_action"
+ queue.type="Direct" # the default; facilitates sync with the child process
+ queue.dequeueBatchSize="6"
+ confirmMessages="on"
+ useTransactions="on"
+ beginTransactionMark="BEGIN TRANSACTION"
+ commitTransactionMark="COMMIT TRANSACTION"
+ action.resumeRetryCount="10"
+ action.resumeInterval="1"
+ )
+}
+'
+startup
+injectmsg 0 10
+shutdown_when_empty
+wait_shutdown
+
+# Since the transaction boundaries are not deterministic, we cannot check for
+# an exact expected output. We must check the output programmatically.
+
+transaction_state="NONE"
+status_expected=true
+messages_to_commit=()
+messages_processed=()
+line_num=1
+error=
+
+while IFS= read -r line; do
+ if [[ $status_expected == true ]]; then
+ case "$transaction_state" in
+ "NONE")
+ if [[ "$line" != "<= OK" ]]; then
+ error="expecting an OK status from script"
+ break
+ fi
+ ;;
+ "STARTED")
+ if [[ "$line" != "<= OK" ]]; then
+ error="expecting an OK status from script"
+ break
+ fi
+ transaction_state="ACTIVE"
+ ;;
+ "ACTIVE")
+ if [[ "$line" != "<= DEFER_COMMIT" ]]; then
+ error="expecting a DEFER_COMMIT status from script"
+ break
+ fi
+ ;;
+ "COMMITTED")
+ if [[ "$line" != "<= OK" ]]; then
+ error="expecting an OK status from script"
+ break
+ fi
+ messages_processed+=("${messages_to_commit[@]}")
+ messages_to_commit=()
+ transaction_state="NONE"
+ ;;
+ esac
+ status_expected=false;
+ else
+ if [[ "$line" == "=> BEGIN TRANSACTION" ]]; then
+ if [[ "$transaction_state" != "NONE" ]]; then
+ error="unexpected transaction start"
+ break
+ fi
+ transaction_state="STARTED"
+ elif [[ "$line" == "=> COMMIT TRANSACTION" ]]; then
+ if [[ "$transaction_state" != "ACTIVE" ]]; then
+ error="unexpected transaction commit"
+ break
+ fi
+ transaction_state="COMMITTED"
+ else
+ if [[ "$transaction_state" != "ACTIVE" ]]; then
+ error="unexpected message outside a transaction"
+ break
+ fi
+ if [[ "$line" != "=> msgnum:"* ]]; then
+ error="unexpected message contents"
+ break
+ fi
+ prefix_to_remove="=> "
+ messages_to_commit+=("${line#$prefix_to_remove}")
+ fi
+ status_expected=true;
+ fi
+ ((line_num++))
+done < $RSYSLOG_OUT_LOG
+
+if [[ -z "$error" && "$transaction_state" != "NONE" ]]; then
+ error="unexpected end of file (transaction state: $transaction_state)"
+fi
+
+if [[ -n "$error" ]]; then
+ echo "$RSYSLOG_OUT_LOG: line $line_num: $error"
+ cat $RSYSLOG_OUT_LOG
+ error_exit 1
+fi
+
+expected_messages=(
+ "msgnum:00000000:"
+ "msgnum:00000001:"
+ "msgnum:00000002:"
+ "msgnum:00000003:"
+ "msgnum:00000004:"
+ "msgnum:00000005:"
+ "msgnum:00000006:"
+ "msgnum:00000007:"
+ "msgnum:00000008:"
+ "msgnum:00000009:"
+)
+if [[ "${messages_processed[*]}" != "${expected_messages[*]}" ]]; then
+ echo "unexpected set of processed messages:"
+ printf '%s\n' "${messages_processed[@]}"
+ echo "contents of $RSYSLOG_OUT_LOG:"
+ cat $RSYSLOG_OUT_LOG
+ error_exit 1
+fi
+
+exit_test