X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fdaemon%2Fcommon_test.c;h=f40b2b1a50defda7e9e859a4bd74e8c7f08afa6b;hb=233ef890d210e7f231ebbc474894e90032ba49b1;hp=1fa8f324461293c201b30440a8bb3e857062a993;hpb=81a5fd5046c6a39f580a8fc1a3af837fd5f5aa5c;p=collectd.git diff --git a/src/daemon/common_test.c b/src/daemon/common_test.c index 1fa8f324..f40b2b1a 100644 --- a/src/daemon/common_test.c +++ b/src/daemon/common_test.c @@ -189,6 +189,57 @@ DEF_TEST(strjoin) return (0); } +DEF_TEST(escape_slashes) +{ + struct { + char *str; + char *want; + } cases[] = { + {"foo/bar/baz", "foo_bar_baz"}, + {"/like/a/path", "like_a_path"}, + {"trailing/slash/", "trailing_slash_"}, + {"foo//bar", "foo__bar"}, + }; + size_t i; + + for (i = 0; i < STATIC_ARRAY_SIZE (cases); i++) { + char buffer[32]; + + strncpy (buffer, cases[i].str, sizeof (buffer)); + OK(escape_slashes (buffer, sizeof (buffer)) == 0); + STREQ(cases[i].want, buffer); + } + + return 0; +} + +DEF_TEST(escape_string) +{ + struct { + char *str; + char *want; + } cases[] = { + {"foobar", "foobar"}, + {"f00bar", "f00bar"}, + {"foo bar", "\"foo bar\""}, + {"foo \"bar\"", "\"foo \\\"bar\\\"\""}, + {"012345678901234", "012345678901234"}, + {"012345 78901234", "\"012345 789012\""}, + {"012345 78901\"34", "\"012345 78901\""}, + }; + size_t i; + + for (i = 0; i < STATIC_ARRAY_SIZE (cases); i++) { + char buffer[16]; + + strncpy (buffer, cases[i].str, sizeof (buffer)); + OK(escape_string (buffer, sizeof (buffer)) == 0); + STREQ(cases[i].want, buffer); + } + + return 0; +} + DEF_TEST(strunescape) { char buffer[16]; @@ -231,6 +282,62 @@ DEF_TEST(strunescape) return (0); } +DEF_TEST(parse_values) +{ + struct { + char buffer[64]; + int status; + gauge_t value; + } cases[] = { + {"1435044576:42", 0, 42.0}, + {"1435044576:42:23", -1, NAN}, + {"1435044576:U", 0, NAN}, + {"N:12.3", 0, 12.3}, + {"N:42.0:23", -1, NAN}, + {"N:U", 0, NAN}, + {"T:42.0", -1, NAN}, + }; + + size_t i; + for (i = 0; i < STATIC_ARRAY_SIZE (cases); i++) + { + data_source_t dsrc = { + .name = "value", + .type = DS_TYPE_GAUGE, + .min = 0.0, + .max = NAN, + }; + data_set_t ds = { + .type = "example", + .ds_num = 1, + .ds = &dsrc, + }; + + value_t v = { + .gauge = NAN, + }; + value_list_t vl = { + .values = &v, + .values_len = 1, + .time = 0, + .interval = 0, + .host = "example.com", + .plugin = "common_test", + .type = "example", + .meta = NULL, + }; + + int status = parse_values (cases[i].buffer, &vl, &ds); + OK(status == cases[i].status); + if (status != 0) + continue; + + OK(cases[i].value == vl.values[0].gauge); + } + + return (0); +} + int main (void) { RUN_TEST(sstrncpy); @@ -238,7 +345,10 @@ int main (void) RUN_TEST(sstrdup); RUN_TEST(strsplit); RUN_TEST(strjoin); + RUN_TEST(escape_slashes); + RUN_TEST(escape_string); RUN_TEST(strunescape); + RUN_TEST(parse_values); END_TEST; }