Add test for \r in directory parsing

This commit is contained in:
Saksham Mittal 2023-03-19 08:27:42 +05:30
parent 447775a5e0
commit bbb3396d79
No known key found for this signature in database
GPG Key ID: F91B5B3C19C5F58C

View File

@ -253,6 +253,32 @@ test_parsecommon_get_next_token_success(void *arg)
return;
}
static void
test_parsecommon_get_next_token_carriage_return(void *arg)
{
memarea_t *area = memarea_new();
const char *str = "uptime 1024\r";
const char *end = str + strlen(str);
const char **s = &str;
token_rule_t table = T01("uptime", K_UPTIME, GE(1), NO_OBJ);
(void)arg;
directory_token_t *token = get_next_token(area, s, end, &table);
tt_int_op(token->tp, OP_EQ, K_UPTIME);
tt_int_op(token->n_args, OP_EQ, 1);
tt_str_op(*(token->args), OP_EQ, "1024");
tt_assert(!token->object_type);
tt_int_op(token->object_size, OP_EQ, 0);
tt_assert(!token->object_body);
tt_ptr_op(*s, OP_EQ, end);
done:
memarea_drop_all(area);
return;
}
static void
test_parsecommon_get_next_token_concat_args(void *arg)
{
@ -571,6 +597,7 @@ test_parsecommon_get_next_token_err_bad_base64(void *arg)
struct testcase_t parsecommon_tests[] = {
PARSECOMMON_TEST(tokenize_string_null),
PARSECOMMON_TEST(get_next_token_carriage_return),
PARSECOMMON_TEST(tokenize_string_multiple_lines),
PARSECOMMON_TEST(tokenize_string_min_cnt),
PARSECOMMON_TEST(tokenize_string_max_cnt),