Files
bacnet_stack/test/bacnet/bacreal/src/main.c
T

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