diff options
Diffstat (limited to 'tests/blogc/check_source_parser.c')
-rw-r--r-- | tests/blogc/check_source_parser.c | 761 |
1 files changed, 0 insertions, 761 deletions
diff --git a/tests/blogc/check_source_parser.c b/tests/blogc/check_source_parser.c deleted file mode 100644 index 822133c..0000000 --- a/tests/blogc/check_source_parser.c +++ /dev/null @@ -1,761 +0,0 @@ -/* - * blogc: A blog compiler. - * Copyright (C) 2014-2020 Rafael G. Martins <rafael@rafaelmartins.eng.br> - * - * This program can be distributed under the terms of the BSD License. - * See the file LICENSE. - */ - -#include <stdarg.h> -#include <stddef.h> -#include <setjmp.h> -#include <cmocka.h> -#include <string.h> -#include "../../src/common/error.h" -#include "../../src/common/utils.h" -#include "../../src/blogc/source-parser.h" - - -static void -test_source_parse(void **state) -{ - const char *a = - "VAR1: asd asd\n" - "VAR2: 123chunda\n" - "----------\n" - "# This is a test\n" - "\n" - "bola\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(err); - assert_non_null(source); - assert_int_equal(bc_trie_size(source), 7); - assert_string_equal(bc_trie_lookup(source, "VAR1"), "asd asd"); - assert_string_equal(bc_trie_lookup(source, "VAR2"), "123chunda"); - assert_string_equal(bc_trie_lookup(source, "EXCERPT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\n" - "<p>bola</p>\n"); - assert_string_equal(bc_trie_lookup(source, "CONTENT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\n" - "<p>bola</p>\n"); - assert_string_equal(bc_trie_lookup(source, "RAW_CONTENT"), - "# This is a test\n" - "\n" - "bola\n"); - assert_string_equal(bc_trie_lookup(source, "FIRST_HEADER"), "This is a test"); - assert_string_equal(bc_trie_lookup(source, "DESCRIPTION"), "bola"); - assert_null(bc_trie_lookup(source, "TOCTREE")); - bc_trie_free(source); -} - - -static void -test_source_parse_crlf(void **state) -{ - const char *a = - "VAR1: asd asd\r\n" - "VAR2: 123chunda\r\n" - "----------\r\n" - "# This is a test\r\n" - "\r\n" - "bola\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 1, &err); - assert_null(err); - assert_non_null(source); - assert_int_equal(bc_trie_size(source), 8); - assert_string_equal(bc_trie_lookup(source, "VAR1"), "asd asd"); - assert_string_equal(bc_trie_lookup(source, "VAR2"), "123chunda"); - assert_string_equal(bc_trie_lookup(source, "EXCERPT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\r\n" - "<p>bola</p>\r\n"); - assert_string_equal(bc_trie_lookup(source, "CONTENT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\r\n" - "<p>bola</p>\r\n"); - assert_string_equal(bc_trie_lookup(source, "RAW_CONTENT"), - "# This is a test\r\n" - "\r\n" - "bola\r\n"); - assert_string_equal(bc_trie_lookup(source, "FIRST_HEADER"), "This is a test"); - assert_string_equal(bc_trie_lookup(source, "DESCRIPTION"), "bola"); - assert_string_equal(bc_trie_lookup(source, "TOCTREE"), - "<ul>\r\n" - " <li><a href=\"#this-is-a-test\">This is a test</a></li>\r\n" - "</ul>\r\n"); - bc_trie_free(source); -} - - -static void -test_source_parse_with_spaces(void **state) -{ - const char *a = - "\n \n" - "VAR1: chunda \t \n" - "\n\n" - "BOLA: guda\n" - "----------\n" - "# This is a test\n" - "\n" - "bola\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), -1, &err); - assert_null(err); - assert_non_null(source); - assert_int_equal(bc_trie_size(source), 8); - assert_string_equal(bc_trie_lookup(source, "VAR1"), "chunda"); - assert_string_equal(bc_trie_lookup(source, "BOLA"), "guda"); - assert_string_equal(bc_trie_lookup(source, "EXCERPT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\n" - "<p>bola</p>\n"); - assert_string_equal(bc_trie_lookup(source, "CONTENT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\n" - "<p>bola</p>\n"); - assert_string_equal(bc_trie_lookup(source, "RAW_CONTENT"), - "# This is a test\n" - "\n" - "bola\n"); - assert_string_equal(bc_trie_lookup(source, "FIRST_HEADER"), "This is a test"); - assert_string_equal(bc_trie_lookup(source, "DESCRIPTION"), "bola"); - assert_string_equal(bc_trie_lookup(source, "TOCTREE"), - "<ul>\n" - " <li><a href=\"#this-is-a-test\">This is a test</a></li>\n" - "</ul>\n"); - bc_trie_free(source); -} - - -static void -test_source_parse_with_excerpt(void **state) -{ - const char *a = - "VAR1: asd asd\n" - "VAR2: 123chunda\n" - "----------\n" - "# This is a test\n" - "\n" - "bola\n" - "\n" - "...\n" - "\n" - "guda\n" - "yay"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(err); - assert_non_null(source); - assert_int_equal(bc_trie_size(source), 7); - assert_string_equal(bc_trie_lookup(source, "VAR1"), "asd asd"); - assert_string_equal(bc_trie_lookup(source, "VAR2"), "123chunda"); - assert_string_equal(bc_trie_lookup(source, "EXCERPT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\n" - "<p>bola</p>\n"); - assert_string_equal(bc_trie_lookup(source, "CONTENT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\n" - "<p>bola</p>\n" - "<p>guda\n" - "yay</p>\n"); - assert_string_equal(bc_trie_lookup(source, "RAW_CONTENT"), - "# This is a test\n" - "\n" - "bola\n" - "\n" - "...\n" - "\n" - "guda\n" - "yay"); - assert_string_equal(bc_trie_lookup(source, "FIRST_HEADER"), "This is a test"); - assert_string_equal(bc_trie_lookup(source, "DESCRIPTION"), "bola"); - assert_null(bc_trie_lookup(source, "TOCTREE")); - bc_trie_free(source); -} - - -static void -test_source_parse_with_first_header(void **state) -{ - const char *a = - "VAR1: asd asd\n" - "VAR2: 123chunda\n" - "FIRST_HEADER: THIS IS CHUNDA!\n" - "----------\n" - "# This is a test\n" - "\n" - "bola\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(err); - assert_non_null(source); - assert_int_equal(bc_trie_size(source), 7); - assert_string_equal(bc_trie_lookup(source, "VAR1"), "asd asd"); - assert_string_equal(bc_trie_lookup(source, "VAR2"), "123chunda"); - assert_string_equal(bc_trie_lookup(source, "EXCERPT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\n" - "<p>bola</p>\n"); - assert_string_equal(bc_trie_lookup(source, "CONTENT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\n" - "<p>bola</p>\n"); - assert_string_equal(bc_trie_lookup(source, "RAW_CONTENT"), - "# This is a test\n" - "\n" - "bola\n"); - assert_string_equal(bc_trie_lookup(source, "FIRST_HEADER"), "THIS IS CHUNDA!"); - assert_string_equal(bc_trie_lookup(source, "DESCRIPTION"), "bola"); - assert_null(bc_trie_lookup(source, "TOCTREE")); - bc_trie_free(source); -} - - -static void -test_source_parse_with_description(void **state) -{ - const char *a = - "VAR1: asd asd\n" - "VAR2: 123chunda\n" - "DESCRIPTION: huehuehuebrbr\n" - "----------\n" - "# This is a test\n" - "\n" - "bola\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(err); - assert_non_null(source); - assert_int_equal(bc_trie_size(source), 7); - assert_string_equal(bc_trie_lookup(source, "VAR1"), "asd asd"); - assert_string_equal(bc_trie_lookup(source, "VAR2"), "123chunda"); - assert_string_equal(bc_trie_lookup(source, "EXCERPT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\n" - "<p>bola</p>\n"); - assert_string_equal(bc_trie_lookup(source, "CONTENT"), - "<h1 id=\"this-is-a-test\">This is a test</h1>\n" - "<p>bola</p>\n"); - assert_string_equal(bc_trie_lookup(source, "RAW_CONTENT"), - "# This is a test\n" - "\n" - "bola\n"); - assert_string_equal(bc_trie_lookup(source, "FIRST_HEADER"), "This is a test"); - assert_string_equal(bc_trie_lookup(source, "DESCRIPTION"), "huehuehuebrbr"); - assert_null(bc_trie_lookup(source, "TOCTREE")); - bc_trie_free(source); -} - - -static void -test_source_parse_with_toctree(void **state) -{ - const char *a = - "VAR1: asd asd\n" - "VAR2: 123chunda\n" - "----------\n" - "### asd\n" - "### qwe\n" - "## zxc\n" - "### rty\n" - "#### bnm\n" - "### asd\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), -1, &err); - assert_null(err); - assert_non_null(source); - assert_int_equal(bc_trie_size(source), 7); - assert_string_equal(bc_trie_lookup(source, "VAR1"), "asd asd"); - assert_string_equal(bc_trie_lookup(source, "VAR2"), "123chunda"); - assert_string_equal(bc_trie_lookup(source, "EXCERPT"), - "<h3 id=\"asd\">asd</h3>\n" - "<h3 id=\"qwe\">qwe</h3>\n" - "<h2 id=\"zxc\">zxc</h2>\n" - "<h3 id=\"rty\">rty</h3>\n" - "<h4 id=\"bnm\">bnm</h4>\n" - "<h3 id=\"asd\">asd</h3>\n"); - assert_string_equal(bc_trie_lookup(source, "CONTENT"), - "<h3 id=\"asd\">asd</h3>\n" - "<h3 id=\"qwe\">qwe</h3>\n" - "<h2 id=\"zxc\">zxc</h2>\n" - "<h3 id=\"rty\">rty</h3>\n" - "<h4 id=\"bnm\">bnm</h4>\n" - "<h3 id=\"asd\">asd</h3>\n"); - assert_string_equal(bc_trie_lookup(source, "RAW_CONTENT"), - "### asd\n" - "### qwe\n" - "## zxc\n" - "### rty\n" - "#### bnm\n" - "### asd\n"); - assert_string_equal(bc_trie_lookup(source, "FIRST_HEADER"), "asd"); - assert_string_equal(bc_trie_lookup(source, "TOCTREE"), - "<ul>\n" - " <ul>\n" - " <li><a href=\"#asd\">asd</a></li>\n" - " <li><a href=\"#qwe\">qwe</a></li>\n" - " </ul>\n" - " <li><a href=\"#zxc\">zxc</a></li>\n" - " <ul>\n" - " <li><a href=\"#rty\">rty</a></li>\n" - " <ul>\n" - " <li><a href=\"#bnm\">bnm</a></li>\n" - " </ul>\n" - " <li><a href=\"#asd\">asd</a></li>\n" - " </ul>\n" - "</ul>\n"); - bc_trie_free(source); -} - - -static void -test_source_parse_with_toctree_noheader(void **state) -{ - const char *a = - "VAR1: asd asd\n" - "VAR2: 123chunda\n" - "----------\n" - "asd\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), -1, &err); - assert_null(err); - assert_non_null(source); - assert_int_equal(bc_trie_size(source), 6); - assert_string_equal(bc_trie_lookup(source, "VAR1"), "asd asd"); - assert_string_equal(bc_trie_lookup(source, "VAR2"), "123chunda"); - assert_string_equal(bc_trie_lookup(source, "EXCERPT"), - "<p>asd</p>\n"); - assert_string_equal(bc_trie_lookup(source, "CONTENT"), - "<p>asd</p>\n"); - assert_string_equal(bc_trie_lookup(source, "RAW_CONTENT"), - "asd\n"); - assert_null(bc_trie_lookup(source, "FIRST_HEADER")); - assert_null(bc_trie_lookup(source, "TOCTREE")); - bc_trie_free(source); -} - - -static void -test_source_parse_with_toctree_maxdepth1(void **state) -{ - const char *a = - "VAR1: asd asd\n" - "VAR2: 123chunda\n" - "----------\n" - "### asd\n" - "### qwe\n" - "## zxc\n" - "### rty\n" - "#### bnm\n" - "### asd\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 1, &err); - assert_null(err); - assert_non_null(source); - assert_int_equal(bc_trie_size(source), 7); - assert_string_equal(bc_trie_lookup(source, "VAR1"), "asd asd"); - assert_string_equal(bc_trie_lookup(source, "VAR2"), "123chunda"); - assert_string_equal(bc_trie_lookup(source, "EXCERPT"), - "<h3 id=\"asd\">asd</h3>\n" - "<h3 id=\"qwe\">qwe</h3>\n" - "<h2 id=\"zxc\">zxc</h2>\n" - "<h3 id=\"rty\">rty</h3>\n" - "<h4 id=\"bnm\">bnm</h4>\n" - "<h3 id=\"asd\">asd</h3>\n"); - assert_string_equal(bc_trie_lookup(source, "CONTENT"), - "<h3 id=\"asd\">asd</h3>\n" - "<h3 id=\"qwe\">qwe</h3>\n" - "<h2 id=\"zxc\">zxc</h2>\n" - "<h3 id=\"rty\">rty</h3>\n" - "<h4 id=\"bnm\">bnm</h4>\n" - "<h3 id=\"asd\">asd</h3>\n"); - assert_string_equal(bc_trie_lookup(source, "RAW_CONTENT"), - "### asd\n" - "### qwe\n" - "## zxc\n" - "### rty\n" - "#### bnm\n" - "### asd\n"); - assert_string_equal(bc_trie_lookup(source, "FIRST_HEADER"), "asd"); - assert_string_equal(bc_trie_lookup(source, "TOCTREE"), - "<ul>\n" - " <li><a href=\"#zxc\">zxc</a></li>\n" - "</ul>\n"); - bc_trie_free(source); -} - - -static void -test_source_parse_with_toctree_maxdepth_invalid(void **state) -{ - const char *a = - "VAR1: asd asd\n" - "VAR2: 123chunda\n" - "TOCTREE_MAXDEPTH: bola\n" - "----------\n" - "### asd\n" - "### qwe\n" - "## zxc\n" - "### rty\n" - "#### bnm\n" - "### asd\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 1, &err); - assert_non_null(err); - assert_null(source); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "Invalid value for 'TOCTREE_MAXDEPTH' variable: bola.\n" - "Error occurred near line 10, position 8: ### asd"); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_empty(void **state) -{ - const char *a = ""; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, "Your source file is empty."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_invalid_key(void **state) -{ - const char *a = "bola: guda"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "Can't find a configuration key or the content separator.\n" - "Error occurred near line 1, position 1: bola: guda"); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_no_key(void **state) -{ - const char *a = "BOLa"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "Invalid configuration key.\n" - "Error occurred near line 1, position 4: BOLa"); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_no_key2(void **state) -{ - const char *a = "BOLA"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "Your last configuration key is missing ':' and the value\n" - "Error occurred near line 1, position 5: BOLA"); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_no_value(void **state) -{ - // this is a special case, not an error - const char *a = "BOLA:\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_non_null(source); - assert_null(err); - assert_string_equal(bc_trie_lookup(source, "BOLA"), ""); - assert_null(bc_trie_lookup(source, "TOCTREE")); - bc_trie_free(source); -} - - -static void -test_source_parse_config_no_value2(void **state) -{ - const char *a = "BOLA:"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "Configuration value not provided for 'BOLA'.\n" - "Error occurred near line 1, position 6: BOLA:"); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name(void **state) -{ - const char *a = "FILENAME: asd\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'FILENAME' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name2(void **state) -{ - const char *a = "CONTENT: asd\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'CONTENT' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name3(void **state) -{ - const char *a = "DATE_FORMATTED: asd\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'DATE_FORMATTED' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name4(void **state) -{ - const char *a = "DATE_FIRST_FORMATTED: asd\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'DATE_FIRST_FORMATTED' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name5(void **state) -{ - const char *a = "DATE_LAST_FORMATTED: asd\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'DATE_LAST_FORMATTED' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name6(void **state) -{ - const char *a = "PAGE_FIRST: asd\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'PAGE_FIRST' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name7(void **state) -{ - const char *a = "PAGE_PREVIOUS: asd\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'PAGE_PREVIOUS' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name8(void **state) -{ - const char *a = "PAGE_CURRENT: asd\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'PAGE_CURRENT' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name9(void **state) -{ - const char *a = "PAGE_NEXT: asd\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'PAGE_NEXT' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name10(void **state) -{ - const char *a = "PAGE_LAST: asd\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'PAGE_LAST' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_reserved_name11(void **state) -{ - const char *a = "BLOGC_VERSION: 1.0\r\n"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "'BLOGC_VERSION' variable is forbidden in source files. It will be set " - "for you by the compiler."); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_config_value_no_line_ending(void **state) -{ - const char *a = "BOLA: asd"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "No line ending after the configuration value for 'BOLA'.\n" - "Error occurred near line 1, position 10: BOLA: asd"); - bc_error_free(err); - bc_trie_free(source); -} - - -static void -test_source_parse_invalid_separator(void **state) -{ - const char *a = "BOLA: asd\n---#"; - bc_error_t *err = NULL; - bc_trie_t *source = blogc_source_parse(a, strlen(a), 0, &err); - assert_null(source); - assert_non_null(err); - assert_int_equal(err->type, BLOGC_ERROR_SOURCE_PARSER); - assert_string_equal(err->msg, - "Invalid content separator. Must be more than one '-' characters.\n" - "Error occurred near line 2, position 4: ---#"); - bc_error_free(err); - bc_trie_free(source); -} - - -int -main(void) -{ - const struct CMUnitTest tests[] = { - cmocka_unit_test(test_source_parse), - cmocka_unit_test(test_source_parse_crlf), - cmocka_unit_test(test_source_parse_with_spaces), - cmocka_unit_test(test_source_parse_with_excerpt), - cmocka_unit_test(test_source_parse_with_first_header), - cmocka_unit_test(test_source_parse_with_description), - cmocka_unit_test(test_source_parse_with_toctree), - cmocka_unit_test(test_source_parse_with_toctree_noheader), - cmocka_unit_test(test_source_parse_with_toctree_maxdepth1), - cmocka_unit_test(test_source_parse_with_toctree_maxdepth_invalid), - cmocka_unit_test(test_source_parse_config_empty), - cmocka_unit_test(test_source_parse_config_invalid_key), - cmocka_unit_test(test_source_parse_config_no_key), - cmocka_unit_test(test_source_parse_config_no_key2), - cmocka_unit_test(test_source_parse_config_no_value), - cmocka_unit_test(test_source_parse_config_no_value2), - cmocka_unit_test(test_source_parse_config_reserved_name), - cmocka_unit_test(test_source_parse_config_reserved_name2), - cmocka_unit_test(test_source_parse_config_reserved_name3), - cmocka_unit_test(test_source_parse_config_reserved_name4), - cmocka_unit_test(test_source_parse_config_reserved_name5), - cmocka_unit_test(test_source_parse_config_reserved_name6), - cmocka_unit_test(test_source_parse_config_reserved_name7), - cmocka_unit_test(test_source_parse_config_reserved_name8), - cmocka_unit_test(test_source_parse_config_reserved_name9), - cmocka_unit_test(test_source_parse_config_reserved_name10), - cmocka_unit_test(test_source_parse_config_reserved_name11), - cmocka_unit_test(test_source_parse_config_value_no_line_ending), - cmocka_unit_test(test_source_parse_invalid_separator), - }; - return cmocka_run_group_tests(tests, NULL, NULL); -} |