|
1 /* |
|
2 * tests of list implementation |
|
3 */ |
|
4 |
|
5 #include <stdio.h> |
|
6 #include <stdlib.h> |
|
7 |
|
8 #include "ucx/list.h" |
|
9 #include "ucx/dlist.h" |
|
10 |
|
11 struct test1_data { |
|
12 int values[3]; |
|
13 int i; |
|
14 }; |
|
15 |
|
16 int list_tests_foreach1(void *v, void *custom) { |
|
17 UcxDlist *dl = (UcxDlist*)v; |
|
18 struct test1_data *tdata = (struct test1_data*)custom; |
|
19 |
|
20 tdata->values[tdata->i] = *(int*)dl->data; |
|
21 tdata->i++; |
|
22 } |
|
23 |
|
24 int list_tests() { |
|
25 int r = 0; |
|
26 int v[8]; |
|
27 UcxDlist *dl = NULL; |
|
28 // build list 0,1,2,3,4,5,6,7 |
|
29 for(int i=0;i<8;i++) { |
|
30 v[i] = i; |
|
31 dl = ucx_dlist_append(dl, &v[i]); |
|
32 } |
|
33 |
|
34 for(int i=0;i<8;i++) { |
|
35 UcxDlist *elm = ucx_dlist_get(dl, i); |
|
36 if(elm == NULL) { |
|
37 fprintf(stderr, "ucx_dlist_get failed: element is NULL\n"); |
|
38 } |
|
39 if(elm->data == NULL) { |
|
40 fprintf(stderr, "ucx_dlist_get failed: data is NULL\n"); |
|
41 } |
|
42 int *data = (int*)elm->data; |
|
43 if(*data != i) { |
|
44 fprintf(stderr, "ucx_dlist_get failed with index %d\n", i); |
|
45 } |
|
46 } |
|
47 |
|
48 //TODO: ucx_dlist_free test |
|
49 |
|
50 dl = NULL; |
|
51 // build list 4,0,4 |
|
52 dl = ucx_dlist_prepend(dl, &v[0]); |
|
53 dl = ucx_dlist_prepend(dl, &v[5]); |
|
54 dl = ucx_dlist_append(dl, &v[5]); |
|
55 |
|
56 struct test1_data tdata; |
|
57 tdata.i = 0; |
|
58 ucx_dlist_foreach(dl, list_tests_foreach1, &tdata); |
|
59 |
|
60 if(tdata.values[0] != 4 || tdata.values[1] != 0 || tdata.values[2] != 4) { |
|
61 fprintf(stderr, "prepend/append test failed\n"); |
|
62 } |
|
63 |
|
64 return r; |
|
65 } |