wmbusmeters/tests/test_meterfiles.sh

103 wiersze
3.9 KiB
Bash
Czysty Zwykły widok Historia

#!/bin/sh
2019-02-23 17:30:16 +00:00
PROG="$1"
mkdir -p testoutput
TEST=testoutput
2019-11-03 21:00:18 +00:00
TESTNAME="Test that normal meterfiles are written"
TESTRESULT="ERROR"
2019-02-23 17:30:16 +00:00
rm -f /tmp/MyTapWater
cat simulations/simulation_c1.txt | grep '^{' | grep 76348799 | tail -n 1 | jq --sort-keys . > $TEST/test_expected.txt
$PROG --meterfiles --format=json simulations/simulation_c1.txt MyTapWater multical21 76348799 "" \
2> $TEST/test_stderr.txt
cat /tmp/MyTapWater | jq --sort-keys . | sed 's/"timestamp": "....-..-..T..:..:..Z"/"timestamp": "1111-11-11T11:11:11Z"/' > $TEST/test_response.txt
2019-02-23 17:30:16 +00:00
diff $TEST/test_expected.txt $TEST/test_response.txt
2020-04-22 06:07:19 +00:00
if [ "$?" = "0" ]
2019-02-23 17:30:16 +00:00
then
2019-11-03 21:00:18 +00:00
echo OK: $TESTNAME
TESTRESULT="OK"
2019-02-23 17:30:16 +00:00
rm /tmp/MyTapWater
fi
2019-11-03 21:00:18 +00:00
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi
TESTNAME="Test that meterfiles with name-id are written"
TESTRESULT="ERROR"
2019-02-23 17:30:16 +00:00
rm -rf /tmp/testmeters
mkdir /tmp/testmeters
cat simulations/simulation_c1.txt | grep '^{' | grep 76348799 | tail -n 1 | jq --sort-keys . > $TEST/test_expected.txt
$PROG --meterfiles=/tmp/testmeters --meterfilesnaming=name-id --format=json \
simulations/simulation_c1.txt MyTapWater multical21 76348799 "" \
> /dev/null 2> $TEST/test_stderr.txt
cat /tmp/testmeters/MyTapWater-76348799 | jq --sort-keys . | sed 's/"timestamp": "....-..-..T..:..:..Z"/"timestamp": "1111-11-11T11:11:11Z"/' > $TEST/test_response.txt
2019-02-23 17:30:16 +00:00
diff $TEST/test_expected.txt $TEST/test_response.txt
2020-04-22 06:07:19 +00:00
if [ "$?" = "0" ]
2019-02-23 17:30:16 +00:00
then
2019-11-03 21:00:18 +00:00
echo OK: $TESTNAME
TESTRESULT="OK"
2019-02-23 17:30:16 +00:00
rm -rf /tmp/testmeters
fi
2019-06-20 12:28:52 +00:00
2019-11-03 21:00:18 +00:00
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi
TESTNAME="Test that meterfiles with id are written"
TESTRESULT="ERROR"
2019-06-20 12:28:52 +00:00
rm -rf /tmp/testmeters
mkdir /tmp/testmeters
cat simulations/simulation_c1.txt | grep '^{' | grep 76348799 | tail -n 1 | jq --sort-keys . > $TEST/test_expected.txt
$PROG --meterfiles=/tmp/testmeters --meterfilesnaming=id --format=json \
simulations/simulation_c1.txt MyTapWater multical21 76348799 "" \
2> $TEST/test_stderr.txt
cat /tmp/testmeters/76348799 | jq --sort-keys . | sed 's/"timestamp": "....-..-..T..:..:..Z"/"timestamp": "1111-11-11T11:11:11Z"/' > $TEST/test_response.txt
2019-06-20 12:28:52 +00:00
diff $TEST/test_expected.txt $TEST/test_response.txt
2020-04-22 06:07:19 +00:00
if [ "$?" = "0" ]
2019-06-20 12:28:52 +00:00
then
2019-11-03 21:00:18 +00:00
echo OK: $TESTNAME
TESTRESULT="OK"
2019-06-20 12:28:52 +00:00
rm -rf /tmp/testmeters
fi
2019-11-03 21:00:18 +00:00
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi
2019-12-11 17:56:34 +00:00
TESTNAME="Test that meterfiles with timestamps are written"
TESTRESULT="ERROR"
rm -rf /tmp/testmeters
mkdir /tmp/testmeters
cat simulations/simulation_c1.txt | grep '^{' | grep 76348799 | tail -n 1 | jq --sort-keys . > $TEST/test_expected.txt
$PROG --meterfiles=/tmp/testmeters --meterfilesnaming=id --meterfilestimestamp=day --format=json \
simulations/simulation_c1.txt MyTapWater multical21 76348799 "" \
2> $TEST/test_stderr.txt
cat /tmp/testmeters/76348799_$(date +%Y-%m-%d) | jq --sort-keys . | sed 's/"timestamp": "....-..-..T..:..:..Z"/"timestamp": "1111-11-11T11:11:11Z"/' > $TEST/test_response.txt
2019-12-11 17:56:34 +00:00
diff $TEST/test_expected.txt $TEST/test_response.txt
2020-04-22 06:07:19 +00:00
if [ "$?" = "0" ]
2019-12-11 17:56:34 +00:00
then
echo OK: $TESTNAME
TESTRESULT="OK"
rm -rf /tmp/testmeters
fi
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi
rm -rf /tmp/testmeters
mkdir /tmp/testmeters
cat simulations/simulation_c1.txt | grep '^{' | grep 76348799 | tail -n 1 | jq --sort-keys . > $TEST/test_expected.txt
$PROG --meterfiles=/tmp/testmeters --meterfilesnaming=id --meterfilestimestamp=minute --format=json \
simulations/simulation_c1.txt MyTapWater multical21 76348799 "" \
2> $TEST/test_stderr.txt
cat /tmp/testmeters/76348799_$(date +%Y-%m-%d_%H:%M) | jq --sort-keys . | sed 's/"timestamp": "....-..-..T..:..:..Z"/"timestamp": "1111-11-11T11:11:11Z"/' > $TEST/test_response.txt
2019-12-11 17:56:34 +00:00
diff $TEST/test_expected.txt $TEST/test_response.txt
2020-04-22 06:07:19 +00:00
if [ "$?" = "0" ]
2019-12-11 17:56:34 +00:00
then
echo OK: $TESTNAME
TESTRESULT="OK"
rm -rf /tmp/testmeters
fi
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi