mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 14:54:20 +01:00
a9c69fd3fe
Original message: Create a branch to make Doug Lea's malloc work. The big problem is having another malloc() in the system breaks things. Address #1343, #1032.
163 lines
3.8 KiB
C
163 lines
3.8 KiB
C
#include "list.h"
|
|
#include "toku_assert.h"
|
|
|
|
#include "test.h"
|
|
#include <memory.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
struct testlist {
|
|
struct 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 list head;
|
|
|
|
list_init(&head);
|
|
for (i=0; i<n; i++) {
|
|
struct testlist *tl = (struct testlist *) toku_malloc(sizeof *tl);
|
|
assert(tl);
|
|
testlist_init(tl, i);
|
|
list_push(&head, &tl->next);
|
|
assert(!list_empty(&head));
|
|
}
|
|
for (i=n-1; i>=0; i--) {
|
|
struct list *list;
|
|
struct testlist *tl;
|
|
|
|
list = list_head(&head);
|
|
tl = list_struct(list, struct testlist, next);
|
|
assert(tl->tag == 0);
|
|
list = list_tail(&head);
|
|
tl = list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
list = list_pop(&head);
|
|
tl = list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
toku_free(tl);
|
|
}
|
|
assert(list_empty(&head));
|
|
}
|
|
|
|
static void test_push_pop_head (int n) {
|
|
int i;
|
|
struct list head;
|
|
|
|
list_init(&head);
|
|
for (i=0; i<n; i++) {
|
|
struct testlist *tl = (struct testlist *) toku_malloc(sizeof *tl);
|
|
assert(tl);
|
|
testlist_init(tl, i);
|
|
list_push(&head, &tl->next);
|
|
assert(!list_empty(&head));
|
|
}
|
|
for (i=0; i<n; i++) {
|
|
struct list *list;
|
|
struct testlist *tl;
|
|
|
|
list = list_head(&head);
|
|
tl = list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
list = list_tail(&head);
|
|
tl = list_struct(list, struct testlist, next);
|
|
assert(tl->tag == n-1);
|
|
|
|
list = list_pop_head(&head);
|
|
tl = list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
toku_free(tl);
|
|
}
|
|
assert(list_empty(&head));
|
|
}
|
|
|
|
static void test_push_head_pop (int n) {
|
|
int i;
|
|
struct list head;
|
|
|
|
list_init(&head);
|
|
for (i=0; i<n; i++) {
|
|
struct testlist *tl = (struct testlist *) toku_malloc(sizeof *tl);
|
|
assert(tl);
|
|
testlist_init(tl, i);
|
|
list_push_head(&head, &tl->next);
|
|
assert(!list_empty(&head));
|
|
}
|
|
for (i=0; i<n; i++) {
|
|
struct list *list;
|
|
struct testlist *tl;
|
|
|
|
list = list_head(&head);
|
|
tl = list_struct(list, struct testlist, next);
|
|
assert(tl->tag == n-1);
|
|
list = list_tail(&head);
|
|
tl = list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
|
|
list = list_pop(&head);
|
|
tl = list_struct(list, struct testlist, next);
|
|
assert(tl->tag == i);
|
|
toku_free(tl);
|
|
}
|
|
assert(list_empty(&head));
|
|
}
|
|
|
|
#if 0
|
|
// cant move an empty list
|
|
static void test_move_empty (void) {
|
|
struct list h1, h2;
|
|
|
|
list_init(&h1);
|
|
list_init(&h2);
|
|
list_move(&h1, &h2);
|
|
assert(list_empty(&h2));
|
|
assert(list_empty(&h1));
|
|
}
|
|
#endif
|
|
|
|
static void test_move (int n) {
|
|
struct list h1, h2;
|
|
int i;
|
|
|
|
list_init(&h1);
|
|
list_init(&h2);
|
|
for (i=0; i<n; i++) {
|
|
struct testlist *tl = (struct testlist *) toku_malloc(sizeof *tl);
|
|
assert(tl);
|
|
testlist_init(tl, i);
|
|
list_push(&h2, &tl->next);
|
|
}
|
|
list_move(&h1, &h2);
|
|
assert(!list_empty(&h1));
|
|
assert(list_empty(&h2));
|
|
i = 0;
|
|
while (!list_empty(&h1)) {
|
|
struct list *list = list_pop_head(&h1);
|
|
struct testlist *tl = 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;
|
|
}
|
|
|