2022-02-05 15:01:07 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
PROG="$1"
|
|
|
|
|
|
|
|
TEST=testaes
|
|
|
|
|
|
|
|
rm -rf $TEST
|
|
|
|
mkdir -p $TEST
|
|
|
|
|
|
|
|
TESTNAME="Test config override with oneshot"
|
|
|
|
TESTRESULT="ERROR"
|
|
|
|
|
2022-02-05 15:09:39 +00:00
|
|
|
BROKEN="T1;1;1;2019-04-03 19:00:42.000;97;148;18888888;0x6e4401068888881805077a85006085bc2630713819512eb4cd87fba554fb43f67cf9654a68ee8e194088160df752e716238292e8af1ac20986202ee561d743602466915e42f1105d9c6782"
|
|
|
|
|
2022-02-05 15:01:07 +00:00
|
|
|
cat simulations/serial_aes.msg | grep '^{' | tr -d '#' > $TEST/test_expected.txt
|
|
|
|
cat simulations/serial_aes.msg | grep '^[CT]' | tr -d '#' > $TEST/test_input.txt
|
2022-02-05 15:09:39 +00:00
|
|
|
echo "$BROKEN" >> $TEST/input.txt
|
|
|
|
|
2022-02-05 15:01:07 +00:00
|
|
|
cat $TEST/test_input.txt | $PROG --useconfig=tests/config9 --device=stdin:rtlwmbus --oneshot > $TEST/test_output.txt 2> $TEST/test_stderr.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"
|
|
|
|
fi
|
|
|
|
|
|
|
|
TESTNAME="Test config override with exitafter"
|
|
|
|
TESTRESULT="ERROR"
|
|
|
|
|
|
|
|
cat simulations/serial_aes.msg | grep '^{' | tr -d '#' > $TEST/test_expected.txt
|
|
|
|
cat simulations/serial_aes.msg | grep '^[CT]' | tr -d '#' > $TEST/test_input.txt
|
|
|
|
# Read from stdin
|
|
|
|
$PROG --useconfig=tests/config9 --device=stdin:rtlwmbus --oneshot --exitafter=1s > $TEST/test_output.txt 2> $TEST/test_stderr.txt
|
|
|
|
|
|
|
|
if ! grep -q "(serial) exit after 2 seconds" $TEST/test_stderr.txt
|
|
|
|
then
|
|
|
|
echo "ERROR: $TESTNAME ($0)"
|
|
|
|
echo "Expected stderr to print \"exit after 2 seconds\""
|
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
echo "OK: $TESTNAME"
|
|
|
|
TESTRESULT=OK
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$TESTRESULT" = "ERROR" ]
|
|
|
|
then
|
|
|
|
echo "ERROR: $TESTNAME ($0)"
|
|
|
|
exit 1
|
|
|
|
fi
|