73 lines
1.7 KiB
C
73 lines
1.7 KiB
C
/**
|
|
* @file
|
|
* @brief test BACnet real value encode/decode APIs
|
|
* @author Steve Karg <skarg@users.sourceforge.net>
|
|
* @date 2004
|
|
* @copyright SPDX-License-Identifier: MIT
|
|
*/
|
|
#include <math.h>
|
|
#include <zephyr/ztest.h>
|
|
#include <bacnet/bacreal.h>
|
|
#include <bacnet/bacdef.h>
|
|
|
|
/**
|
|
* @addtogroup bacnet_tests
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* @brief Test BACnet real data type (single precision floating point)
|
|
*/
|
|
#if defined(CONFIG_ZTEST_NEW_API)
|
|
ZTEST(bacreal_tests, testBACreal)
|
|
#else
|
|
static void testBACreal(void)
|
|
#endif
|
|
{
|
|
float real_value = 3.14159F, test_real_value = 0.0;
|
|
uint8_t apdu[MAX_APDU] = { 0 };
|
|
int len = 0, test_len = 0;
|
|
|
|
len = encode_bacnet_real(real_value, &apdu[0]);
|
|
zassert_equal(len, 4, NULL);
|
|
test_len = decode_real(&apdu[0], &test_real_value);
|
|
zassert_equal(test_len, len, NULL);
|
|
zassert_false(islessgreater(test_real_value, real_value), NULL);
|
|
}
|
|
|
|
/**
|
|
* @brief Test BACnet double data type (double precision floating point)
|
|
*/
|
|
#if defined(CONFIG_ZTEST_NEW_API)
|
|
ZTEST(bacreal_tests, testBACdouble)
|
|
#else
|
|
static void testBACdouble(void)
|
|
#endif
|
|
{
|
|
double double_value = 3.1415927, test_double_value = 0.0;
|
|
uint8_t apdu[MAX_APDU] = { 0 };
|
|
int len = 0, test_len = 0;
|
|
|
|
len = encode_bacnet_double(double_value, &apdu[0]);
|
|
zassert_equal(len, 8, NULL);
|
|
test_len = decode_double(&apdu[0], &test_double_value);
|
|
zassert_equal(test_len, len, NULL);
|
|
zassert_false(islessgreater(test_double_value, double_value), NULL);
|
|
}
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
#if defined(CONFIG_ZTEST_NEW_API)
|
|
ZTEST_SUITE(bacreal_tests, NULL, NULL, NULL, NULL, NULL);
|
|
#else
|
|
void test_main(void)
|
|
{
|
|
ztest_test_suite(
|
|
bacreal_tests, ztest_unit_test(testBACreal),
|
|
ztest_unit_test(testBACdouble));
|
|
|
|
ztest_run_test_suite(bacreal_tests);
|
|
}
|
|
#endif
|