2020-10-25 19:57:25 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
PROG="$1"
|
|
|
|
|
|
|
|
mkdir -p testoutput
|
|
|
|
|
|
|
|
TEST=testoutput
|
|
|
|
|
|
|
|
####################################################
|
|
|
|
TESTNAME="Test duplicates are ignored"
|
|
|
|
TESTRESULT="ERROR"
|
|
|
|
|
2023-08-27 15:33:32 +00:00
|
|
|
cat > $TEST/test_expected_unsorted.txt <<EOF
|
2022-12-05 19:43:57 +00:00
|
|
|
{"media":"smoke detector","meter":"lansensm","name":"Rummet","id":"01000273","status":"OK","async_msg_id_counter":588,"minutes_since_last_manual_test_counter":30022,"timestamp":"1111-11-11T11:11:11Z"}
|
2020-10-25 19:57:25 +00:00
|
|
|
EOF
|
|
|
|
|
2023-08-27 15:33:32 +00:00
|
|
|
jq --sort-keys . $TEST/test_expected_unsorted.txt > $TEST/test_expected.txt
|
|
|
|
|
2020-10-25 19:57:25 +00:00
|
|
|
$PROG --format=json --ignoreduplicates simulations/simulation_duplicates.txt \
|
|
|
|
Rummet lansensm 01000273 "" \
|
2023-08-27 15:33:32 +00:00
|
|
|
| grep Rummet | jq --sort-keys . > $TEST/test_output.txt
|
2020-10-25 19:57:25 +00:00
|
|
|
|
|
|
|
if [ "$?" = "0" ]
|
|
|
|
then
|
2023-08-27 15:33:32 +00:00
|
|
|
cat $TEST/test_output.txt | sed 's/"timestamp": "....-..-..T..:..:..Z"/"timestamp": "1111-11-11T11:11:11Z"/' > $TEST/test_responses.txt
|
2020-10-25 19:57:25 +00:00
|
|
|
diff $TEST/test_expected.txt $TEST/test_responses.txt
|
|
|
|
if [ "$?" = "0" ]
|
|
|
|
then
|
|
|
|
echo "OK: $TESTNAME"
|
|
|
|
TESTRESULT="OK"
|
2023-08-27 15:33:32 +00:00
|
|
|
else
|
|
|
|
if [ "$USE_MELD" = "true" ]
|
|
|
|
then
|
|
|
|
meld $TEST/test_expected.txt $TEST/test_responses.txt
|
|
|
|
fi
|
2020-10-25 19:57:25 +00:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi
|
|
|
|
|
|
|
|
####################################################
|
|
|
|
TESTNAME="Test duplicates are left alone"
|
|
|
|
TESTRESULT="ERROR"
|
|
|
|
|
2023-08-27 15:33:32 +00:00
|
|
|
cat > $TEST/test_expected_unsorted.txt <<EOF
|
2022-12-05 19:43:57 +00:00
|
|
|
{"media":"smoke detector","meter":"lansensm","name":"Rummet","id":"01000273","status":"OK","async_msg_id_counter":588,"minutes_since_last_manual_test_counter":30022,"timestamp":"1111-11-11T11:11:11Z"}
|
|
|
|
{"media":"smoke detector","meter":"lansensm","name":"Rummet","id":"01000273","status":"OK","async_msg_id_counter":588,"minutes_since_last_manual_test_counter":30022,"timestamp":"1111-11-11T11:11:11Z"}
|
|
|
|
{"media":"smoke detector","meter":"lansensm","name":"Rummet","id":"01000273","status":"OK","async_msg_id_counter":588,"minutes_since_last_manual_test_counter":30022,"timestamp":"1111-11-11T11:11:11Z"}
|
|
|
|
{"media":"smoke detector","meter":"lansensm","name":"Rummet","id":"01000273","status":"OK","async_msg_id_counter":588,"minutes_since_last_manual_test_counter":30022,"timestamp":"1111-11-11T11:11:11Z"}
|
|
|
|
{"media":"smoke detector","meter":"lansensm","name":"Rummet","id":"01000273","status":"OK","async_msg_id_counter":588,"minutes_since_last_manual_test_counter":30022,"timestamp":"1111-11-11T11:11:11Z"}
|
2020-10-25 19:57:25 +00:00
|
|
|
EOF
|
|
|
|
|
2023-08-27 15:33:32 +00:00
|
|
|
jq --sort-keys . $TEST/test_expected_unsorted.txt > $TEST/test_expected.txt
|
|
|
|
|
2021-02-20 21:21:01 +00:00
|
|
|
$PROG --format=json --ignoreduplicates=false simulations/simulation_duplicates.txt \
|
2020-10-25 19:57:25 +00:00
|
|
|
Rummet lansensm 01000273 "" \
|
2023-08-27 15:33:32 +00:00
|
|
|
| grep Rummet | jq --sort-keys . > $TEST/test_output.txt
|
2020-10-25 19:57:25 +00:00
|
|
|
|
|
|
|
if [ "$?" = "0" ]
|
|
|
|
then
|
2023-08-27 15:33:32 +00:00
|
|
|
cat $TEST/test_output.txt | sed 's/"timestamp": "....-..-..T..:..:..Z"/"timestamp": "1111-11-11T11:11:11Z"/' > $TEST/test_responses.txt
|
2020-10-25 19:57:25 +00:00
|
|
|
diff $TEST/test_expected.txt $TEST/test_responses.txt
|
|
|
|
if [ "$?" = "0" ]
|
|
|
|
then
|
|
|
|
echo "OK: $TESTNAME"
|
|
|
|
TESTRESULT="OK"
|
2023-08-27 15:33:32 +00:00
|
|
|
else
|
|
|
|
if [ "$USE_MELD" = "true" ]
|
|
|
|
then
|
|
|
|
meld $TEST/test_expected.txt $TEST/test_responses.txt
|
|
|
|
fi
|
2020-10-25 19:57:25 +00:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$TESTRESULT" = "ERROR" ]; then echo ERROR: $TESTNAME; exit 1; fi
|