-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfuzz.c
60 lines (54 loc) · 1.46 KB
/
fuzz.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include "rb-tree.h"
int verify_tree(rb_tree *node) {
if (node == NULL)
return 1;
if (node->color == rb_RED) {
if (node->left && node->left->color == rb_RED)
return 0;
if (node->right && node->right->color == rb_RED)
return 0;
}
int l_black_height = verify_tree(node->left);
if (l_black_height == 0)
return l_black_height;
int r_black_height = verify_tree(node->right);
if (r_black_height == 0)
return r_black_height;
if (l_black_height != r_black_height)
return 0;
return l_black_height + (node->color == rb_BLACK);
}
int valid_rb_tree(rb_tree *root) {
if (root && root->color != rb_BLACK)
return 0;
return verify_tree(root) != 0;
}
int main(int argc, char *argv[]) {
srand(time(NULL));
int ops = 10000, insertions = 0, deletions = 0;
if (argc == 2)
sscanf(argv[1], "%d", &ops);
printf("Running fuzz test with %d operations.\n", ops);
rb_tree *tree = NULL;
for (int i = 0; i < ops; i++) {
int n = rand() >> 16;
if (n & 1) {
rb_insert(&tree, n >> 1);
++insertions;
} else {
rb_delete(&tree, n >> 1);
++deletions;
}
if (!valid_rb_tree(tree)) {
printf("[failed] Invalid tree!");
rb_print(tree);
return 1;
}
}
printf("[passed] RB-tree valid after %d operations!\n", ops);
printf(" size=%d, insertions=%d, deletions=%d\n", rb_size(tree), insertions, deletions);
rb_free(&tree);
}