diff options
author | Danny van Kooten <dannyvankooten@users.noreply.github.com> | 2020-03-17 13:55:23 +0100 |
---|---|---|
committer | Danny van Kooten <dannyvankooten@users.noreply.github.com> | 2020-03-17 13:55:23 +0100 |
commit | 4624d6d369e8e5ce9a887acfe27be90fedf3d1ed (patch) | |
tree | cbfcb2447a01ce09c97f9ee0e126478694d3f9aa /tests | |
parent | 2b2ddbdb94334d586cab8e4737062bb2e794d102 (diff) | |
download | unja-4624d6d369e8e5ce9a887acfe27be90fedf3d1ed.tar.gz unja-4624d6d369e8e5ce9a887acfe27be90fedf3d1ed.zip |
add support for {% else %} statements
Diffstat (limited to 'tests')
-rw-r--r-- | tests/test_template.c | 36 |
1 files changed, 30 insertions, 6 deletions
diff --git a/tests/test_template.c b/tests/test_template.c index 329075e..0567995 100644 --- a/tests/test_template.c +++ b/tests/test_template.c @@ -151,18 +151,42 @@ TEST(comments) { free(output); } - TEST(if_block) { struct { char *input; char *expected_output; } tests[] = { - {"{% if 5 > 10 %}OK{% endif %}.", "."}, - {"{% if 10 > 5 %}OK{% endif %}.", "OK."}, - {"{% if foobar %}OK{% endif %}.", "."}, - {"{% if name %}OK{% endif %}.", "OK."}, - {"{% if age > 10 %}OK{% endif %}.", "OK."}, + {"{% if 5 > 10 %}1{% endif %}.", "."}, + {"{% if 10 > 5 %}1{% endif %}.", "1."}, + {"{% if foobar %}1{% endif %}.", "."}, + {"{% if name %}1{% endif %}.", "1."}, + {"{% if age > 10 %}1{% endif %}.", "1."}, + }; + + struct hashmap *ctx = hashmap_new(); + hashmap_insert(ctx, "name", "Danny"); + hashmap_insert(ctx, "age", "29"); + for (int i=0; i < ARRAY_SIZE(tests); i++) { + char *output = template(tests[i].input, ctx); + assert_str(output, tests[i].expected_output); + free(output); + } + + hashmap_free(ctx); +} + +TEST(if_else_block) { + + struct { + char *input; + char *expected_output; + } tests[] = { + {"{% if 5 > 10 %}1{% else %}2{% endif %}", "2"}, + {"{% if 10 > 5 %}1{% else %}2{% endif %}", "1"}, + {"{% if foobar %}1{% else %}2{% endif %}", "2"}, + {"{% if name %}1{% else %}2{% endif %}", "1"}, + {"{% if age < 10 %}1{% else %}2{% endif %}", "2"}, }; struct hashmap *ctx = hashmap_new(); |