mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 14:54:20 +01:00
324c278a31
git-svn-id: file:///svn/toku/tokudb@16673 c7de825b-a66e-492c-adef-691d508d4ae1
163 lines
4.1 KiB
C
163 lines
4.1 KiB
C
#include "toku_list.h"
|
|
|
|
|
|
#include "test.h"
|
|
#include <memory.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
struct testlist {
|
|
struct toku_list next;
|
|
int tag;
|
|
};
|
|
|
|
static void testlist_init (struct testlist *tl, int tag) {
|
|
tl->tag = tag;
|
|
}
|
|
|
|
static void test_push_pop (int n) {
|
|
int i;
|
|
struct toku_list head;
|
|
|
|
toku_list_init(&head);
|
|
for (i=0; i<n; i++) {
|
|
struct testlist *tl = (struct testlist *) toku_malloc(sizeof *tl);
|
|
assert(tl);
|
|
testlist_init(tl, i);
|
|
toku_list_push(&head, &tl->next);
|
|
assert(!toku_list_empty(&head));
|
|
}
|
|
for (i=n-1; i>=0; i--) {
|
|
struct toku_list *list;
|
|
struct testlist *tl;
|
|
|
|
list = toku_list_head(&head);
|
|
tl = toku_list_struct(list, struct testlist, next);
|
|
assert(tl->tag == 0);
|
|
list = toku_list_tail(&head);
|
|
tl = toku_list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
list = toku_list_pop(&head);
|
|
tl = toku_list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
toku_free(tl);
|
|
}
|
|
assert(toku_list_empty(&head));
|
|
}
|
|
|
|
static void test_push_pop_head (int n) {
|
|
int i;
|
|
struct toku_list head;
|
|
|
|
toku_list_init(&head);
|
|
for (i=0; i<n; i++) {
|
|
struct testlist *tl = (struct testlist *) toku_malloc(sizeof *tl);
|
|
assert(tl);
|
|
testlist_init(tl, i);
|
|
toku_list_push(&head, &tl->next);
|
|
assert(!toku_list_empty(&head));
|
|
}
|
|
for (i=0; i<n; i++) {
|
|
struct toku_list *list;
|
|
struct testlist *tl;
|
|
|
|
list = toku_list_head(&head);
|
|
tl = toku_list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
list = toku_list_tail(&head);
|
|
tl = toku_list_struct(list, struct testlist, next);
|
|
assert(tl->tag == n-1);
|
|
|
|
list = toku_list_pop_head(&head);
|
|
tl = toku_list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
toku_free(tl);
|
|
}
|
|
assert(toku_list_empty(&head));
|
|
}
|
|
|
|
static void test_push_head_pop (int n) {
|
|
int i;
|
|
struct toku_list head;
|
|
|
|
toku_list_init(&head);
|
|
for (i=0; i<n; i++) {
|
|
struct testlist *tl = (struct testlist *) toku_malloc(sizeof *tl);
|
|
assert(tl);
|
|
testlist_init(tl, i);
|
|
toku_list_push_head(&head, &tl->next);
|
|
assert(!toku_list_empty(&head));
|
|
}
|
|
for (i=0; i<n; i++) {
|
|
struct toku_list *list;
|
|
struct testlist *tl;
|
|
|
|
list = toku_list_head(&head);
|
|
tl = toku_list_struct(list, struct testlist, next);
|
|
assert(tl->tag == n-1);
|
|
list = toku_list_tail(&head);
|
|
tl = toku_list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
|
|
list = toku_list_pop(&head);
|
|
tl = toku_list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
toku_free(tl);
|
|
}
|
|
assert(toku_list_empty(&head));
|
|
}
|
|
|
|
#if 0
|
|
// cant move an empty list
|
|
static void test_move_empty (void) {
|
|
struct toku_list h1, h2;
|
|
|
|
toku_list_init(&h1);
|
|
toku_list_init(&h2);
|
|
toku_list_move(&h1, &h2);
|
|
assert(toku_list_empty(&h2));
|
|
assert(toku_list_empty(&h1));
|
|
}
|
|
#endif
|
|
|
|
static void test_move (int n) {
|
|
struct toku_list h1, h2;
|
|
int i;
|
|
|
|
toku_list_init(&h1);
|
|
toku_list_init(&h2);
|
|
for (i=0; i<n; i++) {
|
|
struct testlist *tl = (struct testlist *) toku_malloc(sizeof *tl);
|
|
assert(tl);
|
|
testlist_init(tl, i);
|
|
toku_list_push(&h2, &tl->next);
|
|
}
|
|
toku_list_move(&h1, &h2);
|
|
assert(!toku_list_empty(&h1));
|
|
assert(toku_list_empty(&h2));
|
|
i = 0;
|
|
while (!toku_list_empty(&h1)) {
|
|
struct toku_list *list = toku_list_pop_head(&h1);
|
|
struct testlist *tl = toku_list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
toku_free(tl);
|
|
i += 1;
|
|
}
|
|
assert(i == n);
|
|
}
|
|
|
|
int
|
|
test_main(int argc, const char *argv[]) {
|
|
default_parse_args(argc, argv);
|
|
test_push_pop(0);
|
|
test_push_pop(8);
|
|
test_push_pop_head(0);
|
|
test_push_pop_head(8);
|
|
test_push_head_pop(8);
|
|
test_move(1);
|
|
test_move(8);
|
|
// test_move_empty();
|
|
|
|
return 0;
|
|
}
|
|
|