r3/tests/test_tree.c
2014-05-15 21:17:30 +08:00

222 lines
5.2 KiB
C

#include <stdio.h>
#include <check.h>
#include "str.h"
#include "node.h"
#include "token.h"
START_TEST (test_ltrim_slash)
{
fail_if( strcmp( ltrim_slash("/blog") , "blog" ) != 0 );
fail_if( strcmp( ltrim_slash("blog") , "blog" ) != 0 );
}
END_TEST
START_TEST (test_rnode_construct_uniq)
{
rnode * n = rnode_create(10);
rnode * child = rnode_create(3);
fail_if( rnode_add_child(n, strdup("/add") , child) == FALSE );
fail_if( rnode_add_child(n, strdup("/add") , child) != FALSE );
rnode_free(n);
}
END_TEST
START_TEST (test_rnode_find_edge)
{
rnode * n = rnode_create(10);
rnode * child = rnode_create(3);
fail_if( rnode_add_child(n, strdup("/add") , child) == FALSE );
fail_if( rnode_find_edge(n, "/add") == NULL );
fail_if( rnode_find_edge(n, "/bar") != NULL );
rnode_free(n);
}
END_TEST
START_TEST (test_combine_patterns)
{
token_array *t;
rnode * n;
n = rnode_create(10);
t = split_route_pattern("/foo", strlen("/foo") );
fail_if( rnode_insert_tokens(n , t) == NULL );
t = split_route_pattern("/bar", strlen("/bar") );
fail_if( rnode_insert_tokens(n , t) == NULL );
t = split_route_pattern("/zoo", strlen("/zoo") );
fail_if( rnode_insert_tokens(n , t) == NULL );
rnode_combine_patterns(n);
// printf("%s\n", n->combined_pattern);
}
END_TEST
START_TEST (test_slug_to_pcre)
{
char * pattern;
pattern = slug_to_pcre("{id}", '/');
fail_if( strcmp(pattern, "[^/]+") != 0 , "as [^/]+" );
free(pattern);
pattern = slug_to_pcre("{id:[a-z]+}", '/');
fail_if( strcmp(pattern, "[a-z]+") != 0 , "as [a-z]+" );
free(pattern);
/*
char * p = malloc(sizeof(char) * 10);
strncat(p, "foo", 3);
free(p);
*/
}
END_TEST
START_TEST (test_rnode_insert_tokens)
{
token_array *t;
rnode * n = rnode_create(10);
fail_if(n == NULL, "rnode tree");
t = split_route_pattern("/foo/bar", strlen("/foo/bar") );
fail_if( rnode_insert_tokens(n , t) == NULL );
t = split_route_pattern("/foo/zoo", strlen("/foo/zoo") );
fail_if( rnode_insert_tokens(n , t) == NULL );
t = split_route_pattern("/a/bb", strlen("/a/bb") );
fail_if( rnode_insert_tokens(n , t) == NULL );
t = split_route_pattern("/a/bb/cc", strlen("/a/bb/cc") );
fail_if( rnode_insert_tokens(n , t) == NULL );
t = split_route_pattern("/a/jj/kk", strlen("/a/jj/kk") );
fail_if( rnode_insert_tokens(n , t) == NULL );
rnode_dump(n, 0);
fail_if( rnode_lookup(n , "/a/jj/kk" , strlen("/a/jj/kk") ) == NULL );
fail_if( rnode_lookup(n , "/a/jj" , strlen("/a/jj") ) != NULL );
fail_if( rnode_lookup(n , "/a/jj/kk/ll" , strlen("/a/jj/kk/ll") ) != NULL );
fail_if( rnode_lookup(n, "/xxxx", strlen("xxxx") ) != NULL );
// fail_if( rnode_find_edge(n, "/add") == NULL );
// fail_if( rnode_find_edge(n, "/bar") != NULL );
rnode_free(n);
}
END_TEST
START_TEST (test_route_split)
{
token_array *t;
t = split_route_pattern("/blog", strlen("/blog") );
fail_if( t == NULL );
token_array_dump(t);
token_array_free(t);
t = split_route_pattern("/foo/{id}", strlen("/foo/{id}") );
fail_if( t == NULL );
token_array_dump(t);
fail_if( t->len != 2 );
token_array_free(t);
t = split_route_pattern("/foo/bar/{id}", strlen("/foo/bar/{id}") );
fail_if( t == NULL );
token_array_dump(t);
fail_if( t->len != 3 );
token_array_free(t);
t = split_route_pattern("/{title}", strlen("/{title}") );
fail_if( t == NULL );
token_array_dump(t);
fail_if( t->len != 1 );
token_array_free(t);
t = split_route_pattern("/", strlen("/") );
fail_if( t == NULL );
token_array_dump(t);
fail_if( t->len != 1 );
token_array_free(t);
}
END_TEST
START_TEST (test_token_array)
{
token_array * l = token_array_create(3);
fail_if( l == NULL );
fail_if( FALSE == token_array_append(l, strdup("abc") ) );
fail_if( l->len != 1 );
fail_if( FALSE == token_array_append(l, strdup("foo") ) );
fail_if( l->len != 2 );
fail_if( FALSE == token_array_append(l, strdup("bar") ) );
fail_if( l->len != 3 );
fail_if( FALSE == token_array_append(l, strdup("zoo") ) );
fail_if( l->len != 4 );
fail_if( FALSE == token_array_resize(l, l->cap * 2) );
token_array_free(l);
}
END_TEST
Suite* r3_suite (void) {
Suite *suite = suite_create("blah");
TCase *tcase = tcase_create("testcase");
tcase_add_test(tcase, test_route_split);
tcase_add_test(tcase, test_token_array);
tcase_add_test(tcase, test_ltrim_slash);
tcase_add_test(tcase, test_rnode_construct_uniq);
tcase_add_test(tcase, test_rnode_find_edge);
tcase_add_test(tcase, test_rnode_insert_tokens);
tcase_add_test(tcase, test_slug_to_pcre);
tcase_add_test(tcase, test_combine_patterns);
suite_add_tcase(suite, tcase);
return suite;
}
int main (int argc, char *argv[]) {
int number_failed;
Suite *suite = r3_suite();
SRunner *runner = srunner_create(suite);
srunner_run_all(runner, CK_NORMAL);
number_failed = srunner_ntests_failed(runner);
srunner_free(runner);
return number_failed;
}