rbtree和hash的全量持久化操作。rbtree的二进制安全。
粗略测试。
This commit is contained in:
263
test/testcase.c
263
test/testcase.c
@@ -45,18 +45,19 @@ int recv_msg(int connfd, char *msg, int length) {
|
||||
|
||||
}
|
||||
|
||||
void testcase(int connfd, uint8_t op, const char* key, const char* value, rsp_ret_status_e st, const char* rsp_value, const char* command_name){
|
||||
void testcase(int connfd, uint8_t op, const char* key, uint32_t key_len, const char* value,
|
||||
uint32_t value_len, rsp_ret_status_e st, const char* rsp_value, uint32_t expect_len, const char* command_name){
|
||||
uint8_t buf[CMD_SIZE];
|
||||
uint8_t result[CMD_SIZE];
|
||||
kvs_response_t rsp;
|
||||
int len, recv_len;
|
||||
|
||||
len = getcmd(op, key, value, buf);
|
||||
len = getcmd(op, key, key_len, value, value_len, buf);
|
||||
send_msg(connfd, buf, len);
|
||||
recv_len = recv_msg(connfd, result, CMD_SIZE);
|
||||
if (parse_response(result, recv_len, &rsp) > 0) {
|
||||
PRESP(command_name, &rsp);
|
||||
if(!verify_response(&rsp, op, st, rsp_value)) printf("%s\n", command_name);
|
||||
if(!verify_response(&rsp, op, st, rsp_value, expect_len)) printf("%s\n", command_name);
|
||||
}else{
|
||||
printf("parser error\n");
|
||||
}
|
||||
@@ -67,23 +68,23 @@ void testcase(int connfd, uint8_t op, const char* key, const char* value, rsp_re
|
||||
|
||||
void array_testcase_1w(int connfd) {
|
||||
|
||||
int count = 1000;
|
||||
int count = 1;
|
||||
int i = 0;
|
||||
|
||||
struct timeval tv_begin;
|
||||
gettimeofday(&tv_begin, NULL);
|
||||
|
||||
for (i = 0;i < count;i ++) {
|
||||
testcase(connfd, KVS_CMD_SET, "name", "lian", KVS_STATUS_OK, NULL, "SET NAME");
|
||||
testcase(connfd, KVS_CMD_GET, "name", NULL, KVS_STATUS_OK, "lian", "GET NAME");
|
||||
testcase(connfd, KVS_CMD_MOD, "name", "liu", KVS_STATUS_OK, NULL, "MOD NAME");
|
||||
testcase(connfd, KVS_CMD_GET, "name", NULL, KVS_STATUS_OK, "liu", "GET NAME");
|
||||
testcase(connfd, KVS_CMD_EXIST, "name", NULL, KVS_STATUS_EXIST, NULL, "EXIST NAME");
|
||||
testcase(connfd, KVS_CMD_DEL, "name", NULL, KVS_STATUS_OK, NULL, "DEL NAME");
|
||||
testcase(connfd, KVS_CMD_EXIST, "name", NULL, KVS_STATUS_NO_EXIST, NULL, "NOT EXIST NAME");
|
||||
testcase(connfd, KVS_CMD_SET, "name", 4, "l\r\0n", 4, KVS_STATUS_OK, NULL, 0, "SET NAME");
|
||||
testcase(connfd, KVS_CMD_GET, "name", 4, NULL, 0, KVS_STATUS_OK, "l\r\0n", 4, "GET NAME");
|
||||
testcase(connfd, KVS_CMD_MOD, "name", 4, "liu", 3, KVS_STATUS_OK, NULL, 0, "MOD NAME");
|
||||
testcase(connfd, KVS_CMD_GET, "name", 4, NULL, 0, KVS_STATUS_OK, "liu", 3, "GET NAME");
|
||||
testcase(connfd, KVS_CMD_EXIST, "name", 4, NULL, 0, KVS_STATUS_EXIST, NULL, 0, "EXIST NAME");
|
||||
testcase(connfd, KVS_CMD_DEL, "name", 4, NULL, 0, KVS_STATUS_OK, NULL, 0, "DEL NAME");
|
||||
testcase(connfd, KVS_CMD_EXIST, "name", 4, NULL, 0, KVS_STATUS_NO_EXIST, NULL, 0, "EXIST NAME");
|
||||
|
||||
testcase(connfd, KVS_CMD_MOD, "stu", "liu", KVS_STATUS_NO_EXIST, NULL, "MOD NAME");
|
||||
testcase(connfd, KVS_CMD_DEL, "stu", NULL, KVS_STATUS_NO_EXIST, NULL, "DEL SUT");
|
||||
testcase(connfd, KVS_CMD_MOD, "stu", 3, "liu", 3, KVS_STATUS_NO_EXIST, NULL, 0, "MOD NAME");
|
||||
testcase(connfd, KVS_CMD_DEL, "stu", 3, NULL, 0, KVS_STATUS_NO_EXIST, NULL, 0, "DEL SUT");
|
||||
}
|
||||
|
||||
struct timeval tv_end;
|
||||
@@ -97,23 +98,23 @@ void array_testcase_1w(int connfd) {
|
||||
|
||||
void rbtree_testcase_1w(int connfd) {
|
||||
|
||||
int count = 1000;
|
||||
int count = 1;
|
||||
int i = 0;
|
||||
|
||||
struct timeval tv_begin;
|
||||
gettimeofday(&tv_begin, NULL);
|
||||
|
||||
for (i = 0;i < count;i ++) {
|
||||
testcase(connfd, KVS_CMD_RSET, "name", "lian", KVS_STATUS_OK, NULL, "SET NAME");
|
||||
testcase(connfd, KVS_CMD_RGET, "name", NULL, KVS_STATUS_OK, "lian", "GET NAME");
|
||||
testcase(connfd, KVS_CMD_RMOD, "name", "liu", KVS_STATUS_OK, NULL, "MOD NAME");
|
||||
testcase(connfd, KVS_CMD_RGET, "name", NULL, KVS_STATUS_OK, "liu", "GET NAME");
|
||||
testcase(connfd, KVS_CMD_REXIST, "name", NULL, KVS_STATUS_EXIST, NULL, "EXIST NAME");
|
||||
testcase(connfd, KVS_CMD_RDEL, "name", NULL, KVS_STATUS_OK, NULL, "DEL NAME");
|
||||
testcase(connfd, KVS_CMD_REXIST, "name", NULL, KVS_STATUS_NO_EXIST, NULL, "NOT EXIST NAME");
|
||||
testcase(connfd, KVS_CMD_RSET, "name", 4, "l\r\0n", 4, KVS_STATUS_OK, NULL, 0, "RSET NAME");
|
||||
testcase(connfd, KVS_CMD_RGET, "name", 4, NULL, 0, KVS_STATUS_OK, "l\r\0n", 4, "RGET NAME");
|
||||
testcase(connfd, KVS_CMD_RMOD, "name", 4, "liu", 3, KVS_STATUS_OK, NULL, 0, "RMOD NAME");
|
||||
testcase(connfd, KVS_CMD_RGET, "name", 4, NULL, 0, KVS_STATUS_OK, "liu", 3, "RGET NAME");
|
||||
testcase(connfd, KVS_CMD_REXIST, "name", 4, NULL, 0, KVS_STATUS_EXIST, NULL, 0, "REXIST NAME");
|
||||
testcase(connfd, KVS_CMD_RDEL, "name", 4, NULL, 0, KVS_STATUS_OK, NULL, 0, "RDEL NAME");
|
||||
testcase(connfd, KVS_CMD_REXIST, "name", 4, NULL, 0, KVS_STATUS_NO_EXIST, NULL, 0, "REXIST NAME");
|
||||
|
||||
testcase(connfd, KVS_CMD_RMOD, "stu", "liu", KVS_STATUS_NO_EXIST, NULL, "MOD NAME");
|
||||
testcase(connfd, KVS_CMD_RDEL, "stu", NULL, KVS_STATUS_NO_EXIST, NULL, "DEL SUT");
|
||||
testcase(connfd, KVS_CMD_RMOD, "stu", 3, "liu", 3, KVS_STATUS_NO_EXIST, NULL, 0, "RMOD NAME");
|
||||
testcase(connfd, KVS_CMD_RDEL, "stu", 3, NULL, 0, KVS_STATUS_NO_EXIST, NULL, 0, "RDEL SUT");
|
||||
}
|
||||
|
||||
struct timeval tv_end;
|
||||
@@ -127,23 +128,23 @@ void rbtree_testcase_1w(int connfd) {
|
||||
|
||||
void hash_testcase_1w(int connfd) {
|
||||
|
||||
int count = 1000;
|
||||
int count = 1;
|
||||
int i = 0;
|
||||
|
||||
struct timeval tv_begin;
|
||||
gettimeofday(&tv_begin, NULL);
|
||||
|
||||
for (i = 0;i < count;i ++) {
|
||||
testcase(connfd, KVS_CMD_HSET, "name", "lian", KVS_STATUS_OK, NULL, "SET NAME");
|
||||
testcase(connfd, KVS_CMD_HGET, "name", NULL, KVS_STATUS_OK, "lian", "GET NAME");
|
||||
testcase(connfd, KVS_CMD_HMOD, "name", "liu", KVS_STATUS_OK, NULL, "MOD NAME");
|
||||
testcase(connfd, KVS_CMD_HGET, "name", NULL, KVS_STATUS_OK, "liu", "GET NAME");
|
||||
testcase(connfd, KVS_CMD_HEXIST, "name", NULL, KVS_STATUS_EXIST, NULL, "EXIST NAME");
|
||||
testcase(connfd, KVS_CMD_HDEL, "name", NULL, KVS_STATUS_OK, NULL, "DEL NAME");
|
||||
testcase(connfd, KVS_CMD_HEXIST, "name", NULL, KVS_STATUS_NO_EXIST, NULL, "NOT EXIST NAME");
|
||||
testcase(connfd, KVS_CMD_HSET, "name", 4, "l\r\0n", 4, KVS_STATUS_OK, NULL, 0, "HSET NAME");
|
||||
testcase(connfd, KVS_CMD_HGET, "name", 4, NULL, 0, KVS_STATUS_OK, "l\r\0n", 4, "HGET NAME");
|
||||
testcase(connfd, KVS_CMD_HMOD, "name", 4, "liu", 3, KVS_STATUS_OK, NULL, 0, "HMOD NAME");
|
||||
testcase(connfd, KVS_CMD_HGET, "name", 4, NULL, 0, KVS_STATUS_OK, "liu", 3, "HGET NAME");
|
||||
testcase(connfd, KVS_CMD_HEXIST, "name", 4, NULL, 0, KVS_STATUS_EXIST, NULL, 0, "HEXIST NAME");
|
||||
testcase(connfd, KVS_CMD_HDEL, "name", 4, NULL, 0, KVS_STATUS_OK, NULL, 0, "HDEL NAME");
|
||||
testcase(connfd, KVS_CMD_HEXIST, "name", 4, NULL, 0, KVS_STATUS_NO_EXIST, NULL, 0, "HEXIST NAME");
|
||||
|
||||
testcase(connfd, KVS_CMD_HMOD, "stu", "liu", KVS_STATUS_NO_EXIST, NULL, "MOD NAME");
|
||||
testcase(connfd, KVS_CMD_HDEL, "stu", NULL, KVS_STATUS_NO_EXIST, NULL, "DEL SUT");
|
||||
testcase(connfd, KVS_CMD_HMOD, "stu", 3, "liu", 3, KVS_STATUS_NO_EXIST, NULL, 0, "HMOD NAME");
|
||||
testcase(connfd, KVS_CMD_HDEL, "stu", 3, NULL, 0, KVS_STATUS_NO_EXIST, NULL, 0, "HDEL SUT");
|
||||
}
|
||||
|
||||
struct timeval tv_end;
|
||||
@@ -155,18 +156,110 @@ void hash_testcase_1w(int connfd) {
|
||||
|
||||
}
|
||||
|
||||
void do_batch_SET_example(int fd)
|
||||
{
|
||||
// void do_batch_SET_example(int fd)
|
||||
// {
|
||||
// kvs_batch_t batch;
|
||||
// kvs_batch_init(&batch);
|
||||
|
||||
// char key[10]={0}, val[10]={0};
|
||||
|
||||
// // 组 batch(最多 64 条)
|
||||
// for(int i = 0;i < 48; ++ i){
|
||||
// int len = sprintf(key, "k%d", i);
|
||||
// len = sprintf(val, "v%d", i);
|
||||
// kvs_batch_add(&batch, KVS_CMD_SET, key, val);
|
||||
// }
|
||||
|
||||
// // 一次性发送
|
||||
// kvs_batch_send(fd, &batch);
|
||||
|
||||
// // 一次性 recv + parse
|
||||
// uint8_t recvbuf[BATCH_SIZE];
|
||||
// kvs_response_t rsps[KVS_BATCH_MAX];
|
||||
|
||||
// int nrsp = kvs_batch_recv_parse(fd, &batch, rsps, recvbuf, sizeof(recvbuf));
|
||||
|
||||
// // 打印/处理
|
||||
// for (int i = 0; i < nrsp; i++) {
|
||||
// int len = sprintf(key, "SET%d", i);
|
||||
// PRESP(key, &rsps[i]);
|
||||
// }
|
||||
// }
|
||||
|
||||
// void do_batch_GET_example(int fd)
|
||||
// {
|
||||
// kvs_batch_t batch;
|
||||
// kvs_batch_init(&batch);
|
||||
|
||||
// char key[10]={0}, val[10]={0};
|
||||
|
||||
// // 组 batch(最多 64 条)
|
||||
// for(int i = 0;i < 48; ++ i){
|
||||
// int len = sprintf(key, "k%d", i);
|
||||
// kvs_batch_add(&batch, KVS_CMD_GET, key, NULL);
|
||||
// }
|
||||
|
||||
// // 一次性发送
|
||||
// kvs_batch_send(fd, &batch);
|
||||
|
||||
// // 一次性 recv + parse
|
||||
// uint8_t recvbuf[BATCH_SIZE];
|
||||
// kvs_response_t rsps[KVS_BATCH_MAX];
|
||||
|
||||
// int nrsp = kvs_batch_recv_parse(fd, &batch, rsps, recvbuf, sizeof(recvbuf));
|
||||
|
||||
// // 打印/处理
|
||||
// for (int i = 0; i < nrsp; i++) {
|
||||
// int len = sprintf(key, "GET%d", i);
|
||||
// PRESP(key, &rsps[i]);
|
||||
// }
|
||||
// }
|
||||
|
||||
// void do_batch_DEL_example(int fd)
|
||||
// {
|
||||
// kvs_batch_t batch;
|
||||
// kvs_batch_init(&batch);
|
||||
|
||||
// char key[10]={0}, val[10]={0};
|
||||
|
||||
// // 组 batch(最多 64 条)
|
||||
// for(int i = 0;i < 48; ++ i){
|
||||
// int len = sprintf(key, "k%d", i);
|
||||
// kvs_batch_add(&batch, KVS_CMD_DEL, key, NULL);
|
||||
// }
|
||||
|
||||
// // 一次性发送
|
||||
// kvs_batch_send(fd, &batch);
|
||||
|
||||
// // 一次性 recv + parse
|
||||
// uint8_t recvbuf[BATCH_SIZE];
|
||||
// kvs_response_t rsps[KVS_BATCH_MAX];
|
||||
|
||||
// int nrsp = kvs_batch_recv_parse(fd, &batch, rsps, recvbuf, sizeof(recvbuf));
|
||||
|
||||
// // 打印/处理
|
||||
// for (int i = 0; i < nrsp; i++) {
|
||||
// int len = sprintf(key, "DEL%d", i);
|
||||
// PRESP(key, &rsps[i]);
|
||||
// }
|
||||
// }
|
||||
|
||||
void do_batch_test(int fd, int op, const char *key, const char *value){
|
||||
kvs_batch_t batch;
|
||||
kvs_batch_init(&batch);
|
||||
|
||||
char key[10]={0}, val[10]={0};
|
||||
char bkey[15]={0}, bval[15]={0};
|
||||
|
||||
// 组 batch(最多 64 条)
|
||||
for(int i = 0;i < 48; ++ i){
|
||||
int len = sprintf(key, "k%d", i);
|
||||
len = sprintf(val, "v%d", i);
|
||||
kvs_batch_add(&batch, KVS_CMD_SET, key, val);
|
||||
if(value == NULL){
|
||||
int klen = sprintf(bkey, "%s%d", key, i);
|
||||
kvs_batch_add(&batch, op, bkey, klen, NULL, 0);
|
||||
}else{
|
||||
int klen = sprintf(bkey, "%s%d", key, i);
|
||||
int vlen = sprintf(bval, "%s%d", value, i);
|
||||
kvs_batch_add(&batch, op, bkey, klen, bval, vlen);
|
||||
}
|
||||
}
|
||||
|
||||
// 一次性发送
|
||||
@@ -180,71 +273,13 @@ void do_batch_SET_example(int fd)
|
||||
|
||||
// 打印/处理
|
||||
for (int i = 0; i < nrsp; i++) {
|
||||
int len = sprintf(key, "SET%d", i);
|
||||
PRESP(key, &rsps[i]);
|
||||
}
|
||||
}
|
||||
|
||||
void do_batch_GET_example(int fd)
|
||||
{
|
||||
kvs_batch_t batch;
|
||||
kvs_batch_init(&batch);
|
||||
|
||||
char key[10]={0}, val[10]={0};
|
||||
|
||||
// 组 batch(最多 64 条)
|
||||
for(int i = 0;i < 48; ++ i){
|
||||
int len = sprintf(key, "k%d", i);
|
||||
kvs_batch_add(&batch, KVS_CMD_GET, key, NULL);
|
||||
}
|
||||
|
||||
// 一次性发送
|
||||
kvs_batch_send(fd, &batch);
|
||||
|
||||
// 一次性 recv + parse
|
||||
uint8_t recvbuf[BATCH_SIZE];
|
||||
kvs_response_t rsps[KVS_BATCH_MAX];
|
||||
|
||||
int nrsp = kvs_batch_recv_parse(fd, &batch, rsps, recvbuf, sizeof(recvbuf));
|
||||
|
||||
// 打印/处理
|
||||
for (int i = 0; i < nrsp; i++) {
|
||||
int len = sprintf(key, "GET%d", i);
|
||||
PRESP(key, &rsps[i]);
|
||||
}
|
||||
}
|
||||
|
||||
void do_batch_DEL_example(int fd)
|
||||
{
|
||||
kvs_batch_t batch;
|
||||
kvs_batch_init(&batch);
|
||||
|
||||
char key[10]={0}, val[10]={0};
|
||||
|
||||
// 组 batch(最多 64 条)
|
||||
for(int i = 0;i < 48; ++ i){
|
||||
int len = sprintf(key, "k%d", i);
|
||||
kvs_batch_add(&batch, KVS_CMD_DEL, key, NULL);
|
||||
}
|
||||
|
||||
// 一次性发送
|
||||
kvs_batch_send(fd, &batch);
|
||||
|
||||
// 一次性 recv + parse
|
||||
uint8_t recvbuf[BATCH_SIZE];
|
||||
kvs_response_t rsps[KVS_BATCH_MAX];
|
||||
|
||||
int nrsp = kvs_batch_recv_parse(fd, &batch, rsps, recvbuf, sizeof(recvbuf));
|
||||
|
||||
// 打印/处理
|
||||
for (int i = 0; i < nrsp; i++) {
|
||||
int len = sprintf(key, "DEL%d", i);
|
||||
PRESP(key, &rsps[i]);
|
||||
int len = sprintf(bkey, "PRT%d", i);
|
||||
PRESP(bkey, &rsps[i]);
|
||||
}
|
||||
}
|
||||
|
||||
void save(int connfd){
|
||||
testcase(connfd, KVS_CMD_SAVE, NULL, NULL, KVS_STATUS_OK, NULL, "SAVE");
|
||||
testcase(connfd, KVS_CMD_SAVE, NULL, 0, NULL, 0, KVS_STATUS_OK, NULL, 0, "SAVE");
|
||||
}
|
||||
|
||||
|
||||
@@ -261,17 +296,29 @@ int main(int argc, char *argv[]) {
|
||||
int connfd = connect_tcpserver(ip, port);
|
||||
|
||||
if(mode == 0){
|
||||
do_batch_SET_example(connfd);
|
||||
}else if(mode == 1){
|
||||
do_batch_GET_example(connfd);
|
||||
}else if(mode == 2){
|
||||
do_batch_DEL_example(connfd);
|
||||
}else if(mode == 10){
|
||||
array_testcase_1w(connfd);
|
||||
}else if(mode == 11){
|
||||
}else if(mode == 1){
|
||||
rbtree_testcase_1w(connfd);
|
||||
}else if(mode == 12){
|
||||
}else if(mode == 2){
|
||||
hash_testcase_1w(connfd);
|
||||
}else if(mode == 10){
|
||||
do_batch_test(connfd, KVS_CMD_SET, "array_set", "array_val");
|
||||
}else if(mode == 11){
|
||||
do_batch_test(connfd, KVS_CMD_GET, "array_set", NULL);
|
||||
}else if(mode == 12){
|
||||
do_batch_test(connfd, KVS_CMD_EXIST, "array_set", NULL);
|
||||
}else if(mode == 20){
|
||||
do_batch_test(connfd, KVS_CMD_RSET, "rbtree_set", "rbtree_val");
|
||||
}else if(mode == 21){
|
||||
do_batch_test(connfd, KVS_CMD_RGET, "rbtree_set", NULL);
|
||||
}else if(mode == 22){
|
||||
do_batch_test(connfd, KVS_CMD_REXIST, "rbtree_set", NULL);
|
||||
}else if(mode == 30){
|
||||
do_batch_test(connfd, KVS_CMD_HSET, "hash_set", "hash_val");
|
||||
}else if(mode == 31){
|
||||
do_batch_test(connfd, KVS_CMD_HGET, "hash_set", NULL);
|
||||
}else if(mode == 32){
|
||||
do_batch_test(connfd, KVS_CMD_HEXIST, "hash_set", NULL);
|
||||
}else if(mode == -1){
|
||||
save(connfd);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user