diff options
Diffstat (limited to 'tests')
-rw-r--r-- | tests/.gitignore | 4 | ||||
-rw-r--r-- | tests/list_check.c | 129 |
2 files changed, 133 insertions, 0 deletions
diff --git a/tests/.gitignore b/tests/.gitignore new file mode 100644 index 00000000..3c726461 --- /dev/null +++ b/tests/.gitignore @@ -0,0 +1,4 @@ +*.o +.deps +list_check +.dirstamp diff --git a/tests/list_check.c b/tests/list_check.c new file mode 100644 index 00000000..be427af0 --- /dev/null +++ b/tests/list_check.c @@ -0,0 +1,129 @@ +/* + * list_check.c + * + * Unit test for the reflection list module + * + * (c) 2011 Thomas White <taw@physics.org> + * + * Part of CrystFEL - crystallography with a FEL + * + */ + + +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif + + +#include <stdlib.h> +#include <stdio.h> + +#include "../src/reflist.h" + + +struct refltemp { + signed int h; + signed int k; + signed int l; + int del; + int dup; +}; + +#define RANDOM_INDEX (128*random()/RAND_MAX - 256*random()/RAND_MAX) + + +static int test_lists(int num_items) +{ + struct refltemp *check; + RefList *list; + int i; + + check = malloc(num_items * sizeof(struct refltemp)); + list = reflist_new(); + + for ( i=0; i<num_items; i++ ) { + + signed int h, k, l; + int j; + int duplicate = 0; + + h = RANDOM_INDEX; + k = RANDOM_INDEX; + l = RANDOM_INDEX; + + for ( j=0; j<i; j++ ) { + if ( (check[j].h == h) + && (check[j].k == k) + && (check[j].l == l) ) { + duplicate++; + } + } + + add_refl(list, h, k, l); + check[i].h = h; + check[i].k = k; + check[i].l = l; + check[i].del = 0; + check[i].dup = duplicate; + + } + + for ( i=0; i<num_items; i++ ) { + + signed int h, k, l; + Reflection *refl; + + h = check[i].h; + k = check[i].k; + l = check[i].l; + + refl = find_refl(list, h, k, l); + if ( refl == NULL ) { + fprintf(stderr, "Couldn't find %3i %3i %3i\n", h, k, l); + return 1; + } + + if ( i<num_items/2 ) { + delete_refl(refl); + check[i].del = 1; + } + + } + + for ( i=0; i<num_items/2; i++ ) { + + signed int h, k, l; + Reflection *refl; + + h = check[i].h; + k = check[i].k; + l = check[i].l; + + refl = find_refl(list, h, k, l); + if ( refl == NULL ) { + fprintf(stderr, "Couldn't find %3i %3i %3i\n", h, k, l); + return 1; + } + + if ( i<num_items/2 ) { + delete_refl(refl); + check[i].del = 1; + } + + } + + free(check); + + return 0; +} + +int main(int argc, char *argv[]) +{ + int i; + + for ( i=0; i<100; i++ ) { + if ( test_lists(random()) ) return 1; + } + + return 0; +} |