r3/tests/check_tree.c

806 lines
20 KiB
C
Raw Permalink Normal View History

2014-05-16 19:14:09 -04:00
#include "config.h"
2014-05-14 12:15:19 -04:00
#include <stdio.h>
#include <check.h>
2014-05-16 06:03:52 -04:00
#include <stdlib.h>
2014-05-31 14:28:58 -04:00
#include <assert.h>
2014-05-16 08:22:25 -04:00
#include "r3.h"
2014-05-16 18:40:08 -04:00
#include "r3_str.h"
2014-05-21 02:59:07 -04:00
#include "zmalloc.h"
2014-05-16 19:48:22 -04:00
#include "bench.h"
2014-05-14 12:15:19 -04:00
2014-06-02 04:12:27 -04:00
#define SAFE_FREE(ptr) if(ptr) free(ptr);
2014-06-01 21:48:00 -04:00
#define STR(str) str, sizeof(str)-1
START_TEST (test_find_common_prefix)
{
node * n = r3_tree_create(10);
2014-06-01 21:48:00 -04:00
edge * e = r3_edge_createl(zstrdup("/foo/{slug}"), sizeof("/foo/{slug}")-1, NULL);
r3_node_append_edge(n,e);
2014-06-02 04:15:44 -04:00
char *errstr = NULL;
int prefix_len = 0;
edge *ret_edge = NULL;
2014-06-02 04:12:27 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "/foo", sizeof("/foo")-1, &prefix_len, &errstr);
ck_assert(ret_edge != NULL);
ck_assert_int_eq(prefix_len, 4);
2014-06-02 04:12:27 -04:00
SAFE_FREE(errstr);
2014-06-02 04:12:27 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "/foo/", sizeof("/foo/")-1, &prefix_len, &errstr);
ck_assert(ret_edge != NULL);
ck_assert_int_eq(prefix_len, 5);
2014-06-02 04:12:27 -04:00
SAFE_FREE(errstr);
2014-06-02 04:12:27 -04:00
errstr = NULL;
prefix_len = 0;
2014-06-02 04:12:27 -04:00
ret_edge = r3_node_find_common_prefix(n, "/foo/{slog}", sizeof("/foo/{slog}")-1, &prefix_len, &errstr);
ck_assert(ret_edge != NULL);
ck_assert_int_eq(prefix_len, 5);
2014-06-02 04:12:27 -04:00
SAFE_FREE(errstr);
2014-06-02 04:12:27 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "/foo/{bar}", sizeof("/foo/{bar}")-1, &prefix_len, &errstr);
ck_assert(ret_edge != NULL);
ck_assert_int_eq(prefix_len, 5);
2014-06-02 04:12:27 -04:00
SAFE_FREE(errstr);
2014-06-02 04:12:27 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "/foo/bar", sizeof("/foo/bar")-1, &prefix_len, &errstr);
ck_assert(ret_edge != NULL);
ck_assert_int_eq(prefix_len, 5);
2014-06-02 04:12:27 -04:00
SAFE_FREE(errstr);
2014-06-02 04:12:27 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "/bar/", sizeof("/bar/")-1, &prefix_len, &errstr);
ck_assert(ret_edge != NULL);
ck_assert_int_eq(prefix_len, 1);
2014-06-02 04:12:27 -04:00
SAFE_FREE(errstr);
2014-06-02 04:12:27 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "{bar}", sizeof("{bar}")-1, &prefix_len, &errstr);
2014-06-03 06:23:28 -04:00
ck_assert(ret_edge == NULL);
ck_assert_int_eq(prefix_len, 0);
2014-06-02 04:12:27 -04:00
SAFE_FREE(errstr);
2014-06-01 21:48:00 -04:00
r3_tree_free(n);
}
END_TEST
2014-06-01 21:48:00 -04:00
START_TEST (test_find_common_prefix_after)
{
node * n = r3_tree_create(10);
edge * e = r3_edge_createl(zstrdup("{slug}/foo"), sizeof("{slug}/foo")-1, NULL);
r3_node_append_edge(n,e);
2014-06-02 04:15:44 -04:00
int prefix_len = 0;
2014-06-01 21:48:00 -04:00
edge *ret_edge = NULL;
2014-06-02 04:15:44 -04:00
char *errstr = NULL;
2014-06-01 21:48:00 -04:00
2014-06-02 04:15:44 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "/foo", sizeof("/foo")-1, &prefix_len, &errstr);
2014-06-01 21:48:00 -04:00
ck_assert(ret_edge == NULL);
ck_assert_int_eq(prefix_len, 0);
2014-06-02 04:15:44 -04:00
SAFE_FREE(errstr);
2014-06-01 21:48:00 -04:00
2014-06-02 04:15:44 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "{slug}/bar", sizeof("{slug}/bar")-1, &prefix_len, &errstr);
2014-06-02 14:13:52 -04:00
ck_assert(ret_edge != NULL);
2014-06-01 21:48:00 -04:00
ck_assert_int_eq(prefix_len, 7);
2014-06-02 04:15:44 -04:00
SAFE_FREE(errstr);
2014-06-01 21:48:00 -04:00
2014-06-02 04:15:44 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "{slug}/foo", sizeof("{slug}/foo")-1, &prefix_len, &errstr);
2014-06-02 14:13:52 -04:00
ck_assert(ret_edge != NULL);
2014-06-01 21:48:00 -04:00
ck_assert_int_eq(prefix_len, 10);
2014-06-02 04:15:44 -04:00
SAFE_FREE(errstr);
2014-06-01 21:48:00 -04:00
r3_tree_free(n);
}
END_TEST
START_TEST (test_find_common_prefix_double_middle)
{
node * n = r3_tree_create(10);
edge * e = r3_edge_createl(zstrdup("{slug}/foo/{name}"), sizeof("{slug}/foo/{name}")-1, NULL);
r3_node_append_edge(n,e);
int prefix_len;
edge *ret_edge = NULL;
2014-06-02 04:15:44 -04:00
char *errstr;
2014-06-01 21:48:00 -04:00
2014-06-02 04:15:44 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "{slug}/foo/{number}", sizeof("{slug}/foo/{number}")-1, &prefix_len, &errstr);
2014-06-01 21:48:00 -04:00
ck_assert(ret_edge);
ck_assert_int_eq(prefix_len, 11);
2014-06-02 04:15:44 -04:00
SAFE_FREE(errstr);
2014-06-01 21:48:00 -04:00
r3_tree_free(n);
}
END_TEST
START_TEST (test_find_common_prefix_middle)
{
node * n = r3_tree_create(10);
edge * e = r3_edge_createl(zstrdup("/foo/{slug}/hate"), sizeof("/foo/{slug}/hate")-1, NULL);
r3_node_append_edge(n,e);
int prefix_len;
edge *ret_edge = NULL;
2014-06-02 04:15:44 -04:00
char *errstr = NULL;
2014-06-01 21:48:00 -04:00
2014-06-02 04:15:44 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "/foo/{slug}/bar", sizeof("/foo/{slug}/bar")-1, &prefix_len, &errstr);
2014-06-01 21:48:00 -04:00
ck_assert(ret_edge);
ck_assert_int_eq(prefix_len, 12);
2014-06-02 04:15:44 -04:00
SAFE_FREE(errstr);
2014-06-01 21:48:00 -04:00
2014-06-02 04:15:44 -04:00
errstr = NULL;
ret_edge = r3_node_find_common_prefix(n, "/fo/{slug}/bar", sizeof("/fo/{slug}/bar")-1, &prefix_len, &errstr);
2014-06-01 21:48:00 -04:00
ck_assert(ret_edge);
ck_assert_int_eq(prefix_len, 3);
2014-06-02 04:15:44 -04:00
SAFE_FREE(errstr);
2014-06-01 21:48:00 -04:00
r3_tree_free(n);
}
END_TEST
START_TEST (test_find_common_prefix_same_pattern)
{
node * n = r3_tree_create(10);
edge * e = r3_edge_createl(zstrdup("/foo/{slug:xxx}/hate"), sizeof("/foo/{slug:xxx}/hate")-1, NULL);
r3_node_append_edge(n,e);
int prefix_len;
edge *ret_edge = NULL;
prefix_len = 0;
ret_edge = r3_node_find_common_prefix(n, "/foo/{slug:yyy}/hate", sizeof("/foo/{slug:yyy}/hate")-1, &prefix_len, NULL);
2014-06-01 21:48:00 -04:00
ck_assert(ret_edge);
ck_assert_int_eq(prefix_len, 5);
prefix_len = 0;
ret_edge = r3_node_find_common_prefix(n, "/foo/{slug}/hate", sizeof("/foo/{slug}/hate")-1, &prefix_len, NULL);
2014-06-02 14:13:52 -04:00
ck_assert(ret_edge != NULL);
2014-06-01 21:48:00 -04:00
ck_assert_int_eq(prefix_len, 5);
r3_tree_free(n);
}
END_TEST
START_TEST (test_find_common_prefix_same_pattern2)
{
node * n = r3_tree_create(10);
edge * e = r3_edge_createl(zstrdup("{slug:xxx}/hate"), sizeof("{slug:xxx}/hate")-1, NULL);
r3_node_append_edge(n,e);
int prefix_len;
edge *ret_edge = NULL;
prefix_len = 0;
ret_edge = r3_node_find_common_prefix(n, "{slug:yyy}/hate", sizeof("{slug:yyy}/hate")-1, &prefix_len, NULL);
2014-06-01 21:48:00 -04:00
ck_assert(ret_edge);
ck_assert_int_eq(prefix_len, 0);
r3_tree_free(n);
}
END_TEST
2014-05-16 06:03:52 -04:00
2014-05-15 00:53:48 -04:00
2014-06-01 21:48:00 -04:00
START_TEST (test_node_construct_and_free)
2014-05-15 01:39:50 -04:00
{
2014-05-16 06:57:36 -04:00
node * n = r3_tree_create(10);
2014-05-21 06:12:14 -04:00
node * another_tree = r3_tree_create(3);
2014-05-16 06:57:36 -04:00
r3_tree_free(n);
2014-05-21 06:12:14 -04:00
r3_tree_free(another_tree);
2014-05-15 01:39:50 -04:00
}
END_TEST
2014-05-23 03:48:26 -04:00
static node * create_simple_str_tree() {
2014-05-16 03:29:25 -04:00
node * n;
2014-05-16 06:57:36 -04:00
n = r3_tree_create(10);
2014-05-18 22:12:41 -04:00
r3_tree_insert_path(n, "/zoo", NULL);
r3_tree_insert_path(n, "/foo", NULL);
r3_tree_insert_path(n, "/bar", NULL);
r3_tree_compile(n, NULL);
2014-05-23 03:48:26 -04:00
return n;
}
START_TEST (test_compile)
{
2014-05-31 14:08:16 -04:00
node *n;
2014-05-23 03:48:26 -04:00
node *m;
2014-05-31 14:08:16 -04:00
n = create_simple_str_tree();
2014-05-15 09:17:30 -04:00
2014-05-16 06:03:52 -04:00
#ifdef DEBUG
2014-05-16 06:57:36 -04:00
r3_tree_dump(n, 0);
2014-05-16 06:03:52 -04:00
#endif
2014-05-18 22:12:41 -04:00
r3_tree_insert_path(n, "/foo/{id}", NULL);
r3_tree_insert_path(n, "/{id}", NULL);
r3_tree_compile(n, NULL);
r3_tree_compile(n, NULL); // test double compile
2015-11-17 02:36:29 -05:00
// r3_tree_dump(n, 0);
2014-05-16 07:12:01 -04:00
match_entry * entry;
2014-05-16 02:24:00 -04:00
2014-05-17 11:54:18 -04:00
entry = match_entry_createl( "foo" , strlen("/foo") );
2014-05-18 22:34:48 -04:00
m = r3_tree_matchl( n , "/foo", strlen("/foo"), entry);
2014-05-21 06:31:51 -04:00
ck_assert( m );
2014-05-16 02:24:00 -04:00
2014-05-17 11:54:18 -04:00
entry = match_entry_createl( "/zoo" , strlen("/zoo") );
2014-05-18 22:34:48 -04:00
m = r3_tree_matchl( n , "/zoo", strlen("/zoo"), entry);
2014-05-21 06:31:51 -04:00
ck_assert( m );
2014-05-16 02:24:00 -04:00
2014-05-17 11:54:18 -04:00
entry = match_entry_createl( "/bar" , strlen("/bar") );
2014-05-18 22:34:48 -04:00
m = r3_tree_matchl( n , "/bar", strlen("/bar"), entry);
2014-05-21 06:31:51 -04:00
ck_assert( m );
2014-05-16 02:36:48 -04:00
2014-05-17 11:54:18 -04:00
entry = match_entry_createl( "/xxx" , strlen("/xxx") );
2014-05-18 22:34:48 -04:00
m = r3_tree_matchl( n , "/xxx", strlen("/xxx"), entry);
2014-05-21 06:31:51 -04:00
ck_assert( m );
2014-05-16 02:42:05 -04:00
2014-05-17 11:54:18 -04:00
entry = match_entry_createl( "/foo/xxx" , strlen("/foo/xxx") );
2014-05-18 22:34:48 -04:00
m = r3_tree_matchl( n , "/foo/xxx", strlen("/foo/xxx"), entry);
2014-05-21 06:31:51 -04:00
ck_assert( m );
2014-05-16 03:29:25 -04:00
2014-05-17 11:54:18 -04:00
entry = match_entry_createl( "/some_id" , strlen("/some_id") );
2014-05-18 22:34:48 -04:00
m = r3_tree_matchl( n , "/some_id", strlen("/some_id"), entry);
2014-05-21 06:31:51 -04:00
ck_assert( m );
2014-05-15 09:17:30 -04:00
}
END_TEST
2014-06-01 18:38:50 -04:00
START_TEST (test_incomplete_slug_path)
{
node * n = r3_tree_create(10);
2014-06-01 18:40:27 -04:00
node * ret_node;
2014-06-01 18:38:50 -04:00
// r3_tree_insert_path(n, "/foo-{user}-{id}", NULL, NULL);
2014-06-01 18:40:27 -04:00
ret_node = r3_tree_insert_path(n, "/post/{handle", NULL);
assert(!ret_node);
ret_node = r3_tree_insert_path(n, "/post/{handle:\\", NULL);
assert(!ret_node);
ret_node = r3_tree_insert_path(n, "/post/{handle:\\d", NULL);
assert(!ret_node);
ret_node = r3_tree_insert_path(n, "/post/{handle:\\d{", NULL);
assert(!ret_node);
ret_node = r3_tree_insert_path(n, "/post/{handle:\\d{3", NULL);
assert(!ret_node);
2014-06-01 18:50:24 -04:00
2014-06-01 18:38:50 -04:00
r3_tree_insert_path(n, "/post/{handle:\\d{3}", NULL);
r3_tree_insert_path(n, "/post/{handle:\\d{3}}/{", NULL);
r3_tree_insert_path(n, "/post/{handle:\\d{3}}/{a", NULL);
r3_tree_insert_path(n, "/post/{handle:\\d{3}}/{a}", NULL);
2014-06-01 20:04:57 -04:00
ret_node = r3_tree_insert_path(n, "/users/{idx:\\d{3}}/{idy}", NULL);
2014-06-01 21:51:42 -04:00
ck_assert(ret_node);
2014-06-01 20:04:57 -04:00
// OK to insert, but should return error when compiling patterns
2014-06-01 21:51:42 -04:00
node * ret_node2 = r3_tree_insert_path(n, "/users/{idx:\\d{3}}/{idy:aaa}", NULL);
ck_assert(ret_node2);
ck_assert(ret_node2 != ret_node); // make sure it's another node
char *errstr = NULL;
r3_tree_compile(n, &errstr);
ck_assert(errstr == NULL); // no error
2014-06-01 20:04:57 -04:00
2015-11-17 02:36:29 -05:00
// r3_tree_dump(n, 0);
2014-06-01 20:04:57 -04:00
2014-06-01 18:38:50 -04:00
r3_tree_free(n);
}
END_TEST
START_TEST (test_pcre_patterns_insert)
2014-05-15 08:38:07 -04:00
{
node * n = r3_tree_create(10);
2014-05-15 09:17:30 -04:00
// r3_tree_insert_path(n, "/foo-{user}-{id}", NULL, NULL);
r3_tree_insert_path(n, "/post/{handle:\\d+}-{id:\\d+}", NULL);
2014-06-01 19:13:47 -04:00
r3_tree_insert_path(n, "/post/foo", NULL);
r3_tree_insert_path(n, "/post/bar", NULL);
char *errstr = NULL;
2014-06-01 02:53:12 -04:00
int errcode;
errcode = r3_tree_compile(n, &errstr);
ck_assert(errcode == 0); // no error
2014-05-31 14:13:38 -04:00
// r3_tree_dump(n, 0);
2014-05-15 09:17:30 -04:00
node *matched;
2014-06-01 19:13:47 -04:00
matched = r3_tree_match(n, "/post/foo", NULL);
ck_assert(matched);
ck_assert(matched->endpoint > 0);
matched = r3_tree_match(n, "/post/bar", NULL);
ck_assert(matched);
ck_assert(matched->endpoint > 0);
matched = r3_tree_match(n, "/post/kkkfoo", NULL);
ck_assert(!matched);
2014-06-01 19:14:16 -04:00
matched = r3_tree_match(n, "/post/kkkbar", NULL);
ck_assert(!matched);
2014-06-01 19:13:47 -04:00
matched = r3_tree_matchl(n, "/post/111-222", strlen("/post/111-222"), NULL);
2014-05-21 06:31:51 -04:00
ck_assert(matched);
ck_assert(matched->endpoint > 0);
2014-05-15 09:17:30 -04:00
// incomplete string shouldn't match
matched = r3_tree_matchl(n, "/post/111-", strlen("/post/111-"), NULL);
ck_assert(! matched);
2014-05-15 09:17:30 -04:00
r3_tree_free(n);
2014-05-15 08:38:07 -04:00
}
END_TEST
2015-10-17 19:39:32 -04:00
/**
* Test for root '/'
*/
START_TEST (test_root_match)
{
node * n = r3_tree_create(10);
int a = 10;
int b = 20;
int c = 30;
r3_tree_insert_path(n, "/", &a);
r3_tree_insert_path(n, "/foo", &b);
r3_tree_insert_path(n, "/bar", &c);
char *errstr = NULL;
r3_tree_compile(n, &errstr);
2015-11-17 02:36:29 -05:00
// r3_tree_dump(n, 0);
2015-10-17 19:39:32 -04:00
node *matched;
matched = r3_tree_match(n, "/", NULL);
ck_assert(matched);
ck_assert(matched->data == &a);
ck_assert(matched->endpoint > 0);
matched = r3_tree_match(n, "/foo", NULL);
ck_assert(matched);
ck_assert(matched->data == &b);
ck_assert(matched->endpoint > 0);
matched = r3_tree_match(n, "/bar", NULL);
ck_assert(matched);
ck_assert(matched->data == &c);
ck_assert(matched->endpoint > 0);
}
END_TEST
/**
2014-05-20 12:55:43 -04:00
* Test for \d{2}/\d{2}
*/
START_TEST (test_pcre_patterns_insert_2)
{
node * n = r3_tree_create(10);
r3_tree_insert_path(n, "/post/{idx:\\d{2}}/{idy:\\d{2}}", NULL);
2014-05-20 13:15:54 -04:00
r3_tree_insert_path(n, "/zoo", NULL);
r3_tree_insert_path(n, "/foo", NULL);
r3_tree_insert_path(n, "/bar", NULL);
2014-05-31 14:08:16 -04:00
char *errstr = NULL;
r3_tree_compile(n, &errstr);
2015-11-17 02:36:29 -05:00
// r3_tree_dump(n, 0);
node *matched;
matched = r3_tree_match(n, "/post/11/22", NULL);
2014-05-21 03:50:37 -04:00
ck_assert((int)matched);
ck_assert(matched->endpoint > 0);
}
END_TEST
/**
2014-05-20 12:55:43 -04:00
* Test for (\d{2})/([^/]+)
*/
START_TEST (test_pcre_patterns_insert_3)
{
node * n = r3_tree_create(10);
2014-05-20 13:15:54 -04:00
printf("Inserting /post/{idx:\\d{2}}/{idy}\n");
2014-05-20 12:49:08 -04:00
r3_tree_insert_path(n, "/post/{idx:\\d{2}}/{idy}", NULL);
2015-11-17 02:36:29 -05:00
// r3_tree_dump(n, 0);
2014-05-20 13:15:54 -04:00
printf("Inserting /zoo\n");
r3_tree_insert_path(n, "/zoo", NULL);
2015-11-17 02:36:29 -05:00
// r3_tree_dump(n, 0);
2014-05-20 13:15:54 -04:00
r3_tree_insert_path(n, "/foo", NULL);
r3_tree_insert_path(n, "/bar", NULL);
2014-05-31 14:08:16 -04:00
char *errstr = NULL;
r3_tree_compile(n, &errstr);
2015-11-17 02:36:29 -05:00
// r3_tree_dump(n, 0);
node *matched;
2014-05-20 13:15:54 -04:00
matched = r3_tree_match(n, "/post/11/22", NULL);
2014-05-21 03:50:37 -04:00
ck_assert((int)matched);
2014-05-20 13:15:54 -04:00
2014-05-20 12:49:08 -04:00
matched = r3_tree_match(n, "/post/11", NULL);
ck_assert(!matched);
matched = r3_tree_match(n, "/post/11/", NULL);
ck_assert(!matched);
2014-05-20 13:15:54 -04:00
/*
2014-05-20 12:49:08 -04:00
matched = r3_tree_match(n, "/post/113", NULL);
ck_assert(!matched);
2014-05-20 13:15:54 -04:00
*/
}
END_TEST
2014-06-02 04:20:02 -04:00
START_TEST (test_insert_pathl_fail)
{
node * n = r3_tree_create(10);
node * ret;
char *errstr = NULL;
ret = r3_tree_insert_pathl_ex(n, "/foo/{name:\\d{5}", strlen("/foo/{name:\\d{5}"), NULL, NULL, &errstr);
ck_assert(ret == NULL);
ck_assert(errstr != NULL);
printf("%s\n", errstr); // Returns Incomplete slug pattern. PATTERN (16): '/foo/{name:\d{5}', OFFSET: 16, STATE: 1
SAFE_FREE(errstr);
errstr = NULL;
r3_tree_compile(n, &errstr);
ck_assert(errstr == NULL);
r3_tree_free(n);
}
END_TEST
2014-06-01 21:48:00 -04:00
START_TEST (test_insert_pathl)
2014-05-15 06:02:10 -04:00
{
2014-05-16 06:57:36 -04:00
node * n = r3_tree_create(10);
2014-05-15 06:02:10 -04:00
2014-06-01 21:48:00 -04:00
node * ret;
ret = r3_tree_insert_path(n, "/foo/bar", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/foo/zoo", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/foo/{id}", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/foo/{number:\\d+}", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/foo/{name:\\w+}", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/foo/{name:\\d+}", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/foo/{name:\\d{5}}", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/foo/{idx}/{idy}", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/foo/{idx}/{idh}", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/f/id" , NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/post/{id}", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/post/{handle}", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/post/{handle}-{id}", NULL);
ck_assert(ret);
2014-05-15 10:57:13 -04:00
2014-06-01 21:48:00 -04:00
char * errstr = NULL;
r3_tree_compile(n, &errstr);
ck_assert(errstr == NULL);
2015-11-17 02:36:29 -05:00
// r3_tree_dump(n, 0);
2014-06-01 21:48:00 -04:00
r3_tree_free(n);
}
END_TEST
2014-05-15 10:57:13 -04:00
2014-06-01 21:48:00 -04:00
START_TEST (test_compile_fail)
{
node * n = r3_tree_create(10);
2014-06-01 21:48:00 -04:00
node * ret;
ret = r3_tree_insert_path(n, "/foo/{idx}/{idy:)}", NULL);
ck_assert(ret);
ret = r3_tree_insert_path(n, "/foo/{idx}/{idh:(}", NULL);
ck_assert(ret);
2014-05-31 14:08:16 -04:00
char * errstr = NULL;
r3_tree_compile(n, &errstr);
2014-06-01 21:48:00 -04:00
ck_assert(errstr);
fprintf(stderr, "Compile failed: %s\n", errstr);
free(errstr);
2014-05-15 06:02:10 -04:00
2015-11-17 02:36:29 -05:00
// r3_tree_dump(n, 0);
2014-05-16 06:57:36 -04:00
r3_tree_free(n);
2014-05-15 06:02:10 -04:00
}
END_TEST
2014-06-01 21:48:00 -04:00
2014-05-15 06:02:10 -04:00
2014-05-14 22:08:42 -04:00
2014-05-16 06:03:52 -04:00
START_TEST(test_route_cmp)
{
route *r1 = r3_route_create("/blog/post");
2014-05-18 00:56:53 -04:00
match_entry * m = match_entry_create("/blog/post");
fail_if( r3_route_cmp(r1, m) == -1, "should match");
r1->request_method = METHOD_GET;
2014-05-18 00:56:53 -04:00
m->request_method = METHOD_GET;
fail_if( r3_route_cmp(r1, m) == -1, "should match");
r1->request_method = METHOD_GET;
2014-05-18 00:56:53 -04:00
m->request_method = METHOD_POST;
fail_if( r3_route_cmp(r1, m) == 0, "should be different");
2014-05-18 00:56:53 -04:00
r1->request_method = METHOD_GET;
m->request_method = METHOD_POST | METHOD_GET;
fail_if( r3_route_cmp(r1, m) == -1, "should match");
2014-05-18 00:24:07 -04:00
r3_route_free(r1);
2014-05-18 00:56:53 -04:00
match_entry_free(m);
}
END_TEST
2014-05-17 07:25:25 -04:00
2014-05-18 02:13:04 -04:00
START_TEST(test_pcre_pattern_simple)
{
match_entry * entry;
entry = match_entry_createl( "/user/123" , strlen("/user/123") );
2014-05-18 02:18:47 -04:00
node * n = r3_tree_create(10);
2014-05-18 22:12:41 -04:00
r3_tree_insert_path(n, "/user/{id:\\d+}", NULL);
r3_tree_insert_path(n, "/user", NULL);
r3_tree_compile(n, NULL);
// r3_tree_dump(n, 0);
2014-05-18 02:30:00 -04:00
node *matched;
2014-05-18 22:34:48 -04:00
matched = r3_tree_matchl(n, "/user/123", strlen("/user/123"), entry);
2014-05-21 06:31:51 -04:00
ck_assert(matched);
ck_assert(entry->vars->len > 0);
2014-05-18 02:30:00 -04:00
ck_assert_str_eq(entry->vars->tokens[0],"123");
2014-05-20 04:18:17 -04:00
r3_tree_free(n);
2014-05-18 02:30:00 -04:00
}
END_TEST
START_TEST(test_pcre_pattern_more)
{
match_entry * entry;
entry = match_entry_createl( "/user/123" , strlen("/user/123") );
node * n = r3_tree_create(10);
2014-05-18 03:00:11 -04:00
int var0 = 5;
int var1 = 100;
int var2 = 200;
int var3 = 300;
2014-05-18 03:06:11 -04:00
info("var0: %p\n", &var0);
info("var1: %p\n", &var1);
info("var2: %p\n", &var2);
info("var3: %p\n", &var3);
2014-05-18 02:13:04 -04:00
2014-05-18 22:12:41 -04:00
r3_tree_insert_path(n, "/user/{id:\\d+}", &var1);
r3_tree_insert_path(n, "/user2/{id:\\d+}", &var2);
r3_tree_insert_path(n, "/user3/{id:\\d{3}}", &var3);
r3_tree_insert_path(n, "/user", &var0);
r3_tree_compile(n, NULL);
2015-11-17 02:36:29 -05:00
// r3_tree_dump(n, 0);
2014-05-18 02:13:04 -04:00
node *matched;
2014-05-18 02:30:00 -04:00
2014-05-18 22:34:48 -04:00
matched = r3_tree_matchl(n, "/user/123", strlen("/user/123"), entry);
2014-05-21 06:31:51 -04:00
ck_assert(matched);
ck_assert(entry->vars->len > 0);
2014-05-18 02:30:00 -04:00
ck_assert_str_eq(entry->vars->tokens[0],"123");
2014-05-18 03:06:11 -04:00
info("matched %p\n", matched->data);
info("matched %p\n", matched->data);
ck_assert_int_eq( *((int*) matched->data), var1);
2014-05-18 22:34:48 -04:00
matched = r3_tree_matchl(n, "/user2/123", strlen("/user2/123"), entry);
2014-05-21 06:31:51 -04:00
ck_assert(matched);
ck_assert(entry->vars->len > 0);
2014-05-18 02:30:00 -04:00
ck_assert_str_eq(entry->vars->tokens[0],"123");
2014-05-18 03:06:11 -04:00
ck_assert_int_eq( *((int*)matched->data), var2);
2014-05-18 02:30:00 -04:00
2014-05-18 22:34:48 -04:00
matched = r3_tree_matchl(n, "/user3/123", strlen("/user3/123"), entry);
2014-05-21 06:31:51 -04:00
ck_assert(matched);
ck_assert(entry->vars->len > 0);
2014-05-18 02:18:47 -04:00
ck_assert_str_eq(entry->vars->tokens[0],"123");
2014-05-18 03:06:11 -04:00
ck_assert_int_eq( *((int*)matched->data), var3);
2014-05-20 04:18:17 -04:00
r3_tree_free(n);
2014-05-18 02:13:04 -04:00
}
2014-05-18 02:18:47 -04:00
END_TEST
2014-05-17 07:25:25 -04:00
2014-05-18 02:30:00 -04:00
START_TEST(test_insert_pathl_before_root)
{
char *errstr = NULL;
int var1 = 22;
int var2 = 33;
int var3 = 44;
node * n = r3_tree_create(3);
r3_tree_insert_pathl_ex(n, STR("/blog/post"), NULL, &var1, NULL);
r3_tree_insert_pathl_ex(n, STR("/blog"), NULL, &var2, NULL);
r3_tree_insert_pathl_ex(n, STR("/"), NULL, &var3, NULL);
errstr = NULL;
r3_tree_compile(n, &errstr);
r3_tree_dump(n, 0);
r3_tree_free(n);
}
END_TEST
2014-05-18 02:30:00 -04:00
2014-05-18 00:24:07 -04:00
START_TEST(test_insert_route)
{
int var1 = 22;
int var2 = 33;
2014-05-17 07:25:25 -04:00
2014-05-18 00:24:07 -04:00
node * n = r3_tree_create(2);
2014-05-31 07:56:46 -04:00
r3_tree_insert_route(n, METHOD_GET, "/blog/post", &var1);
r3_tree_insert_route(n, METHOD_POST, "/blog/post", &var2);
2014-05-17 07:25:25 -04:00
2014-06-12 06:52:39 -04:00
match_entry * entry;
route *r;
2014-05-18 00:56:53 -04:00
2014-06-12 06:52:39 -04:00
entry = match_entry_create("/blog/post");
entry->request_method = METHOD_GET;
r = r3_tree_match_route(n, entry);
ck_assert(r != NULL);
ck_assert(r->request_method & METHOD_GET );
ck_assert(*((int*)r->data) == 22);
2014-05-18 00:24:07 -04:00
match_entry_free(entry);
2014-06-12 06:52:39 -04:00
entry = match_entry_create("/blog/post");
entry->request_method = METHOD_POST;
r = r3_tree_match_route(n, entry);
ck_assert(r != NULL);
ck_assert(r->request_method & METHOD_POST );
ck_assert(*((int*)r->data) == 33);
match_entry_free(entry);
r3_tree_free(n);
2014-05-17 07:25:25 -04:00
}
END_TEST
2014-05-14 22:08:42 -04:00
Suite* r3_suite (void) {
2014-06-01 20:04:57 -04:00
Suite *suite = suite_create("r3 core tests");
2015-11-17 02:36:29 -05:00
TCase *tcase = tcase_create("common_prefix_testcase");
tcase_add_test(tcase, test_find_common_prefix);
2014-06-01 21:48:00 -04:00
tcase_add_test(tcase, test_find_common_prefix_after);
tcase_add_test(tcase, test_find_common_prefix_double_middle);
tcase_add_test(tcase, test_find_common_prefix_middle);
tcase_add_test(tcase, test_find_common_prefix_same_pattern);
tcase_add_test(tcase, test_find_common_prefix_same_pattern2);
2015-11-17 02:36:29 -05:00
suite_add_tcase(suite, tcase);
tcase = tcase_create("insert_testcase");
2014-06-01 21:48:00 -04:00
tcase_add_test(tcase, test_insert_pathl);
2014-06-02 04:20:02 -04:00
tcase_add_test(tcase, test_insert_pathl_fail);
2014-06-01 21:48:00 -04:00
tcase_add_test(tcase, test_node_construct_and_free);
2015-11-17 02:36:29 -05:00
suite_add_tcase(suite, tcase);
tcase = tcase_create("compile_testcase");
2014-05-16 02:05:51 -04:00
tcase_add_test(tcase, test_compile);
2014-06-01 21:49:13 -04:00
tcase_add_test(tcase, test_compile_fail);
tcase_add_test(tcase, test_route_cmp);
2014-05-18 01:04:17 -04:00
tcase_add_test(tcase, test_insert_route);
tcase_add_test(tcase, test_insert_pathl_before_root);
2015-11-17 02:36:29 -05:00
suite_add_tcase(suite, tcase);
tcase = tcase_create("pcre_pattern_testcase");
2014-05-18 02:30:00 -04:00
tcase_add_test(tcase, test_pcre_pattern_simple);
tcase_add_test(tcase, test_pcre_pattern_more);
tcase_add_test(tcase, test_pcre_patterns_insert);
tcase_add_test(tcase, test_pcre_patterns_insert_2);
2015-10-17 19:39:32 -04:00
tcase_add_test(tcase, test_root_match);
2014-05-20 12:49:08 -04:00
tcase_add_test(tcase, test_pcre_patterns_insert_3);
2014-06-01 18:38:50 -04:00
tcase_add_test(tcase, test_incomplete_slug_path);
2014-05-14 12:15:19 -04:00
suite_add_tcase(suite, tcase);
2014-05-14 22:08:42 -04:00
2014-05-14 12:15:19 -04:00
return suite;
}
int main (int argc, char *argv[]) {
int number_failed;
2014-05-14 22:08:42 -04:00
Suite *suite = r3_suite();
2014-05-14 12:15:19 -04:00
SRunner *runner = srunner_create(suite);
srunner_run_all(runner, CK_NORMAL);
number_failed = srunner_ntests_failed(runner);
srunner_free(runner);
return number_failed;
}