wmbusmeters/tests/test_config_oneshot_exitaft...

64 wiersze
1.5 KiB
Bash
Executable File

#!/bin/sh
PROG="$1"
if [ "$PROG" = "" ]
then
echo Please supply the binary to be tested as the first argument.
exit 1
fi
TEST=testoutput
rm -rf $TEST
mkdir -p $TEST
TESTNAME="Test config with oneshot"
TESTRESULT="ERROR"
cat simulations/serial_aes.msg | grep '^{' | jq --sort-keys . | tr -d '#' > $TEST/test_expected.txt
cat simulations/serial_aes.msg | grep '^[CT]' | tr -d '#' > $TEST/test_input.txt
cat $TEST/test_input.txt | $PROG --useconfig=tests/config10 2> $TEST/test_stderr.txt | jq --sort-keys . > $TEST/test_output.txt
if ! grep -q "(main) all meters have received at least one update, stopping." $TEST/test_stderr.txt
then
echo "ERROR: $TESTNAME ($0)"
echo "Expected stderr to print \"all meters have received at least one update\""
exit 1
fi
cat $TEST/test_output.txt | sed 's/"timestamp": "....-..-..T..:..:..Z"/"timestamp": "1111-11-11T11:11:11Z"/' > $TEST/test_response.txt
diff $TEST/test_expected.txt $TEST/test_response.txt
if [ "$?" = "0" ]
then
echo "OK: $TESTNAME"
TESTRESULT="OK"
else
echo "ERROR: $TESTNAME"
exit 1
fi
TESTNAME="Test config with exitafter"
TESTRESULT="ERROR"
# Read from stdin
{ echo "Nada" ; sleep 4; } | $PROG --useconfig=tests/config10 > $TEST/test_output.txt 2> $TEST/test_stderr.txt
if ! grep -q "(serial) exit after " $TEST/test_stderr.txt
then
echo "ERROR: $TESTNAME ($0)"
echo "Expected stderr to print \"(serial) exit after\""
exit 1
else
echo "OK: $TESTNAME"
TESTRESULT=OK
fi
if [ "$TESTRESULT" = "ERROR" ]
then
echo "ERROR: $TESTNAME ($0)"
exit 1
fi