kopia lustrzana https://github.com/weetmuts/wmbusmeters
103 wiersze
3.9 KiB
Bash
Executable File
103 wiersze
3.9 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
PROG="$1"
|
|
|
|
mkdir -p testoutput
|
|
TEST=testoutput
|
|
|
|
TESTNAME="Test that normal meterfiles are written"
|
|
TESTRESULT="ERROR"
|
|
|
|
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
|
|
diff $TEST/test_expected.txt $TEST/test_response.txt
|
|
if [ "$?" = "0" ]
|
|
then
|
|
echo OK: $TESTNAME
|
|
TESTRESULT="OK"
|
|
rm /tmp/MyTapWater
|
|
fi
|
|
|
|
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi
|
|
|
|
TESTNAME="Test that meterfiles with name-id 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=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
|
|
diff $TEST/test_expected.txt $TEST/test_response.txt
|
|
if [ "$?" = "0" ]
|
|
then
|
|
echo OK: $TESTNAME
|
|
TESTRESULT="OK"
|
|
rm -rf /tmp/testmeters
|
|
fi
|
|
|
|
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi
|
|
|
|
TESTNAME="Test that meterfiles with id 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 --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
|
|
diff $TEST/test_expected.txt $TEST/test_response.txt
|
|
if [ "$?" = "0" ]
|
|
then
|
|
echo OK: $TESTNAME
|
|
TESTRESULT="OK"
|
|
rm -rf /tmp/testmeters
|
|
fi
|
|
|
|
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi
|
|
|
|
|
|
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
|
|
diff $TEST/test_expected.txt $TEST/test_response.txt
|
|
if [ "$?" = "0" ]
|
|
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
|
|
diff $TEST/test_expected.txt $TEST/test_response.txt
|
|
if [ "$?" = "0" ]
|
|
then
|
|
echo OK: $TESTNAME
|
|
TESTRESULT="OK"
|
|
rm -rf /tmp/testmeters
|
|
fi
|
|
|
|
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi
|