From fb27e8ed5030e6b5aa8df33cc4d347eacaef76ba Mon Sep 17 00:00:00 2001 From: "Rafael G. Martins" Date: Fri, 24 Feb 2017 23:15:28 +0100 Subject: make: parse runserver arguments from cli, instead of env this is some over-optimized parser, to celebrate #cloudbleed :D --- tests/blogc-make/check_rules.c | 104 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 104 insertions(+) create mode 100644 tests/blogc-make/check_rules.c (limited to 'tests/blogc-make') diff --git a/tests/blogc-make/check_rules.c b/tests/blogc-make/check_rules.c new file mode 100644 index 0000000..0ef8be7 --- /dev/null +++ b/tests/blogc-make/check_rules.c @@ -0,0 +1,104 @@ +/* + * blogc: A blog compiler. + * Copyright (C) 2015-2017 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 + +#include "../../src/blogc-make/rules.h" +#include "../../src/common/utils.h" + + +static void +test_rule_parse_args(void **state) +{ + bc_trie_t *t = bm_rule_parse_args("bola:foo=" + 4); + assert_non_null(t); + assert_int_equal(bc_trie_size(t), 1); + assert_string_equal(bc_trie_lookup(t, "foo"), ""); + bc_trie_free(t); + t = bm_rule_parse_args("bola:foo=bar" + 4); + assert_non_null(t); + assert_int_equal(bc_trie_size(t), 1); + assert_string_equal(bc_trie_lookup(t, "foo"), "bar"); + bc_trie_free(t); + t = bm_rule_parse_args("bola:foo=,baz=lol" + 4); + assert_non_null(t); + assert_int_equal(bc_trie_size(t), 2); + assert_string_equal(bc_trie_lookup(t, "foo"), ""); + assert_string_equal(bc_trie_lookup(t, "baz"), "lol"); + bc_trie_free(t); + t = bm_rule_parse_args("bola:foo=bar,baz=" + 4); + assert_non_null(t); + assert_int_equal(bc_trie_size(t), 2); + assert_string_equal(bc_trie_lookup(t, "foo"), "bar"); + assert_string_equal(bc_trie_lookup(t, "baz"), ""); + bc_trie_free(t); + t = bm_rule_parse_args("bola:foo=bar,baz=lol" + 4); + assert_non_null(t); + assert_int_equal(bc_trie_size(t), 2); + assert_string_equal(bc_trie_lookup(t, "foo"), "bar"); + assert_string_equal(bc_trie_lookup(t, "baz"), "lol"); + bc_trie_free(t); + t = bm_rule_parse_args("bola:foo=,baz=lol,asd=qwe" + 4); + assert_non_null(t); + assert_int_equal(bc_trie_size(t), 3); + assert_string_equal(bc_trie_lookup(t, "foo"), ""); + assert_string_equal(bc_trie_lookup(t, "baz"), "lol"); + assert_string_equal(bc_trie_lookup(t, "asd"), "qwe"); + bc_trie_free(t); + t = bm_rule_parse_args("bola:foo=bar,baz=,asd=qwe" + 4); + assert_non_null(t); + assert_int_equal(bc_trie_size(t), 3); + assert_string_equal(bc_trie_lookup(t, "foo"), "bar"); + assert_string_equal(bc_trie_lookup(t, "baz"), ""); + assert_string_equal(bc_trie_lookup(t, "asd"), "qwe"); + bc_trie_free(t); + t = bm_rule_parse_args("bola:foo=bar,baz=lol,asd=" + 4); + assert_non_null(t); + assert_int_equal(bc_trie_size(t), 3); + assert_string_equal(bc_trie_lookup(t, "foo"), "bar"); + assert_string_equal(bc_trie_lookup(t, "baz"), "lol"); + assert_string_equal(bc_trie_lookup(t, "asd"), ""); + bc_trie_free(t); + t = bm_rule_parse_args("bola:foo=bar,baz=lol,asd=qwe" + 4); + assert_non_null(t); + assert_int_equal(bc_trie_size(t), 3); + assert_string_equal(bc_trie_lookup(t, "foo"), "bar"); + assert_string_equal(bc_trie_lookup(t, "baz"), "lol"); + assert_string_equal(bc_trie_lookup(t, "asd"), "qwe"); + bc_trie_free(t); +} + + +static void +test_rule_parse_args_error(void **state) +{ + assert_null(bm_rule_parse_args(NULL)); + assert_null(bm_rule_parse_args("bola" + 4)); + assert_null(bm_rule_parse_args("bola:" + 4)); + assert_null(bm_rule_parse_args("bola:asd" + 4)); + assert_null(bm_rule_parse_args("bola:asd=foo,lol" + 4)); + assert_null(bm_rule_parse_args("bola:asd=foo,qwe=bar,lol" + 4)); + assert_null(bm_rule_parse_args("bolaasd" + 4)); +} + + +int +main(void) +{ + const UnitTest tests[] = { + unit_test(test_rule_parse_args), + unit_test(test_rule_parse_args_error), + }; + return run_tests(tests); +} -- cgit v1.2.3-18-g5258