FlashDB/tests/fdb_tsdb_tc.c

281 lines
7.2 KiB
C
Raw Normal View History

2020-05-24 18:39:09 +08:00
/*
* Copyright (c) 2020, Armink, <armink.ztl@gmail.com>
*
* SPDX-License-Identifier: Apache-2.0
*/
/**
* @file
* @brief TSDB testcases.
*
* This testcases is be used in RT-Thread Utest framework.
* If you want run it, please add it to RT-Thread project.
*/
#include "utest.h"
#include <flashdb.h>
#include <stdio.h>
#include <stdlib.h>
2022-06-10 17:56:29 +08:00
#if defined(RT_USING_UTEST) && defined(FDB_USING_TSDB)
2020-05-24 18:39:09 +08:00
#define TEST_TS_PART_NAME "fdb_tsdb1"
#define TEST_TS_COUNT 256
#define TEST_TS_USER_STATUS1_COUNT (TEST_TS_COUNT/2)
#define TEST_TS_DELETED_COUNT (TEST_TS_COUNT - TEST_TS_USER_STATUS1_COUNT)
static char logbuf[10];
2020-05-24 18:39:09 +08:00
static struct fdb_tsdb test_tsdb;
static int cur_times = 0;
static fdb_time_t get_time(void)
{
return cur_times ++;
}
static void test_fdb_tsdb_init_ex(void)
{
if (access("/fdb_tsdb1", 0) < 0)
{
mkdir("/fdb_tsdb1", 0);
}
#ifndef FDB_USING_FAL_MODE
uint32_t sec_size = 4096, db_size = sec_size * 16;
rt_bool_t file_mode = true;
fdb_kvdb_control((fdb_kvdb_t)&(test_tsdb), FDB_TSDB_CTRL_SET_SEC_SIZE, &sec_size);
fdb_kvdb_control((fdb_kvdb_t)&(test_tsdb), FDB_TSDB_CTRL_SET_FILE_MODE, &file_mode);
fdb_kvdb_control((fdb_kvdb_t)&(test_tsdb), FDB_TSDB_CTRL_SET_MAX_SIZE, &db_size);
#endif
2020-05-24 18:39:09 +08:00
uassert_true(fdb_tsdb_init(&test_tsdb, "test_ts", TEST_TS_PART_NAME, get_time, 128, NULL) == FDB_NO_ERR);
}
static void test_fdb_tsl_append(void)
{
struct fdb_blob blob;
int i;
for (i = 0; i < TEST_TS_COUNT; ++i) {
rt_snprintf(logbuf, sizeof(logbuf), "%d", i);
uassert_true(fdb_tsl_append(&test_tsdb, fdb_blob_make(&blob, logbuf, rt_strnlen(logbuf, sizeof(logbuf)))) == FDB_NO_ERR);
2020-05-24 18:39:09 +08:00
}
}
static bool test_fdb_tsl_iter_cb(fdb_tsl_t tsl, void *arg)
{
struct fdb_blob blob;
char data[sizeof(logbuf)];
2020-05-24 18:39:09 +08:00
size_t read_len;
fdb_blob_make(&blob, data, tsl->log_len);
read_len = fdb_blob_read((fdb_db_t) &test_tsdb, fdb_tsl_to_blob(tsl, &blob));
data[read_len] = '\0';
if (arg == NULL) {
uassert_true(tsl->time == atoi(data));
} else {
uassert_true(tsl->time == *((fdb_time_t *)arg));
}
2020-05-24 18:39:09 +08:00
return false;
}
static void test_fdb_tsl_iter(void)
{
fdb_tsl_iter(&test_tsdb, test_fdb_tsl_iter_cb, NULL);
}
static void test_fdb_tsl_iter_by_time(void)
{
fdb_time_t from = 0, to = TEST_TS_COUNT -1;
for (fdb_time_t cur = from; cur <= to; cur ++) {
fdb_tsl_iter_by_time(&test_tsdb, cur, cur, test_fdb_tsl_iter_cb, &cur);
}
2020-05-24 18:39:09 +08:00
fdb_tsl_iter_by_time(&test_tsdb, from, to, test_fdb_tsl_iter_cb, NULL);
}
static void test_fdb_tsl_query_count(void)
{
fdb_time_t from = 0, to = TEST_TS_COUNT -1;
uassert_true(fdb_tsl_query_count(&test_tsdb, from, to, FDB_TSL_WRITE) == TEST_TS_COUNT);
}
static bool est_fdb_tsl_set_status_cb(fdb_tsl_t tsl, void *arg)
{
fdb_tsdb_t db = arg;
if (tsl->time >= 0 && tsl->time < TEST_TS_USER_STATUS1_COUNT) {
uassert_true(fdb_tsl_set_status(db, tsl, FDB_TSL_USER_STATUS1) == FDB_NO_ERR);
} else {
uassert_true(fdb_tsl_set_status(db, tsl, FDB_TSL_DELETED) == FDB_NO_ERR);
}
return false;
}
static void test_fdb_tsl_set_status(void)
{
fdb_time_t from = 0, to = TEST_TS_COUNT -1;
fdb_tsl_iter_by_time(&test_tsdb, from, to, est_fdb_tsl_set_status_cb, &test_tsdb);
uassert_true(fdb_tsl_query_count(&test_tsdb, from, to, FDB_TSL_USER_STATUS1) == TEST_TS_USER_STATUS1_COUNT);
uassert_true(fdb_tsl_query_count(&test_tsdb, from, to, FDB_TSL_DELETED) == TEST_TS_DELETED_COUNT);
}
static bool test_fdb_tsl_clean_cb(fdb_tsl_t tsl, void *arg)
{
size_t *count = arg;
(*count) ++;
return false;
}
static void test_fdb_tsl_clean(void)
{
size_t count = 0;
cur_times = 0;
2020-05-24 18:39:09 +08:00
fdb_tsl_clean(&test_tsdb);
fdb_tsl_iter(&test_tsdb, test_fdb_tsl_clean_cb, &count);
uassert_true(count == 0);
}
static rt_err_t utest_tc_init(void)
{
cur_times = 0;
rt_memset(&test_tsdb, 0, sizeof(struct fdb_tsdb));
return RT_EOK;
}
static rt_err_t utest_tc_cleanup(void)
{
return RT_EOK;
}
static rt_slist_t recv_data_list;
struct recv_data {
int data;
fdb_time_t time;
rt_slist_t list;
};
static bool query_cb(fdb_tsl_t tsl, void *arg)
{
struct fdb_blob blob;
int data;
struct recv_data *list;
fdb_blob_read((fdb_db_t) &test_tsdb, fdb_tsl_to_blob(tsl, fdb_blob_make(&blob, &data, sizeof(data))));
list = rt_malloc(sizeof(*list));
list->data = data;
list->time = tsl->time;
rt_slist_append(&recv_data_list,&list->list);
return false;
}
static void tsdb_data_utest(fdb_time_t from,fdb_time_t to)
{
int len,iter_data_len;
fdb_time_t start = from;
rt_slist_t *node;
struct recv_data *recv_obj;
if(from <= to)
iter_data_len = to - from + 1;
else
iter_data_len = from - to + 1;
fdb_tsl_iter_by_time(&test_tsdb,from,to,query_cb,NULL);
len = rt_slist_len(&recv_data_list);
uassert_true(len == iter_data_len);
rt_slist_for_each(node,&recv_data_list) {
recv_obj = rt_slist_entry(node, struct recv_data, list);
uassert_true(recv_obj->time == recv_obj->data);
if(start <= to)
uassert_true(recv_obj->data == from++);
else
uassert_true(recv_obj->data == from--);
rt_free(recv_obj);
}
rt_slist_init(&recv_data_list);
}
static void tsdb_fdb_tsl_iter_reverse(void)
{
rt_slist_t *node;
int len,data = 799;
struct recv_data *recv_obj;
fdb_tsl_iter_reverse(&test_tsdb,query_cb,NULL);
len = rt_slist_len(&recv_data_list);
uassert_true(len == 800);
rt_slist_for_each(node,&recv_data_list) {
recv_obj = rt_slist_entry(node, struct recv_data, list);
uassert_true(recv_obj->time == recv_obj->data);
uassert_true(recv_obj->data == data--);
rt_free(recv_obj);
}
rt_slist_init(&recv_data_list);
}
static void test_fdb_tsl_iter_by_time_1(void)
{
struct fdb_blob blob;
int data;
rt_slist_init(&recv_data_list);
for(data = 0; data < 800 ; data++) {
fdb_tsl_append(&test_tsdb, fdb_blob_make(&blob, &data, sizeof(data)));
}
/* Adjacent sector iteration */
tsdb_data_utest(45,234);
/* Iterating across a sector */
tsdb_data_utest(37,423);
/* Iterating across two sectors */
tsdb_data_utest(201,774);
/* Same sector iteration */
tsdb_data_utest(334,334);
/* Reverse iteration of adjacent sectors */
tsdb_data_utest(234,2);
/* Reverse iterations across a sectors */
tsdb_data_utest(650,400);
/* Reverse iterations across two sectors */
tsdb_data_utest(773,123);
/* Reverse iteration of the same sector */
tsdb_data_utest(430,425);
}
2020-05-24 18:39:09 +08:00
static void testcase(void)
{
UTEST_UNIT_RUN(test_fdb_tsdb_init_ex);
UTEST_UNIT_RUN(test_fdb_tsl_clean);
UTEST_UNIT_RUN(test_fdb_tsl_append);
UTEST_UNIT_RUN(test_fdb_tsl_iter);
UTEST_UNIT_RUN(test_fdb_tsl_iter_by_time);
UTEST_UNIT_RUN(test_fdb_tsl_query_count);
UTEST_UNIT_RUN(test_fdb_tsl_set_status);
UTEST_UNIT_RUN(test_fdb_tsl_clean);
UTEST_UNIT_RUN(test_fdb_tsl_iter_by_time_1);
UTEST_UNIT_RUN(tsdb_fdb_tsl_iter_reverse);
2020-05-24 18:39:09 +08:00
}
UTEST_TC_EXPORT(testcase, "packages.tools.flashdb.tsdb", utest_tc_init, utest_tc_cleanup, 20);
#endif /* defined(RT_USING_UTEST) && defined(FDBTC_USING_TSDB) && defined(TC_USING_FDBTC_TSDB) */