/* * blogc: A blog compiler. * Copyright (C) 2014-2016 Rafael G. Martins * * This program can be distributed under the terms of the BSD License. * See the file LICENSE. */ #include #include #include #include #include #include "../src/utils.h" #define SB_STRING_CHUNK_SIZE 128 static void test_slist_append(void **state) { sb_slist_t *l = NULL; l = sb_slist_append(l, (void*) sb_strdup("bola")); assert_non_null(l); assert_string_equal(l->data, "bola"); assert_null(l->next); l = sb_slist_append(l, (void*) sb_strdup("guda")); assert_non_null(l); assert_string_equal(l->data, "bola"); assert_non_null(l->next); assert_string_equal(l->next->data, "guda"); assert_null(l->next->next); sb_slist_free_full(l, free); } static void test_slist_prepend(void **state) { sb_slist_t *l = NULL; l = sb_slist_prepend(l, (void*) sb_strdup("bola")); assert_non_null(l); assert_string_equal(l->data, "bola"); assert_null(l->next); l = sb_slist_prepend(l, (void*) sb_strdup("guda")); assert_non_null(l); assert_string_equal(l->data, "guda"); assert_non_null(l->next); assert_string_equal(l->next->data, "bola"); assert_null(l->next->next); sb_slist_free_full(l, free); } static void test_slist_free(void **state) { sb_slist_t *l = NULL; char *t1 = sb_strdup("bola"); char *t2 = sb_strdup("guda"); char *t3 = sb_strdup("chunda"); l = sb_slist_append(l, (void*) t1); l = sb_slist_append(l, (void*) t2); l = sb_slist_append(l, (void*) t3); sb_slist_free(l); assert_string_equal(t1, "bola"); assert_string_equal(t2, "guda"); assert_string_equal(t3, "chunda"); free(t1); free(t2); free(t3); } static void test_slist_length(void **state) { sb_slist_t *l = NULL; l = sb_slist_append(l, (void*) sb_strdup("bola")); l = sb_slist_append(l, (void*) sb_strdup("guda")); l = sb_slist_append(l, (void*) sb_strdup("chunda")); assert_int_equal(sb_slist_length(l), 3); sb_slist_free_full(l, free); assert_int_equal(sb_slist_length(NULL), 0); } static void test_strdup(void **state) { char *str = sb_strdup("bola"); assert_string_equal(str, "bola"); free(str); str = sb_strdup(NULL); assert_null(str); } static void test_strndup(void **state) { char *str = sb_strndup("bolaguda", 4); assert_string_equal(str, "bola"); free(str); str = sb_strndup("bolaguda", 30); assert_string_equal(str, "bolaguda"); free(str); str = sb_strndup("bolaguda", 8); assert_string_equal(str, "bolaguda"); free(str); str = sb_strdup(NULL); assert_null(str); } static void test_strdup_printf(void **state) { char *str = sb_strdup_printf("bola"); assert_string_equal(str, "bola"); free(str); str = sb_strdup_printf("bola, %s", "guda"); assert_string_equal(str, "bola, guda"); free(str); } static void test_str_starts_with(void **state) { assert_true(sb_str_starts_with("bolaguda", "bola")); assert_true(sb_str_starts_with("bola", "bola")); assert_false(sb_str_starts_with("gudabola", "bola")); assert_false(sb_str_starts_with("guda", "bola")); assert_false(sb_str_starts_with("bola", "bolaguda")); } static void test_str_ends_with(void **state) { assert_true(sb_str_ends_with("bolaguda", "guda")); assert_true(sb_str_ends_with("bola", "bola")); assert_false(sb_str_ends_with("gudabola", "guda")); assert_false(sb_str_ends_with("guda", "bola")); assert_false(sb_str_ends_with("bola", "gudabola")); } static void test_str_lstrip(void **state) { char *str = sb_strdup(" \tbola\n \t"); assert_string_equal(sb_str_lstrip(str), "bola\n \t"); free(str); str = sb_strdup("guda"); assert_string_equal(sb_str_lstrip(str), "guda"); free(str); str = sb_strdup("\n"); assert_string_equal(sb_str_lstrip(str), ""); free(str); str = sb_strdup("\t \n"); assert_string_equal(sb_str_lstrip(str), ""); free(str); str = sb_strdup(""); assert_string_equal(sb_str_lstrip(str), ""); free(str); assert_null(sb_str_lstrip(NULL)); } static void test_str_rstrip(void **state) { char *str = sb_strdup(" \tbola\n \t"); assert_string_equal(sb_str_rstrip(str), " \tbola"); free(str); str = sb_strdup("guda"); assert_string_equal(sb_str_rstrip(str), "guda"); free(str); str = sb_strdup("\n"); assert_string_equal(sb_str_rstrip(str), ""); free(str); str = sb_strdup("\t \n"); assert_string_equal(sb_str_rstrip(str), ""); free(str); str = sb_strdup(""); assert_string_equal(sb_str_rstrip(str), ""); free(str); assert_null(sb_str_rstrip(NULL)); } static void test_str_strip(void **state) { char *str = sb_strdup(" \tbola\n \t"); assert_string_equal(sb_str_strip(str), "bola"); free(str); str = sb_strdup("guda"); assert_string_equal(sb_str_strip(str), "guda"); free(str); str = sb_strdup("\n"); assert_string_equal(sb_str_strip(str), ""); free(str); str = sb_strdup("\t \n"); assert_string_equal(sb_str_strip(str), ""); free(str); str = sb_strdup(""); assert_string_equal(sb_str_strip(str), ""); free(str); assert_null(sb_str_strip(NULL)); } static void test_str_split(void **state) { char **strv = sb_str_split("bola:guda:chunda", ':', 0); assert_string_equal(strv[0], "bola"); assert_string_equal(strv[1], "guda"); assert_string_equal(strv[2], "chunda"); assert_null(strv[3]); sb_strv_free(strv); strv = sb_str_split("bola:guda:chunda", ':', 2); assert_string_equal(strv[0], "bola"); assert_string_equal(strv[1], "guda:chunda"); assert_null(strv[2]); sb_strv_free(strv); strv = sb_str_split("bola:guda:chunda", ':', 1); assert_string_equal(strv[0], "bola:guda:chunda"); assert_null(strv[1]); sb_strv_free(strv); strv = sb_str_split("", ':', 1); assert_null(strv[0]); sb_strv_free(strv); assert_null(sb_str_split(NULL, ':', 0)); } static void test_str_replace(void **state) { char *str = sb_str_replace("bolao", 'o', "zaz"); assert_string_equal(str, "bzazlazaz"); free(str); str = sb_str_replace("bolao", 'b', "zaz"); assert_string_equal(str, "zazolao"); free(str); str = sb_str_replace("bolao", 'b', NULL); assert_string_equal(str, "bolao"); free(str); assert_null(sb_str_replace(NULL, 'b', "zaz")); } static void test_strv_join(void **state) { char *pieces[] = {"guda","bola", "chunda", NULL}; char *str = sb_strv_join(pieces, ":"); assert_string_equal(str, "guda:bola:chunda"); free(str); char *pieces2[] = {NULL}; str = sb_strv_join(pieces2, ":"); assert_string_equal(str, ""); free(str); assert_null(sb_strv_join(pieces, NULL)); assert_null(sb_strv_join(NULL, ":")); assert_null(sb_strv_join(NULL, NULL)); } static void test_strv_length(void **state) { char *pieces[] = {"guda","bola", "chunda", NULL}; assert_int_equal(sb_strv_length(pieces), 3); char *pieces2[] = {NULL}; assert_int_equal(sb_strv_length(pieces2), 0); assert_int_equal(sb_strv_length(NULL), 0); } static void test_string_new(void **state) { sb_string_t *str = sb_string_new(); assert_non_null(str); assert_string_equal(str->str, ""); assert_int_equal(str->len, 0); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE); assert_null(sb_string_free(str, true)); } static void test_string_free(void **state) { sb_string_t *str = sb_string_new(); free(str->str); str->str = sb_strdup("bola"); str->len = 4; str->allocated_len = SB_STRING_CHUNK_SIZE; char *tmp = sb_string_free(str, false); assert_string_equal(tmp, "bola"); free(tmp); assert_null(sb_string_free(NULL, false)); } static void test_string_dup(void **state) { sb_string_t *str = sb_string_new(); free(str->str); str->str = sb_strdup("bola"); str->len = 4; str->allocated_len = SB_STRING_CHUNK_SIZE; sb_string_t *new = sb_string_dup(str); assert_non_null(new); assert_string_equal(new->str, "bola"); assert_int_equal(new->len, 4); assert_int_equal(new->allocated_len, SB_STRING_CHUNK_SIZE); assert_null(sb_string_free(new, true)); assert_null(sb_string_free(str, true)); assert_null(sb_string_dup(NULL)); } static void test_string_append_len(void **state) { sb_string_t *str = sb_string_new(); str = sb_string_append_len(str, "guda", 4); assert_non_null(str); assert_string_equal(str->str, "guda"); assert_int_equal(str->len, 4); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE); assert_null(sb_string_free(str, true)); str = sb_string_new(); str = sb_string_append_len(str, "guda", 4); str = sb_string_append_len(str, "bola", 4); assert_non_null(str); assert_string_equal(str->str, "gudabola"); assert_int_equal(str->len, 8); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE); assert_null(sb_string_free(str, true)); str = sb_string_new(); str = sb_string_append_len(str, "guda", 3); str = sb_string_append_len(str, "bola", 4); assert_non_null(str); assert_string_equal(str->str, "gudbola"); assert_int_equal(str->len, 7); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE); assert_null(sb_string_free(str, true)); str = sb_string_new(); str = sb_string_append_len(str, "guda", 4); str = sb_string_append_len(str, "cwlwmwxxmvjnwtidmjehzdeexbxjnjowruxjrqpgpfhmvwgqeacdjissntmbtsjidzkcw" "nnqhxhneolbwqlctcxmrsutolrjikpavxombpfpjyaqltgvzrjidotalcuwrwxtaxjiwa" "xfhfyzymtffusoqywaruxpybwggukltspqqmghzpqstvcvlqbkhquihzndnrvkaqvevaz" "dxrewtgapkompnviiyielanoyowgqhssntyvcvqqtfjmkphywbkvzfyttaalttywhqcec" "hgrwzaglzogwjvqncjzodaqsblcbpcdpxmrtctzginvtkckhqvdplgjvbzrnarcxjrsbc" "sbfvpylgjznsuhxcxoqbpxowmsrgwimxjgyzwwmryqvstwzkglgeezelvpvkwefqdatnd" "dxntikgoqlidfnmdhxzevqzlzubvyleeksdirmmttqthhkvfjggznpmarcamacpvwsrnr" "ftzfeyasjpxoevyptpdnqokswiondusnuymqwaryrmdgscbnuilxtypuynckancsfnwtg" "okxhegoifakimxbbafkeannglvsxprqzfekdinssqymtfexf", 600); str = sb_string_append_len(str, NULL, 0); str = sb_string_append_len(str, "cwlwmwxxmvjnwtidmjehzdeexbxjnjowruxjrqpgpfhmvwgqeacdjissntmbtsjidzkcw" "nnqhxhneolbwqlctcxmrsutolrjikpavxombpfpjyaqltgvzrjidotalcuwrwxtaxjiwa" "xfhfyzymtffusoqywaruxpybwggukltspqqmghzpqstvcvlqbkhquihzndnrvkaqvevaz" "dxrewtgapkompnviiyielanoyowgqhssntyvcvqqtfjmkphywbkvzfyttaalttywhqcec" "hgrwzaglzogwjvqncjzodaqsblcbpcdpxmrtctzginvtkckhqvdplgjvbzrnarcxjrsbc" "sbfvpylgjznsuhxcxoqbpxowmsrgwimxjgyzwwmryqvstwzkglgeezelvpvkwefqdatnd" "dxntikgoqlidfnmdhxzevqzlzubvyleeksdirmmttqthhkvfjggznpmarcamacpvwsrnr" "ftzfeyasjpxoevyptpdnqokswiondusnuymqwaryrmdgscbnuilxtypuynckancsfnwtg" "okxhegoifakimxbbafkeannglvsxprqzfekdinssqymtfexf", 600); assert_non_null(str); assert_string_equal(str->str, "gudacwlwmwxxmvjnwtidmjehzdeexbxjnjowruxjrqpgpfhmvwgqeacdjissntmbtsjid" "zkcwnnqhxhneolbwqlctcxmrsutolrjikpavxombpfpjyaqltgvzrjidotalcuwrwxtax" "jiwaxfhfyzymtffusoqywaruxpybwggukltspqqmghzpqstvcvlqbkhquihzndnrvkaqv" "evazdxrewtgapkompnviiyielanoyowgqhssntyvcvqqtfjmkphywbkvzfyttaalttywh" "qcechgrwzaglzogwjvqncjzodaqsblcbpcdpxmrtctzginvtkckhqvdplgjvbzrnarcxj" "rsbcsbfvpylgjznsuhxcxoqbpxowmsrgwimxjgyzwwmryqvstwzkglgeezelvpvkwefqd" "atnddxntikgoqlidfnmdhxzevqzlzubvyleeksdirmmttqthhkvfjggznpmarcamacpvw" "srnrftzfeyasjpxoevyptpdnqokswiondusnuymqwaryrmdgscbnuilxtypuynckancsf" "nwtgokxhegoifakimxbbafkeannglvsxprqzfekdinssqymtfexfcwlwmwxxmvjnwtidm" "jehzdeexbxjnjowruxjrqpgpfhmvwgqeacdjissntmbtsjidzkcwnnqhxhneolbwqlctc" "xmrsutolrjikpavxombpfpjyaqltgvzrjidotalcuwrwxtaxjiwaxfhfyzymtffusoqyw" "aruxpybwggukltspqqmghzpqstvcvlqbkhquihzndnrvkaqvevazdxrewtgapkompnvii" "yielanoyowgqhssntyvcvqqtfjmkphywbkvzfyttaalttywhqcechgrwzaglzogwjvqnc" "jzodaqsblcbpcdpxmrtctzginvtkckhqvdplgjvbzrnarcxjrsbcsbfvpylgjznsuhxcx" "oqbpxowmsrgwimxjgyzwwmryqvstwzkglgeezelvpvkwefqdatnddxntikgoqlidfnmdh" "xzevqzlzubvyleeksdirmmttqthhkvfjggznpmarcamacpvwsrnrftzfeyasjpxoevypt" "pdnqokswiondusnuymqwaryrmdgscbnuilxtypuynckancsfnwtgokxhegoifakimxbba" "fkeannglvsxprqzfekdinssqymtfexf"); assert_int_equal(str->len, 1204); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE * 10); assert_null(sb_string_free(str, true)); str = sb_string_new(); str = sb_string_append_len(str, NULL, 0); assert_non_null(str); assert_string_equal(str->str, ""); assert_int_equal(str->len, 0); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE); assert_null(sb_string_free(str, true)); assert_null(sb_string_append_len(NULL, "foo", 3)); } static void test_string_append(void **state) { sb_string_t *str = sb_string_new(); str = sb_string_append(str, "guda"); assert_non_null(str); assert_string_equal(str->str, "guda"); assert_int_equal(str->len, 4); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE); assert_null(sb_string_free(str, true)); str = sb_string_new(); str = sb_string_append(str, "guda"); str = sb_string_append(str, "bola"); assert_non_null(str); assert_string_equal(str->str, "gudabola"); assert_int_equal(str->len, 8); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE); assert_null(sb_string_free(str, true)); str = sb_string_new(); str = sb_string_append(str, "guda"); str = sb_string_append(str, "cwlwmwxxmvjnwtidmjehzdeexbxjnjowruxjrqpgpfhmvwgqeacdjissntmbtsjidzkcw" "nnqhxhneolbwqlctcxmrsutolrjikpavxombpfpjyaqltgvzrjidotalcuwrwxtaxjiwa" "xfhfyzymtffusoqywaruxpybwggukltspqqmghzpqstvcvlqbkhquihzndnrvkaqvevaz" "dxrewtgapkompnviiyielanoyowgqhssntyvcvqqtfjmkphywbkvzfyttaalttywhqcec" "hgrwzaglzogwjvqncjzodaqsblcbpcdpxmrtctzginvtkckhqvdplgjvbzrnarcxjrsbc" "sbfvpylgjznsuhxcxoqbpxowmsrgwimxjgyzwwmryqvstwzkglgeezelvpvkwefqdatnd" "dxntikgoqlidfnmdhxzevqzlzubvyleeksdirmmttqthhkvfjggznpmarcamacpvwsrnr" "ftzfeyasjpxoevyptpdnqokswiondusnuymqwaryrmdgscbnuilxtypuynckancsfnwtg" "okxhegoifakimxbbafkeannglvsxprqzfekdinssqymtfexf"); str = sb_string_append(str, NULL); str = sb_string_append(str, "cwlwmwxxmvjnwtidmjehzdeexbxjnjowruxjrqpgpfhmvwgqeacdjissntmbtsjidzkcw" "nnqhxhneolbwqlctcxmrsutolrjikpavxombpfpjyaqltgvzrjidotalcuwrwxtaxjiwa" "xfhfyzymtffusoqywaruxpybwggukltspqqmghzpqstvcvlqbkhquihzndnrvkaqvevaz" "dxrewtgapkompnviiyielanoyowgqhssntyvcvqqtfjmkphywbkvzfyttaalttywhqcec" "hgrwzaglzogwjvqncjzodaqsblcbpcdpxmrtctzginvtkckhqvdplgjvbzrnarcxjrsbc" "sbfvpylgjznsuhxcxoqbpxowmsrgwimxjgyzwwmryqvstwzkglgeezelvpvkwefqdatnd" "dxntikgoqlidfnmdhxzevqzlzubvyleeksdirmmttqthhkvfjggznpmarcamacpvwsrnr" "ftzfeyasjpxoevyptpdnqokswiondusnuymqwaryrmdgscbnuilxtypuynckancsfnwtg" "okxhegoifakimxbbafkeannglvsxprqzfekdinssqymtfexf"); assert_non_null(str); assert_string_equal(str->str, "gudacwlwmwxxmvjnwtidmjehzdeexbxjnjowruxjrqpgpfhmvwgqeacdjissntmbtsjid" "zkcwnnqhxhneolbwqlctcxmrsutolrjikpavxombpfpjyaqltgvzrjidotalcuwrwxtax" "jiwaxfhfyzymtffusoqywaruxpybwggukltspqqmghzpqstvcvlqbkhquihzndnrvkaqv" "evazdxrewtgapkompnviiyielanoyowgqhssntyvcvqqtfjmkphywbkvzfyttaalttywh" "qcechgrwzaglzogwjvqncjzodaqsblcbpcdpxmrtctzginvtkckhqvdplgjvbzrnarcxj" "rsbcsbfvpylgjznsuhxcxoqbpxowmsrgwimxjgyzwwmryqvstwzkglgeezelvpvkwefqd" "atnddxntikgoqlidfnmdhxzevqzlzubvyleeksdirmmttqthhkvfjggznpmarcamacpvw" "srnrftzfeyasjpxoevyptpdnqokswiondusnuymqwaryrmdgscbnuilxtypuynckancsf" "nwtgokxhegoifakimxbbafkeannglvsxprqzfekdinssqymtfexfcwlwmwxxmvjnwtidm" "jehzdeexbxjnjowruxjrqpgpfhmvwgqeacdjissntmbtsjidzkcwnnqhxhneolbwqlctc" "xmrsutolrjikpavxombpfpjyaqltgvzrjidotalcuwrwxtaxjiwaxfhfyzymtffusoqyw" "aruxpybwggukltspqqmghzpqstvcvlqbkhquihzndnrvkaqvevazdxrewtgapkompnvii" "yielanoyowgqhssntyvcvqqtfjmkphywbkvzfyttaalttywhqcechgrwzaglzogwjvqnc" "jzodaqsblcbpcdpxmrtctzginvtkckhqvdplgjvbzrnarcxjrsbcsbfvpylgjznsuhxcx" "oqbpxowmsrgwimxjgyzwwmryqvstwzkglgeezelvpvkwefqdatnddxntikgoqlidfnmdh" "xzevqzlzubvyleeksdirmmttqthhkvfjggznpmarcamacpvwsrnrftzfeyasjpxoevypt" "pdnqokswiondusnuymqwaryrmdgscbnuilxtypuynckancsfnwtgokxhegoifakimxbba" "fkeannglvsxprqzfekdinssqymtfexf"); assert_int_equal(str->len, 1204); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE * 10); assert_null(sb_string_free(str, true)); str = sb_string_new(); str = sb_string_append(str, NULL); assert_non_null(str); assert_string_equal(str->str, ""); assert_int_equal(str->len, 0); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE); assert_null(sb_string_free(str, true)); assert_null(sb_string_append(NULL, "asd")); assert_null(sb_string_append(NULL, NULL)); } static void test_string_append_c(void **state) { sb_string_t *str = sb_string_new(); str = sb_string_append_len(str, "guda", 4); for (int i = 0; i < 600; i++) str = sb_string_append_c(str, 'c'); assert_non_null(str); assert_string_equal(str->str, "gudaccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc" "ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc" "ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc" "ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc" "ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc" "ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc" "ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc" "ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc" "cccccccccccccccccccccccccccccccccccccccccccccccccccc"); assert_int_equal(str->len, 604); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE * 5); assert_null(sb_string_free(str, true)); assert_null(sb_string_append_c(NULL, 0)); } static void test_string_append_printf(void **state) { sb_string_t *str = sb_string_new(); str = sb_string_append_printf(str, "guda: %s %d", "bola", 1); assert_non_null(str); assert_string_equal(str->str, "guda: bola 1"); assert_int_equal(str->len, 12); assert_int_equal(str->allocated_len, SB_STRING_CHUNK_SIZE); assert_null(sb_string_free(str, true)); assert_null(sb_string_append_printf(NULL, "asd")); } static void test_trie_new(void **state) { sb_trie_t *trie = sb_trie_new(free); assert_non_null(trie); assert_null(trie->root); assert_true(trie->free_func == free); sb_trie_free(trie); } static void test_trie_insert(void **state) { sb_trie_t *trie = sb_trie_new(free); sb_trie_insert(trie, "bola", sb_strdup("guda")); assert_true(trie->root->key == 'b'); assert_null(trie->root->data); assert_true(trie->root->child->key == 'o'); assert_null(trie->root->child->data); assert_true(trie->root->child->child->key == 'l'); assert_null(trie->root->child->child->data); assert_true(trie->root->child->child->child->key == 'a'); assert_null(trie->root->child->child->child->data); assert_true(trie->root->child->child->child->child->key == '\0'); assert_string_equal(trie->root->child->child->child->child->data, "guda"); sb_trie_insert(trie, "chu", sb_strdup("nda")); assert_true(trie->root->key == 'b'); assert_null(trie->root->data); assert_true(trie->root->child->key == 'o'); assert_null(trie->root->child->data); assert_true(trie->root->child->child->key == 'l'); assert_null(trie->root->child->child->data); assert_true(trie->root->child->child->child->key == 'a'); assert_null(trie->root->child->child->child->data); assert_true(trie->root->child->child->child->child->key == '\0'); assert_string_equal(trie->root->child->child->child->child->data, "guda"); assert_true(trie->root->next->key == 'c'); assert_null(trie->root->next->data); assert_true(trie->root->next->child->key == 'h'); assert_null(trie->root->next->child->data); assert_true(trie->root->next->child->child->key == 'u'); assert_null(trie->root->next->child->child->data); assert_true(trie->root->next->child->child->child->key == '\0'); assert_string_equal(trie->root->next->child->child->child->data, "nda"); sb_trie_insert(trie, "bote", sb_strdup("aba")); assert_true(trie->root->key == 'b'); assert_null(trie->root->data); assert_true(trie->root->child->key == 'o'); assert_null(trie->root->child->data); assert_true(trie->root->child->child->key == 'l'); assert_null(trie->root->child->child->data); assert_true(trie->root->child->child->child->key == 'a'); assert_null(trie->root->child->child->child->data); assert_true(trie->root->child->child->child->child->key == '\0'); assert_string_equal(trie->root->child->child->child->child->data, "guda"); assert_true(trie->root->next->key == 'c'); assert_null(trie->root->next->data); assert_true(trie->root->next->child->key == 'h'); assert_null(trie->root->next->child->data); assert_true(trie->root->next->child->child->key == 'u'); assert_null(trie->root->next->child->child->data); assert_true(trie->root->next->child->child->child->key == '\0'); assert_string_equal(trie->root->next->child->child->child->data, "nda"); assert_true(trie->root->child->child->next->key == 't'); assert_null(trie->root->child->child->next->data); assert_true(trie->root->child->child->next->child->key == 'e'); assert_null(trie->root->child->child->next->child->data); assert_true(trie->root->child->child->next->child->child->key == '\0'); assert_string_equal(trie->root->child->child->next->child->child->data, "aba"); sb_trie_insert(trie, "bo", sb_strdup("haha")); assert_true(trie->root->key == 'b'); assert_null(trie->root->data); assert_true(trie->root->child->key == 'o'); assert_null(trie->root->child->data); assert_true(trie->root->child->child->key == 'l'); assert_null(trie->root->child->child->data); assert_true(trie->root->child->child->child->key == 'a'); assert_null(trie->root->child->child->child->data); assert_true(trie->root->child->child->child->child->key == '\0'); assert_string_equal(trie->root->child->child->child->child->data, "guda"); assert_true(trie->root->next->key == 'c'); assert_null(trie->root->next->data); assert_true(trie->root->next->child->key == 'h'); assert_null(trie->root->next->child->data); assert_true(trie->root->next->child->child->key == 'u'); assert_null(trie->root->next->child->child->data); assert_true(trie->root->next->child->child->child->key == '\0'); assert_string_equal(trie->root->next->child->child->child->data, "nda"); assert_true(trie->root->child->child->next->key == 't'); assert_null(trie->root->child->child->next->data); assert_true(trie->root->child->child->next->child->key == 'e'); assert_null(trie->root->child->child->next->child->data); assert_true(trie->root->child->child->next->child->child->key == '\0'); assert_string_equal(trie->root->child->child->next->child->child->data, "aba"); assert_true(trie->root->child->child->next->next->key == '\0'); assert_string_equal(trie->root->child->child->next->next->data, "haha"); sb_trie_free(trie); trie = sb_trie_new(free); sb_trie_insert(trie, "chu", sb_strdup("nda")); assert_true(trie->root->key == 'c'); assert_null(trie->root->data); assert_true(trie->root->child->key == 'h'); assert_null(trie->root->child->data); assert_true(trie->root->child->child->key == 'u'); assert_null(trie->root->child->child->data); assert_true(trie->root->child->child->child->key == '\0'); assert_string_equal(trie->root->child->child->child->data, "nda"); sb_trie_insert(trie, "bola", sb_strdup("guda")); assert_true(trie->root->key == 'c'); assert_null(trie->root->data); assert_true(trie->root->child->key == 'h'); assert_null(trie->root->child->data); assert_true(trie->root->child->child->key == 'u'); assert_null(trie->root->child->child->data); assert_true(trie->root->child->child->child->key == '\0'); assert_string_equal(trie->root->child->child->child->data, "nda"); assert_true(trie->root->next->key == 'b'); assert_null(trie->root->next->data); assert_true(trie->root->next->child->key == 'o'); assert_null(trie->root->next->child->data); assert_true(trie->root->next->child->child->key == 'l'); assert_null(trie->root->next->child->child->data); assert_true(trie->root->next->child->child->child->key == 'a'); assert_null(trie->root->next->child->child->child->data); assert_true(trie->root->next->child->child->child->child->key == '\0'); assert_string_equal(trie->root->next->child->child->child->child->data, "guda"); sb_trie_insert(trie, "bote", sb_strdup("aba")); assert_true(trie->root->key == 'c'); assert_null(trie->root->data); assert_true(trie->root->child->key == 'h'); assert_null(trie->root->child->data); assert_true(trie->root->child->child->key == 'u'); assert_null(trie->root->child->child->data); assert_true(trie->root->child->child->child->key == '\0'); assert_string_equal(trie->root->child->child->child->data, "nda"); assert_true(trie->root->next->key == 'b'); assert_null(trie->root->next->data); assert_true(trie->root->next->child->key == 'o'); assert_null(trie->root->next->child->data); assert_true(trie->root->next->child->child->key == 'l'); assert_null(trie->root->next->child->child->data); assert_true(trie->root->next->child->child->child->key == 'a'); assert_null(trie->root->next->child->child->child->data); assert_true(trie->root->next->child->child->child->child->key == '\0'); assert_string_equal(trie->root->next->child->child->child->child->data, "guda"); assert_true(trie->root->next->child->child->next->key == 't'); assert_null(trie->root->next->child->child->next->data); assert_true(trie->root->next->child->child->next->child->key == 'e'); assert_null(trie->root->next->child->child->next->child->data); assert_true(trie->root->next->child->child->next->child->child->key == '\0'); assert_string_equal(trie->root->next->child->child->next->child->child->data, "aba"); sb_trie_insert(trie, "bo", sb_strdup("haha")); assert_true(trie->root->key == 'c'); assert_null(trie->root->data); assert_true(trie->root->child->key == 'h'); assert_null(trie->root->child->data); assert_true(trie->root->child->child->key == 'u'); assert_null(trie->root->child->child->data); assert_true(trie->root->child->child->child->key == '\0'); assert_string_equal(trie->root->child->child->child->data, "nda"); assert_true(trie->root->next->key == 'b'); assert_null(trie->root->next->data); assert_true(trie->root->next->child->key == 'o'); assert_null(trie->root->next->child->data); assert_true(trie->root->next->child->child->key == 'l'); assert_null(trie->root->next->child->child->data); assert_true(trie->root->next->child->child->child->key == 'a'); assert_null(trie->root->next->child->child->child->data); assert_true(trie->root->next->child->child->child->child->key == '\0'); assert_string_equal(trie->root->next->child->child->child->child->data, "guda"); assert_true(trie->root->next->child->child->next->key == 't'); assert_null(trie->root->next->child->child->next->data); assert_true(trie->root->next->child->child->next->child->key == 'e'); assert_null(trie->root->next->child->child->next->child->data); assert_true(trie->root->next->child->child->next->child->child->key == '\0'); assert_string_equal(trie->root->next->child->child->next->child->child->data, "aba"); assert_true(trie->root->next->child->child->next->next->key == '\0'); assert_string_equal(trie->root->next->child->child->next->next->data, "haha"); sb_trie_free(trie); } static void test_trie_insert_duplicated(void **state) { sb_trie_t *trie = sb_trie_new(free); sb_trie_insert(trie, "bola", sb_strdup("guda")); assert_true(trie->root->key == 'b'); assert_null(trie->root->data); assert_true(trie->root->child->key == 'o'); assert_null(trie->root->child->data); assert_true(trie->root->child->child->key == 'l'); assert_null(trie->root->child->child->data); assert_true(trie->root->child->child->child->key == 'a'); assert_null(trie->root->child->child->child->data); assert_true(trie->root->child->child->child->child->key == '\0'); assert_string_equal(trie->root->child->child->child->child->data, "guda"); sb_trie_insert(trie, "bola", sb_strdup("asdf")); assert_true(trie->root->key == 'b'); assert_null(trie->root->data); assert_true(trie->root->child->key == 'o'); assert_null(trie->root->child->data); assert_true(trie->root->child->child->key == 'l'); assert_null(trie->root->child->child->data); assert_true(trie->root->child->child->child->key == 'a'); assert_null(trie->root->child->child->child->data); assert_true(trie->root->child->child->child->child->key == '\0'); assert_string_equal(trie->root->child->child->child->child->data, "asdf"); sb_trie_free(trie); trie = NULL; sb_trie_insert(trie, "bola", NULL); assert_null(trie); } static void test_trie_keep_data(void **state) { sb_trie_t *trie = sb_trie_new(NULL); char *t1 = "guda"; char *t2 = "nda"; char *t3 = "aba"; char *t4 = "haha"; sb_trie_insert(trie, "bola", t1); sb_trie_insert(trie, "chu", t2); sb_trie_insert(trie, "bote", t3); sb_trie_insert(trie, "bo", t4); sb_trie_free(trie); assert_string_equal(t1, "guda"); assert_string_equal(t2, "nda"); assert_string_equal(t3, "aba"); assert_string_equal(t4, "haha"); } static void test_trie_lookup(void **state) { sb_trie_t *trie = sb_trie_new(free); sb_trie_insert(trie, "bola", sb_strdup("guda")); sb_trie_insert(trie, "chu", sb_strdup("nda")); sb_trie_insert(trie, "bote", sb_strdup("aba")); sb_trie_insert(trie, "bo", sb_strdup("haha")); assert_string_equal(sb_trie_lookup(trie, "bola"), "guda"); assert_string_equal(sb_trie_lookup(trie, "chu"), "nda"); assert_string_equal(sb_trie_lookup(trie, "bote"), "aba"); assert_string_equal(sb_trie_lookup(trie, "bo"), "haha"); assert_null(sb_trie_lookup(trie, "arcoiro")); sb_trie_free(trie); trie = sb_trie_new(free); sb_trie_insert(trie, "chu", sb_strdup("nda")); sb_trie_insert(trie, "bola", sb_strdup("guda")); sb_trie_insert(trie, "bote", sb_strdup("aba")); sb_trie_insert(trie, "bo", sb_strdup("haha")); sb_trie_insert(trie, "copa", sb_strdup("bu")); sb_trie_insert(trie, "b", sb_strdup("c")); sb_trie_insert(trie, "test", sb_strdup("asd")); assert_string_equal(sb_trie_lookup(trie, "bola"), "guda"); assert_string_equal(sb_trie_lookup(trie, "chu"), "nda"); assert_string_equal(sb_trie_lookup(trie, "bote"), "aba"); assert_string_equal(sb_trie_lookup(trie, "bo"), "haha"); assert_null(sb_trie_lookup(trie, "arcoiro")); sb_trie_free(trie); assert_null(sb_trie_lookup(NULL, "bola")); } static void test_trie_size(void **state) { sb_trie_t *trie = sb_trie_new(free); sb_trie_insert(trie, "bola", sb_strdup("guda")); sb_trie_insert(trie, "chu", sb_strdup("nda")); sb_trie_insert(trie, "bote", sb_strdup("aba")); sb_trie_insert(trie, "bo", sb_strdup("haha")); assert_int_equal(sb_trie_size(trie), 4); assert_int_equal(sb_trie_size(NULL), 0); sb_trie_free(trie); trie = sb_trie_new(free); sb_trie_insert(trie, "chu", sb_strdup("nda")); sb_trie_insert(trie, "bola", sb_strdup("guda")); sb_trie_insert(trie, "bote", sb_strdup("aba")); sb_trie_insert(trie, "bo", sb_strdup("haha")); sb_trie_insert(trie, "copa", sb_strdup("bu")); sb_trie_insert(trie, "b", sb_strdup("c")); sb_trie_insert(trie, "test", sb_strdup("asd")); assert_int_equal(sb_trie_size(trie), 7); assert_int_equal(sb_trie_size(NULL), 0); sb_trie_free(trie); } static unsigned int counter; static char *expected_keys[] = {"chu", "copa", "bola", "bote", "bo", "b", "test"}; static char *expected_datas[] = {"nda", "bu", "guda", "aba", "haha", "c", "asd"}; static void mock_foreach(const char *key, void *data, void *user_data) { assert_string_equal(user_data, "foo"); assert_string_equal(key, expected_keys[counter]); assert_string_equal((char*) data, expected_datas[counter++]); } static void test_trie_foreach(void **state) { sb_trie_t *trie = sb_trie_new(free); sb_trie_insert(trie, "chu", sb_strdup("nda")); sb_trie_insert(trie, "bola", sb_strdup("guda")); sb_trie_insert(trie, "bote", sb_strdup("aba")); sb_trie_insert(trie, "bo", sb_strdup("haha")); sb_trie_insert(trie, "copa", sb_strdup("bu")); sb_trie_insert(trie, "b", sb_strdup("c")); sb_trie_insert(trie, "test", sb_strdup("asd")); counter = 0; sb_trie_foreach(trie, mock_foreach, "foo"); sb_trie_foreach(NULL, mock_foreach, "foo"); sb_trie_foreach(trie, NULL, "foo"); sb_trie_foreach(NULL, NULL, "foo"); sb_trie_free(trie); } int main(void) { const UnitTest tests[] = { // slist unit_test(test_slist_append), unit_test(test_slist_prepend), unit_test(test_slist_free), unit_test(test_slist_length), // strfuncs unit_test(test_strdup), unit_test(test_strndup), unit_test(test_strdup_printf), unit_test(test_str_starts_with), unit_test(test_str_ends_with), unit_test(test_str_lstrip), unit_test(test_str_rstrip), unit_test(test_str_strip), unit_test(test_str_split), unit_test(test_str_replace), unit_test(test_strv_join), unit_test(test_strv_length), // string unit_test(test_string_new), unit_test(test_string_free), unit_test(test_string_dup), unit_test(test_string_append_len), unit_test(test_string_append), unit_test(test_string_append_c), unit_test(test_string_append_printf), // trie unit_test(test_trie_new), unit_test(test_trie_insert), unit_test(test_trie_insert_duplicated), unit_test(test_trie_keep_data), unit_test(test_trie_lookup), unit_test(test_trie_size), unit_test(test_trie_foreach), }; return run_tests(tests); }