aboutsummaryrefslogtreecommitdiff
path: root/src/test/test_parsecommon.c
diff options
context:
space:
mode:
authorSaksham Mittal <gotlouemail@gmail.com>2023-03-27 20:22:24 +0530
committerSaksham Mittal <gotlouemail@gmail.com>2023-03-27 20:22:24 +0530
commitc5889d3f1584e60633f4dfec6e63f6dc471915e2 (patch)
treeeb769e542bdc8c7406b8ab776547fcb6aad29ecb /src/test/test_parsecommon.c
parentbbb3396d7925e5d08617f31340514f4d7f2684b8 (diff)
downloadtor-c5889d3f1584e60633f4dfec6e63f6dc471915e2.tar.gz
tor-c5889d3f1584e60633f4dfec6e63f6dc471915e2.zip
Test \r more effectively using 2 lines
Diffstat (limited to 'src/test/test_parsecommon.c')
-rw-r--r--src/test/test_parsecommon.c35
1 files changed, 24 insertions, 11 deletions
diff --git a/src/test/test_parsecommon.c b/src/test/test_parsecommon.c
index a171cfa7cf..06dbea3a75 100644
--- a/src/test/test_parsecommon.c
+++ b/src/test/test_parsecommon.c
@@ -257,28 +257,41 @@ 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);
+ smartlist_t *tokens = smartlist_new();
+
(void)arg;
- directory_token_t *token = get_next_token(area, s, end, &table);
+ token_rule_t table[] = {
+ T01("uptime", K_UPTIME, GE(1), NO_OBJ),
+ T01("hibernating", K_HIBERNATING, GE(1), NO_OBJ),
+ END_OF_TABLE,
+ };
+
+ char *str = tor_strdup("hibernating 0\r\nuptime 1024\n");
+
+ int retval =
+ tokenize_string(area, str, NULL,
+ tokens, table, 0);
+
+ tt_int_op(smartlist_len(tokens), OP_EQ, 2);
+ directory_token_t *token = smartlist_get(tokens, 0);
+
+ tt_int_op(token->tp, OP_EQ, K_HIBERNATING);
+
+ token = smartlist_get(tokens, 1);
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);
+ tt_int_op(retval, OP_EQ, 0);
done:
+ tor_free(str);
memarea_drop_all(area);
+ smartlist_free(tokens);
return;
}
+
static void
test_parsecommon_get_next_token_concat_args(void *arg)
{