239 lines
6.3 KiB
C
239 lines
6.3 KiB
C
#include "inc.h"
|
|
|
|
char *key_u32 = "test_u32";
|
|
char *key_str = "test_str";
|
|
char *key_mem = "test_mem";
|
|
char *key_map = "test_map";
|
|
char *key_label = "test_label";
|
|
|
|
/*===========================================================================*
|
|
* test_u32 *
|
|
*===========================================================================*/
|
|
void test_u32(void)
|
|
{
|
|
int r;
|
|
u32_t value;
|
|
|
|
/* Publish and retrieve. */
|
|
r = ds_publish_u32(key_u32, 1234, 0);
|
|
assert(r == OK);
|
|
r = ds_retrieve_u32(key_u32, &value);
|
|
assert(r == OK && value == 1234);
|
|
|
|
/* If dstest deletes 'test_u32' immediately after publishing it,
|
|
* subs will catch the event, but it can't check it immediately.
|
|
* So dstest will sleep 2 seconds to wait for subs to complete. */
|
|
sleep(2);
|
|
|
|
/* Publish again without DSF_OVERWRITE. */
|
|
r = ds_publish_u32(key_u32, 4321, 0);
|
|
assert(r == EEXIST);
|
|
|
|
/* Publish again with DSF_OVERWRITE to overwrite it. */
|
|
r = ds_publish_u32(key_u32, 4321, DSF_OVERWRITE);
|
|
assert(r == OK);
|
|
r = ds_retrieve_u32(key_u32, &value);
|
|
assert(r == OK && value == 4321);
|
|
|
|
/* Delete. */
|
|
r = ds_delete_u32(key_u32);
|
|
assert(r == OK);
|
|
r = ds_retrieve_u32(key_u32, &value);
|
|
assert(r == ESRCH);
|
|
|
|
printf("DSTEST: U32 test successful!\n");
|
|
}
|
|
|
|
/*===========================================================================*
|
|
* test_str *
|
|
*===========================================================================*/
|
|
void test_str(void)
|
|
{
|
|
int r;
|
|
char *string = "little";
|
|
char *longstring = "verylooooooongstring";
|
|
char buf[17];
|
|
|
|
r = ds_publish_str(key_str, string, 0);
|
|
assert(r == OK);
|
|
|
|
r = ds_retrieve_str(key_str, buf, sizeof(buf)-1);
|
|
assert(r == OK && strcmp(string, buf) == 0);
|
|
|
|
r = ds_delete_str(key_str);
|
|
assert(r == OK);
|
|
|
|
/* Publish a long string. */
|
|
r = ds_publish_str(key_str, longstring, 0);
|
|
assert(r == OK);
|
|
|
|
r = ds_retrieve_str(key_str, buf, sizeof(buf)-1);
|
|
assert(r == OK && strcmp(string, buf) != 0
|
|
&& strncmp(longstring, buf, sizeof(buf)-1) == 0);
|
|
|
|
r = ds_delete_str(key_str);
|
|
assert(r == OK);
|
|
|
|
printf("DSTEST: STRING test successful!\n");
|
|
}
|
|
|
|
/*===========================================================================*
|
|
* test_mem *
|
|
*===========================================================================*/
|
|
void test_mem(void)
|
|
{
|
|
char *string1 = "ok, this is a string";
|
|
char *string2 = "ok, this is a very looooong string";
|
|
size_t len1 = strlen(string1) + 1;
|
|
size_t len2 = strlen(string2) + 1;
|
|
char buf[100];
|
|
size_t get_len;
|
|
int r;
|
|
|
|
/* Publish and retrieve. */
|
|
r = ds_publish_mem(key_mem, string1, len1, 0);
|
|
assert(r == OK);
|
|
get_len = 100;
|
|
r = ds_retrieve_mem(key_mem, buf, &get_len);
|
|
assert(r == OK && strcmp(string1, buf) == 0);
|
|
assert(get_len == len1);
|
|
|
|
/* Let get_len=8, which is less than strlen(string1). */
|
|
get_len = 8;
|
|
r = ds_retrieve_mem(key_mem, buf, &get_len);
|
|
assert(r == OK && get_len == 8);
|
|
|
|
/* Publish again to overwrite with a bigger memory range. */
|
|
r = ds_publish_mem(key_mem, string2, len2, DSF_OVERWRITE);
|
|
assert(r == OK);
|
|
|
|
get_len = 100;
|
|
r = ds_retrieve_mem(key_mem, buf, &get_len);
|
|
assert(r == OK && strcmp(string2, buf) == 0);
|
|
assert(get_len == len2);
|
|
|
|
r = ds_delete_mem(key_mem);
|
|
assert(r == OK);
|
|
|
|
printf("DSTEST: MEM test successful!\n");
|
|
}
|
|
|
|
/*===========================================================================*
|
|
* test_label *
|
|
*===========================================================================*/
|
|
void test_label(void)
|
|
{
|
|
int r;
|
|
char label[DS_MAX_KEYLEN];
|
|
endpoint_t endpoint;
|
|
|
|
/* Retrieve own label and endpoint. */
|
|
r = ds_retrieve_label_name(label, getprocnr());
|
|
assert(r == OK);
|
|
r = ds_retrieve_label_endpt(label, &endpoint);
|
|
assert(r == OK && endpoint == getprocnr());
|
|
|
|
/* Publish and delete. */
|
|
r = ds_publish_label(label, endpoint, 0);
|
|
assert(r == EPERM);
|
|
r = ds_delete_label(label);
|
|
assert(r == EPERM);
|
|
|
|
printf("DSTEST: LABEL test successful!\n");
|
|
}
|
|
|
|
/*===========================================================================*
|
|
* test_map *
|
|
*===========================================================================*/
|
|
void test_map(void)
|
|
{
|
|
char buf_buf[CLICK_SIZE * 2];
|
|
char buf_buf2[CLICK_SIZE * 2];
|
|
char *buf, *buf2;
|
|
char get_buf[CLICK_SIZE];
|
|
int *p;
|
|
volatile int *p2;
|
|
int *get_p;
|
|
size_t get_len;
|
|
int is;
|
|
int r;
|
|
|
|
buf = (char*) CLICK_CEIL(buf_buf);
|
|
buf2 = (char*) CLICK_CEIL(buf_buf2);
|
|
|
|
p = (int *)buf;
|
|
p2 = (int *)buf2;
|
|
get_p = (int *)get_buf;
|
|
|
|
*p = 1;
|
|
r = ds_publish_map(key_map, buf, CLICK_SIZE, 0);
|
|
assert(r == OK);
|
|
|
|
r = ds_snapshot_map(key_map, &is);
|
|
assert(r == OK);
|
|
|
|
/* Copy the mapped memory range.
|
|
* Set *p=2, then the mapped memory range should change too
|
|
* and *get_p should be 2.
|
|
*/
|
|
*p = 2;
|
|
get_len = CLICK_SIZE;
|
|
r = ds_retrieve_map(key_map, get_buf, &get_len, 0, DSMF_COPY_MAPPED);
|
|
assert(r == OK && get_len == CLICK_SIZE && *get_p == 2);
|
|
|
|
/* Copy snapshot, where *get_p should still be 1. */
|
|
get_len = CLICK_SIZE;
|
|
r = ds_retrieve_map(key_map, get_buf, &get_len, is, DSMF_COPY_SNAPSHOT);
|
|
assert(r == OK && get_len == CLICK_SIZE && *get_p == 1);
|
|
|
|
/* Map the mapped memory range to @buf2, then set *p=3, which
|
|
* in turn should let *p2=3.
|
|
*/
|
|
get_len = CLICK_SIZE;
|
|
r = ds_retrieve_map(key_map, buf2, &get_len, 0, DSMF_MAP_MAPPED);
|
|
assert(r == OK && get_len == CLICK_SIZE);
|
|
*p = 3;
|
|
assert(*p2 == 3);
|
|
|
|
r = ds_delete_map(key_map);
|
|
assert(r == OK);
|
|
|
|
printf("DSTEST: MAP test successful!\n");
|
|
}
|
|
|
|
/*===========================================================================*
|
|
* sef_cb_init_fresh *
|
|
*===========================================================================*/
|
|
static int sef_cb_init_fresh(int UNUSED(type), sef_init_info_t *UNUSED(info))
|
|
{
|
|
/* Run all the tests. */
|
|
test_u32();
|
|
test_str();
|
|
test_mem();
|
|
test_map();
|
|
test_label();
|
|
|
|
return OK;
|
|
}
|
|
|
|
/*===========================================================================*
|
|
* sef_local_startup *
|
|
*===========================================================================*/
|
|
static void sef_local_startup(void)
|
|
{
|
|
/* Let SEF perform startup. */
|
|
sef_setcb_init_fresh(sef_cb_init_fresh);
|
|
|
|
sef_startup();
|
|
}
|
|
|
|
/*===========================================================================*
|
|
* main *
|
|
*===========================================================================*/
|
|
int main(void)
|
|
{
|
|
/* SEF local startup. */
|
|
sef_local_startup();
|
|
|
|
return 0;
|
|
}
|