rsyslog/tests/timegenerated-uxtimestamp.sh
Rainer Gerhards 58dfe006a8
testbench: improve tests
modernize them, reduce robustness against slow machines, provide some
test framework functional enhancements and optimizie some tests
2020-01-19 16:09:44 +01:00

208 lines
5.2 KiB
Bash
Executable File

#!/bin/bash
# test many concurrent tcp connections
# addd 2016-03-02 by RGerhards, released under ASL 2.0
# Note: we run several subtests here in order to save us
# from creating additional tests
# requires faketime
echo \[timegenerated-uxtimestamp\]: check valid dates with uxtimestamp format
. ${srcdir:=.}/diag.sh init
. $srcdir/faketime_common.sh
export TZ=UTC+00:00
generate_conf
add_conf '
module(load="../plugins/imtcp/.libs/imtcp")
input(type="imtcp" port="0" listenPortFileName="'$RSYSLOG_DYNNAME'.tcpflood_port")
template(name="outfmt" type="string"
string="%timegenerated:::date-unixtimestamp%\n")
:msg, contains, "msgnum:" action(type="omfile" template="outfmt"
file="'$RSYSLOG_OUT_LOG'")
'
echo "***SUBTEST: check 1970-01-01"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='1970-01-01 00:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "0" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
echo "***SUBTEST: check 2000-03-01"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2000-03-01 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "951912000" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
echo "***SUBTEST: check 2016-01-01"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2016-01-01 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "1451649600" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
echo "***SUBTEST: check 2016-02-29"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2016-02-29 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "1456747200" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
echo "***SUBTEST: check 2016-03-01"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2016-03-01 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "1456833600" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
echo "***SUBTEST: check 2016-03-03"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2016-03-03 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "1457006400" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
echo "***SUBTEST: check 2016-12-31"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2016-12-31 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "1483185600" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
echo "***SUBTEST: check 2017-01-01"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2017-01-01 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "1483272000" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
echo "***SUBTEST: check 2020-03-01"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2020-03-01 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "1583064000" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
echo "***SUBTEST: check 2038-01-01"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2038-01-01 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "2145960000" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
rsyslog_testbench_require_y2k38_support
echo "***SUBTEST: check 2040-01-01"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2040-01-01 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "2209032000" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
cat $RSYSLOG_OUT_LOG
date -d @$(pwd $RSYSLOG_OUT_LOG)
exit 1
fi;
echo "***SUBTEST: check 2100-01-01"
rm -f $RSYSLOG_OUT_LOG # do cleanup of previous subtest
FAKETIME='2100-01-01 12:00:00' startup
tcpflood -m1
shutdown_when_empty
wait_shutdown
echo "4102488000" | cmp - $RSYSLOG_OUT_LOG
if [ ! $? -eq 0 ]; then
echo "invalid timestamps generated, $RSYSLOG_OUT_LOG is:"
date -d @$(pwd $RSYSLOG_OUT_LOG)
cat $RSYSLOG_OUT_LOG
exit 1
fi;
exit_test