Feature/zephyr ztest (#118)
* Leverage (older) embedded unit tests into external unit tests build upon copy of Zephyr's ztest library and CMake. * Expand top-level CMake build to run external unit tests. * Expand Zephyr module extension to run external unit tests via west or sanitycheck. Co-authored-by: Gregory Shue <gregory.shue@legrand.us>
This commit is contained in:
@@ -0,0 +1,103 @@
|
||||
/*
|
||||
* Copyright (c) 2020 Legrand North America, LLC.
|
||||
*
|
||||
* SPDX-License-Identifier: MIT
|
||||
*/
|
||||
|
||||
/* @file
|
||||
* @brief test BACnet integer encode/decode APIs
|
||||
*/
|
||||
|
||||
#include <ztest.h>
|
||||
#include <bacnet/alarm_ack.h>
|
||||
|
||||
/**
|
||||
* @addtogroup bacnet_tests
|
||||
* @{
|
||||
*/
|
||||
|
||||
/**
|
||||
* @brief Test
|
||||
*/
|
||||
static void testAlarmAck(void)
|
||||
{
|
||||
BACNET_ALARM_ACK_DATA testAlarmAckIn;
|
||||
BACNET_ALARM_ACK_DATA testAlarmAckOut;
|
||||
|
||||
uint8_t buffer[MAX_APDU];
|
||||
int inLen;
|
||||
int outLen;
|
||||
|
||||
testAlarmAckIn.ackProcessIdentifier = 0x1234;
|
||||
characterstring_init_ansi(&testAlarmAckIn.ackSource, "This is a test");
|
||||
testAlarmAckIn.ackTimeStamp.tag = TIME_STAMP_SEQUENCE;
|
||||
testAlarmAckIn.ackTimeStamp.value.sequenceNum = 0x4331;
|
||||
testAlarmAckIn.eventObjectIdentifier.instance = 567;
|
||||
testAlarmAckIn.eventObjectIdentifier.type = OBJECT_DEVICE;
|
||||
testAlarmAckIn.eventTimeStamp.tag = TIME_STAMP_TIME;
|
||||
testAlarmAckIn.eventTimeStamp.value.time.hour = 10;
|
||||
testAlarmAckIn.eventTimeStamp.value.time.min = 11;
|
||||
testAlarmAckIn.eventTimeStamp.value.time.sec = 12;
|
||||
testAlarmAckIn.eventTimeStamp.value.time.hundredths = 14;
|
||||
testAlarmAckIn.eventStateAcked = EVENT_STATE_OFFNORMAL;
|
||||
|
||||
memset(&testAlarmAckOut, 0, sizeof(testAlarmAckOut));
|
||||
|
||||
inLen = alarm_ack_encode_service_request(buffer, &testAlarmAckIn);
|
||||
outLen = alarm_ack_decode_service_request(buffer, inLen, &testAlarmAckOut);
|
||||
|
||||
zassert_equal(inLen, outLen, NULL);
|
||||
|
||||
zassert_equal(
|
||||
testAlarmAckIn.ackProcessIdentifier,
|
||||
testAlarmAckOut.ackProcessIdentifier, NULL);
|
||||
|
||||
zassert_equal(
|
||||
testAlarmAckIn.ackTimeStamp.tag, testAlarmAckOut.ackTimeStamp.tag, NULL);
|
||||
zassert_equal(
|
||||
testAlarmAckIn.ackTimeStamp.value.sequenceNum,
|
||||
testAlarmAckOut.ackTimeStamp.value.sequenceNum, NULL);
|
||||
|
||||
zassert_equal(
|
||||
testAlarmAckIn.ackProcessIdentifier,
|
||||
testAlarmAckOut.ackProcessIdentifier, NULL);
|
||||
|
||||
zassert_equal(
|
||||
testAlarmAckIn.eventObjectIdentifier.instance,
|
||||
testAlarmAckOut.eventObjectIdentifier.instance, NULL);
|
||||
zassert_equal(
|
||||
testAlarmAckIn.eventObjectIdentifier.type,
|
||||
testAlarmAckOut.eventObjectIdentifier.type, NULL);
|
||||
|
||||
zassert_equal(
|
||||
testAlarmAckIn.eventTimeStamp.tag,
|
||||
testAlarmAckOut.eventTimeStamp.tag, NULL);
|
||||
zassert_equal(
|
||||
testAlarmAckIn.eventTimeStamp.value.time.hour,
|
||||
testAlarmAckOut.eventTimeStamp.value.time.hour, NULL);
|
||||
zassert_equal(
|
||||
testAlarmAckIn.eventTimeStamp.value.time.min,
|
||||
testAlarmAckOut.eventTimeStamp.value.time.min, NULL);
|
||||
zassert_equal(
|
||||
testAlarmAckIn.eventTimeStamp.value.time.sec,
|
||||
testAlarmAckOut.eventTimeStamp.value.time.sec, NULL);
|
||||
zassert_equal(
|
||||
testAlarmAckIn.eventTimeStamp.value.time.hundredths,
|
||||
testAlarmAckOut.eventTimeStamp.value.time.hundredths, NULL);
|
||||
|
||||
zassert_equal(
|
||||
testAlarmAckIn.eventStateAcked, testAlarmAckOut.eventStateAcked, NULL);
|
||||
}
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
|
||||
void test_main(void)
|
||||
{
|
||||
ztest_test_suite(alarm_ack_tests,
|
||||
ztest_unit_test(testAlarmAck)
|
||||
);
|
||||
|
||||
ztest_run_test_suite(alarm_ack_tests);
|
||||
}
|
||||
Reference in New Issue
Block a user