Changed BACnetPropertyStates to support more enumerations. Added apdu size checking on decode. Removed BACnetPropertyStates local enumeration. Increased BACnetPropertyStates codec unit test coverage.

This commit is contained in:
Steve Karg
2024-01-05 16:00:42 -06:00
parent bb081d28da
commit ba4b0ca7c6
6 changed files with 980 additions and 286 deletions
+157 -86
View File
@@ -25,118 +25,189 @@ ZTEST(bacpropstates_tests, testPropStates)
void testPropStates(void)
#endif
{
BACNET_PROPERTY_STATE inData;
BACNET_PROPERTY_STATE outData;
uint8_t appMsg[MAX_APDU];
int inLen;
int outLen;
BACNET_PROPERTY_STATE data = { 0 };
BACNET_PROPERTY_STATE test_data = { 0 };
uint8_t apdu[MAX_APDU] = { 0 };
int apdu_len = 0;
int test_len = 0;
inData.tag = BOOLEAN_VALUE;
inData.state.booleanValue = true;
/*************************************************/
data.tag = PROP_STATE_BOOLEAN_VALUE;
data.state.booleanValue = true;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(
test_len, apdu_len, "apdu_len=%d test_len=%d", apdu_len, test_len);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(data.state.booleanValue, test_data.state.booleanValue, NULL);
inLen = bacapp_encode_property_state(appMsg, &inData);
/*************************************************/
data.tag = PROP_STATE_BINARY_VALUE;
data.state.binaryValue = BINARY_ACTIVE;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(data.state.binaryValue, test_data.state.binaryValue, NULL);
memset(&outData, 0, sizeof(outData));
/*************************************************/
data.tag = PROP_STATE_EVENT_TYPE;
data.state.eventType = EVENT_BUFFER_READY;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(data.state.eventType, test_data.state.eventType, NULL);
outLen = bacapp_decode_property_state(appMsg, &outData);
/*************************************************/
data.tag = PROP_STATE_POLARITY;
data.state.polarity = POLARITY_REVERSE;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(data.state.polarity, test_data.state.polarity, NULL);
zassert_equal(outLen, inLen, NULL);
zassert_equal(inData.tag, outData.tag, NULL);
zassert_equal(inData.state.booleanValue, outData.state.booleanValue, NULL);
/*************************************************/
data.tag = PROP_STATE_PROGRAM_CHANGE;
data.state.programChange = PROGRAM_REQUEST_RESTART;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(
data.state.programChange, test_data.state.programChange, NULL);
/****************
*****************
****************/
inData.tag = BINARY_VALUE;
inData.state.binaryValue = BINARY_ACTIVE;
/*************************************************/
data.tag = PROP_STATE_PROGRAM_STATE;
data.state.programState = PROGRAM_STATE_HALTED;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(data.state.programState, test_data.state.programState, NULL);
inLen = bacapp_encode_property_state(appMsg, &inData);
/*************************************************/
data.tag = PROP_STATE_REASON_FOR_HALT;
data.state.programError = PROGRAM_ERROR_LOAD_FAILED;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(data.state.programError, test_data.state.programError, NULL);
memset(&outData, 0, sizeof(outData));
/*************************************************/
data.tag = PROP_STATE_RELIABILITY;
data.state.reliability = RELIABILITY_COMMUNICATION_FAILURE;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(data.state.reliability, test_data.state.reliability, NULL);
outLen = bacapp_decode_property_state(appMsg, &outData);
/*************************************************/
data.tag = PROP_STATE_EVENT_STATE;
data.state.state = EVENT_STATE_FAULT;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(data.state.state, test_data.state.state, NULL);
zassert_equal(outLen, inLen, NULL);
zassert_equal(inData.tag, outData.tag, NULL);
zassert_equal(inData.state.binaryValue, outData.state.binaryValue, NULL);
/*************************************************/
data.tag = PROP_STATE_SYSTEM_STATUS;
data.state.systemStatus = STATUS_OPERATIONAL_READ_ONLY;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(data.state.systemStatus, test_data.state.systemStatus, NULL);
/****************
*****************
****************/
inData.tag = EVENT_TYPE;
inData.state.eventType = EVENT_BUFFER_READY;
/*************************************************/
data.tag = PROP_STATE_UNITS;
data.state.units = UNITS_BARS;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(data.state.units, test_data.state.units, NULL);
inLen = bacapp_encode_property_state(appMsg, &inData);
/*************************************************/
data.tag = PROP_STATE_UNSIGNED_VALUE;
data.state.unsignedValue = 0xdeadbeef;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(
data.state.unsignedValue, test_data.state.unsignedValue, NULL);
memset(&outData, 0, sizeof(outData));
/*************************************************/
data.tag = PROP_STATE_LIFE_SAFETY_MODE;
data.state.lifeSafetyMode = LIFE_SAFETY_MODE_ON;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(
data.state.lifeSafetyMode, test_data.state.lifeSafetyMode, NULL);
outLen = bacapp_decode_property_state(appMsg, &outData);
/*************************************************/
data.tag = PROP_STATE_LIFE_SAFETY_STATE;
data.state.lifeSafetyState = LIFE_SAFETY_STATE_ABNORMAL;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(
data.state.lifeSafetyState, test_data.state.lifeSafetyState, NULL);
zassert_equal(outLen, inLen, NULL);
zassert_equal(inData.tag, outData.tag, NULL);
zassert_equal(inData.state.eventType, outData.state.eventType, NULL);
/*************************************************/
data.tag = PROP_STATE_RESTART_REASON;
data.state.restartReason = RESTART_REASON_COLDSTART;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(
data.state.restartReason, test_data.state.restartReason, NULL);
/****************
*****************
****************/
inData.tag = POLARITY;
inData.state.polarity = POLARITY_REVERSE;
inLen = bacapp_encode_property_state(appMsg, &inData);
memset(&outData, 0, sizeof(outData));
outLen = bacapp_decode_property_state(appMsg, &outData);
zassert_equal(outLen, inLen, NULL);
zassert_equal(inData.tag, outData.tag, NULL);
zassert_equal(inData.state.polarity, outData.state.polarity, NULL);
/****************
*****************
****************/
inData.tag = PROGRAM_CHANGE;
inData.state.programChange = PROGRAM_REQUEST_RESTART;
inLen = bacapp_encode_property_state(appMsg, &inData);
memset(&outData, 0, sizeof(outData));
outLen = bacapp_decode_property_state(appMsg, &outData);
zassert_equal(outLen, inLen, NULL);
zassert_equal(inData.tag, outData.tag, NULL);
zassert_equal(inData.state.programChange, outData.state.programChange, NULL);
/****************
*****************
****************/
inData.tag = UNSIGNED_VALUE;
inData.state.unsignedValue = 0xdeadbeef;
inLen = bacapp_encode_property_state(appMsg, &inData);
memset(&outData, 0, sizeof(outData));
outLen = bacapp_decode_property_state(appMsg, &outData);
zassert_equal(outLen, inLen, NULL);
zassert_equal(inData.tag, outData.tag, NULL);
zassert_equal(inData.state.unsignedValue, outData.state.unsignedValue, NULL);
/*************************************************/
data.tag = PROP_STATE_DOOR_ALARM_STATE;
data.state.doorAlarmState = DOOR_ALARM_STATE_ALARM;
apdu_len = bacapp_encode_property_state(apdu, &data);
memset(&test_data, 0, sizeof(test_data));
test_len = bacapp_decode_property_state(apdu, &test_data);
zassert_equal(test_len, apdu_len, NULL);
zassert_equal(data.tag, test_data.tag, NULL);
zassert_equal(
data.state.doorAlarmState, test_data.state.doorAlarmState, NULL);
}
/**
* @}
*/
#if defined(CONFIG_ZTEST_NEW_API)
ZTEST_SUITE(bacpropstates_tests, NULL, NULL, NULL, NULL, NULL);
#else
void test_main(void)
{
ztest_test_suite(bacpropstates_tests,
ztest_unit_test(testPropStates)
);
ztest_test_suite(bacpropstates_tests, ztest_unit_test(testPropStates));
ztest_run_test_suite(bacpropstates_tests);
}
+1 -1
View File
@@ -127,7 +127,7 @@ static void testEventEventState(void)
data.toState = EVENT_STATE_OFFNORMAL;
data.eventType = EVENT_CHANGE_OF_STATE;
data.notificationParams.changeOfState.newState.tag = UNITS;
data.notificationParams.changeOfState.newState.tag = PROP_STATE_UNITS;
data.notificationParams.changeOfState.newState.state.units =
UNITS_SQUARE_METERS;