mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
290 lines
9.7 KiB
C
290 lines
9.7 KiB
C
/*
|
|
* Copyright (C) 2018 Eistec AB
|
|
* 2018 Otto-von-Guericke-Universität Magdeburg
|
|
* 2017 Freie Universität Berlin
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Unittests for the phydat module
|
|
*
|
|
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
*
|
|
* @}
|
|
*/
|
|
|
|
#include <string.h>
|
|
|
|
#include "embUnit.h"
|
|
#include "tests-phydat.h"
|
|
|
|
#include "phydat.h"
|
|
|
|
#define ENABLE_DEBUG 0
|
|
#include "debug.h"
|
|
|
|
/* Default is smaller implementation */
|
|
#ifndef PHYDAT_FIT_TRADE_PRECISION_FOR_ROM
|
|
#define PHYDAT_FIT_TRADE_PRECISION_FOR_ROM 1
|
|
#endif
|
|
|
|
#if (PHYDAT_DIM != 3)
|
|
#error "PHYDAT unittests are only applicable if PHYDAT_DIM is 3"
|
|
#endif
|
|
|
|
#define BUFSIZE (128U)
|
|
|
|
static char test[BUFSIZE];
|
|
|
|
typedef struct {
|
|
int dim;
|
|
phydat_t dat;
|
|
const char *json;
|
|
} tdat_t;
|
|
|
|
/* define test data */
|
|
static tdat_t data[] = {
|
|
{
|
|
.dim = 1,
|
|
.dat = { { 2345, 0, 0 }, UNIT_TEMP_C, -2 },
|
|
.json = "{\"d\":23.45,\"u\":\"°C\"}",
|
|
},
|
|
{
|
|
.dim = 3,
|
|
.dat = { { 1032, 10, -509 }, UNIT_G, -3 },
|
|
.json = "{\"d\":[1.032,0.010,-0.509],\"u\":\"g\"}",
|
|
},
|
|
{
|
|
.dim = 3,
|
|
.dat = { { 1200, 38, 98 }, UNIT_M, -3 },
|
|
.json = "{\"d\":[1.200,0.038,0.098],\"u\":\"m\"}",
|
|
},
|
|
{
|
|
.dim = 2,
|
|
.dat = { { 19, 23, 0 }, UNIT_NONE, 0 },
|
|
.json = "{\"d\":[19,23],\"u\":\"none\"}",
|
|
},
|
|
{
|
|
.dim = 1,
|
|
.dat = { { 1, 0, 0 }, UNIT_BOOL, 0 },
|
|
.json = "{\"d\":true,\"u\":\"none\"}",
|
|
},
|
|
{
|
|
.dim = 3,
|
|
.dat = { { 1, 0, 1 }, UNIT_BOOL, 0 },
|
|
.json = "{\"d\":[true,false,true],\"u\":\"none\"}",
|
|
},
|
|
{
|
|
.dim = 3,
|
|
.dat = { { 1, 1, 1970 }, UNIT_DATE, 0 },
|
|
.json = "{\"d\":[1,1,1970],\"u\":\"date\"}",
|
|
},
|
|
{
|
|
.dim = 3,
|
|
.dat = { { 23, 59, 14}, UNIT_TIME, 0 },
|
|
.json = "\"d\":[23,59,14],\"u\":\"time\"}",
|
|
}
|
|
|
|
};
|
|
|
|
static void test_phydat_fit(void)
|
|
{
|
|
/* Input values for each test: */
|
|
static const int32_t values[][3] = {
|
|
{ 100445, -1, -1 },
|
|
{ -5, 2000954, 3 },
|
|
{ 30000449, -30000450, 30000500 },
|
|
{ -30000449, -30000499, -30000500 },
|
|
{ 0, 0, 1234567 },
|
|
{ 32768, 32768, 32768 },
|
|
{ 32767, 32767, 32767 },
|
|
{ 32766, 32766, 32766 },
|
|
{ -32769, -32769, -32769 },
|
|
{ -32768, -32768, -32768 },
|
|
{ -32767, -32767, -32767 },
|
|
{ -32766, -32766, -32766 },
|
|
};
|
|
static const int8_t scales[] = {
|
|
-6,
|
|
42,
|
|
0,
|
|
-1,
|
|
5,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
};
|
|
static const unsigned int dims[] = {
|
|
1,
|
|
2,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
};
|
|
static const uint8_t units[] = {
|
|
UNIT_V,
|
|
UNIT_A,
|
|
UNIT_NONE,
|
|
UNIT_LUX,
|
|
UNIT_M,
|
|
UNIT_NONE,
|
|
UNIT_NONE,
|
|
UNIT_NONE,
|
|
UNIT_NONE,
|
|
UNIT_NONE,
|
|
UNIT_NONE,
|
|
UNIT_NONE,
|
|
};
|
|
/* Expected output values for each test: */
|
|
static const phydat_t expected[] = {
|
|
{ .val = { 10045, -1, -1 }, .unit = UNIT_V, .scale = -5 },
|
|
{ .val = { 0, 20010, -1 }, .unit = UNIT_A, .scale = 44 },
|
|
{ .val = { 30000, -30000, 30001 }, .unit = UNIT_NONE, .scale = 3 },
|
|
{ .val = { -30000, -30000, -30001 }, .unit = UNIT_LUX, .scale = 2 },
|
|
{ .val = { 0, 0, 12346 }, .unit = UNIT_M, .scale = 7 },
|
|
{ .val = { 3277, 3277, 3277 }, .unit = UNIT_NONE, .scale = 1 },
|
|
{ .val = { 32767, 32767, 32767 }, .unit = UNIT_NONE, .scale = 0 },
|
|
{ .val = { 32766, 32766, 32766 }, .unit = UNIT_NONE, .scale = 0 },
|
|
{ .val = { -3277, -3277, -3277 }, .unit = UNIT_NONE, .scale = 1 },
|
|
#if PHYDAT_FIT_TRADE_PRECISION_FOR_ROM
|
|
{ .val = { -3277, -3277, -3277 }, .unit = UNIT_NONE, .scale = 1 },
|
|
#else
|
|
{ .val = { -32768, -32768, -32768 }, .unit = UNIT_NONE, .scale = 0 },
|
|
#endif
|
|
{ .val = { -32767, -32767, -32767 }, .unit = UNIT_NONE, .scale = 0 },
|
|
{ .val = { -32766, -32766, -32766 }, .unit = UNIT_NONE, .scale = 0 },
|
|
};
|
|
|
|
for (unsigned int i = 0; i < ARRAY_SIZE(dims); i++) {
|
|
phydat_t dat = {
|
|
.val = { -1, -1, -1 },
|
|
.scale = scales[i],
|
|
.unit = units[i]
|
|
};
|
|
phydat_fit(&dat, values[i], dims[i]);
|
|
TEST_ASSERT_EQUAL_INT(expected[i].val[0], dat.val[0]);
|
|
TEST_ASSERT_EQUAL_INT(expected[i].val[1], dat.val[1]);
|
|
TEST_ASSERT_EQUAL_INT(expected[i].val[2], dat.val[2]);
|
|
TEST_ASSERT_EQUAL_INT(expected[i].scale, dat.scale);
|
|
TEST_ASSERT_EQUAL_INT(expected[i].unit, dat.unit);
|
|
}
|
|
}
|
|
|
|
static void test_unitstr__success(void)
|
|
{
|
|
/* test the verbose cases */
|
|
TEST_ASSERT_EQUAL_STRING("undefined", phydat_unit_to_str_verbose(UNIT_UNDEF));
|
|
TEST_ASSERT_EQUAL_STRING("none", phydat_unit_to_str_verbose(UNIT_NONE));
|
|
TEST_ASSERT_EQUAL_STRING("none", phydat_unit_to_str_verbose(UNIT_BOOL));
|
|
TEST_ASSERT_EQUAL_STRING("time", phydat_unit_to_str_verbose(UNIT_TIME));
|
|
TEST_ASSERT_EQUAL_STRING("date", phydat_unit_to_str_verbose(UNIT_DATE));
|
|
|
|
TEST_ASSERT_EQUAL_STRING("°C", phydat_unit_to_str_verbose(UNIT_TEMP_C));
|
|
TEST_ASSERT_EQUAL_STRING("°F", phydat_unit_to_str_verbose(UNIT_TEMP_F));
|
|
TEST_ASSERT_EQUAL_STRING("K", phydat_unit_to_str_verbose(UNIT_TEMP_K));
|
|
TEST_ASSERT_EQUAL_STRING("lx", phydat_unit_to_str_verbose(UNIT_LUX));
|
|
TEST_ASSERT_EQUAL_STRING("m", phydat_unit_to_str_verbose(UNIT_M));
|
|
TEST_ASSERT_EQUAL_STRING("m^2", phydat_unit_to_str_verbose(UNIT_M2));
|
|
TEST_ASSERT_EQUAL_STRING("m^3", phydat_unit_to_str_verbose(UNIT_M3));
|
|
TEST_ASSERT_EQUAL_STRING("g", phydat_unit_to_str_verbose(UNIT_G));
|
|
TEST_ASSERT_EQUAL_STRING("dps", phydat_unit_to_str_verbose(UNIT_DPS));
|
|
TEST_ASSERT_EQUAL_STRING("G", phydat_unit_to_str_verbose(UNIT_GR));
|
|
TEST_ASSERT_EQUAL_STRING("A", phydat_unit_to_str_verbose(UNIT_A));
|
|
TEST_ASSERT_EQUAL_STRING("V", phydat_unit_to_str_verbose(UNIT_V));
|
|
TEST_ASSERT_EQUAL_STRING("W", phydat_unit_to_str_verbose(UNIT_W));
|
|
TEST_ASSERT_EQUAL_STRING("dBm", phydat_unit_to_str_verbose(UNIT_DBM));
|
|
TEST_ASSERT_EQUAL_STRING("Gs", phydat_unit_to_str_verbose(UNIT_GS));
|
|
TEST_ASSERT_EQUAL_STRING("Bar", phydat_unit_to_str_verbose(UNIT_BAR));
|
|
TEST_ASSERT_EQUAL_STRING("Pa", phydat_unit_to_str_verbose(UNIT_PA));
|
|
TEST_ASSERT_EQUAL_STRING("permille", phydat_unit_to_str_verbose(UNIT_PERMILL));
|
|
TEST_ASSERT_EQUAL_STRING("ppm", phydat_unit_to_str_verbose(UNIT_PPM));
|
|
TEST_ASSERT_EQUAL_STRING("ppb", phydat_unit_to_str_verbose(UNIT_PPB));
|
|
TEST_ASSERT_EQUAL_STRING("cd", phydat_unit_to_str_verbose(UNIT_CD));
|
|
TEST_ASSERT_EQUAL_STRING("%", phydat_unit_to_str_verbose(UNIT_PERCENT));
|
|
TEST_ASSERT_EQUAL_STRING("cts", phydat_unit_to_str_verbose(UNIT_CTS));
|
|
TEST_ASSERT_EQUAL_STRING("C", phydat_unit_to_str_verbose(UNIT_COULOMB));
|
|
TEST_ASSERT_EQUAL_STRING("g/m^3", phydat_unit_to_str_verbose(UNIT_GPM3));
|
|
TEST_ASSERT_EQUAL_STRING("F", phydat_unit_to_str_verbose(UNIT_F));
|
|
TEST_ASSERT_EQUAL_STRING("pH", phydat_unit_to_str_verbose(UNIT_PH));
|
|
TEST_ASSERT_EQUAL_STRING("#/m^3", phydat_unit_to_str_verbose(UNIT_CPM3));
|
|
TEST_ASSERT_EQUAL_STRING("ohm", phydat_unit_to_str_verbose(UNIT_OHM));
|
|
|
|
}
|
|
|
|
static void test_json__success(void)
|
|
{
|
|
size_t len;
|
|
|
|
len = phydat_to_json(&data[0].dat, data[0].dim, NULL);
|
|
TEST_ASSERT_EQUAL_INT((strlen(data[0].json) + 1), len);
|
|
len = phydat_to_json(&data[0].dat, data[0].dim, test);
|
|
TEST_ASSERT_EQUAL_INT(strlen(data[0].json), strlen(test));
|
|
TEST_ASSERT_EQUAL_STRING(data[0].json, (const char *)test);
|
|
|
|
len = phydat_to_json(&data[1].dat, data[1].dim, NULL);
|
|
TEST_ASSERT_EQUAL_INT((strlen(data[1].json) + 1), len);
|
|
len = phydat_to_json(&data[1].dat, data[1].dim, test);
|
|
TEST_ASSERT_EQUAL_INT(strlen(data[1].json), strlen(test));
|
|
TEST_ASSERT_EQUAL_STRING(data[1].json, (const char *)test);
|
|
|
|
len = phydat_to_json(&data[2].dat, data[2].dim, NULL);
|
|
TEST_ASSERT_EQUAL_INT((strlen(data[2].json) + 1), len);
|
|
len = phydat_to_json(&data[2].dat, data[2].dim, test);
|
|
TEST_ASSERT_EQUAL_INT(strlen(data[2].json), strlen(test));
|
|
TEST_ASSERT_EQUAL_STRING(data[2].json, (const char *)test);
|
|
|
|
len = phydat_to_json(&data[3].dat, data[3].dim, NULL);
|
|
TEST_ASSERT_EQUAL_INT((strlen(data[3].json) + 1), len);
|
|
len = phydat_to_json(&data[3].dat, data[3].dim, test);
|
|
TEST_ASSERT_EQUAL_INT(strlen(data[3].json), strlen(test));
|
|
TEST_ASSERT_EQUAL_STRING(data[3].json, (const char *)test);
|
|
|
|
len = phydat_to_json(&data[4].dat, data[4].dim, NULL);
|
|
TEST_ASSERT_EQUAL_INT((strlen(data[4].json) + 1), len);
|
|
len = phydat_to_json(&data[4].dat, data[4].dim, test);
|
|
TEST_ASSERT_EQUAL_INT(strlen(data[4].json), strlen(test));
|
|
TEST_ASSERT_EQUAL_STRING(data[4].json, (const char *)test);
|
|
|
|
len = phydat_to_json(&data[5].dat, data[5].dim, NULL);
|
|
TEST_ASSERT_EQUAL_INT((strlen(data[5].json) + 1), len);
|
|
len = phydat_to_json(&data[5].dat, data[5].dim, test);
|
|
TEST_ASSERT_EQUAL_INT(strlen(data[5].json), strlen(test));
|
|
TEST_ASSERT_EQUAL_STRING(data[5].json, (const char *)test);
|
|
}
|
|
|
|
Test *tests_phydat_tests(void)
|
|
{
|
|
EMB_UNIT_TESTFIXTURES(fixtures) {
|
|
new_TestFixture(test_phydat_fit),
|
|
new_TestFixture(test_unitstr__success),
|
|
new_TestFixture(test_json__success),
|
|
};
|
|
|
|
EMB_UNIT_TESTCALLER(phydat_tests, NULL, NULL, fixtures);
|
|
|
|
return (Test *)&phydat_tests;
|
|
}
|
|
|
|
void tests_phydat(void)
|
|
{
|
|
TESTS_RUN(tests_phydat_tests());
|
|
}
|