diff options
Diffstat (limited to 'fluent-bit/tests/internal/sds.c')
-rw-r--r-- | fluent-bit/tests/internal/sds.c | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/fluent-bit/tests/internal/sds.c b/fluent-bit/tests/internal/sds.c new file mode 100644 index 000000000..30dc166dd --- /dev/null +++ b/fluent-bit/tests/internal/sds.c @@ -0,0 +1,88 @@ +/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ + +#include <fluent-bit/flb_info.h> +#include <fluent-bit/flb_sds.h> + +#include "flb_tests_internal.h" + +static void test_sds_usage() +{ + flb_sds_t s; + + s = flb_sds_create("test"); + TEST_CHECK(s != NULL); + TEST_CHECK(flb_sds_len(s) == 4); + TEST_CHECK(flb_sds_alloc(s) == 4); + TEST_CHECK(strcmp("test", s) == 0); + + s = flb_sds_cat(s, ",cat message", 12); + TEST_CHECK(strcmp("test,cat message", s) == 0); + + flb_sds_destroy(s); +} + +static void test_sds_printf() +{ + int len; + flb_sds_t s; + flb_sds_t tmp; + char *str = "0123456789ABCDEFGHIJQLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvewxyz"; + + s = flb_sds_create_size(10); + tmp = flb_sds_printf(&s, "%s=%s", str, str); + + len = (strlen(str) * 2) + 1; + TEST_CHECK(tmp == s); + TEST_CHECK(flb_sds_len(s) == len); + flb_sds_destroy(s); +} + +/* https://github.com/fluent/fluent-bit/issues/7143 */ +static void test_sds_printf_7143_off_by_1() +{ + flb_sds_t tmp; + flb_sds_t test; + flb_sds_t test2; + int len; + + /* 66 char final string, not impacted by bug */ + test = flb_sds_create_size(64); + TEST_CHECK(test != NULL); + tmp = flb_sds_printf(&test, "A0123456789 %s", "this-is-54-chars-1234567890-abcdefghijklmnopqrstuvwxyz"); + TEST_CHECK(tmp != NULL); + len = flb_sds_len(test); + TEST_CHECK(len == 66); + TEST_CHECK(test[len -1] == 'z'); + flb_sds_destroy(test); + + /* 65 char final string, impacted by bug */ + test2 = flb_sds_create_size(64); + TEST_CHECK(test2 != NULL); + tmp = flb_sds_printf(&test2, "0123456789 %s", "this-is-54-chars-1234567890-abcdefghijklmnopqrstuvwxyz"); + TEST_CHECK(tmp != NULL); + len = flb_sds_len(test2); + TEST_CHECK(len == 65); + TEST_CHECK(test2[len -1] == 'z'); + flb_sds_destroy(test2); + +} + +static void test_sds_cat_utf8() +{ + flb_sds_t s; + char *utf8_str = "\xe8\x9f\xb9\xf0\x9f\xa6\x80"; + + s = flb_sds_create(""); + flb_sds_cat_utf8(&s, utf8_str, strlen(utf8_str)); + + TEST_CHECK(strcmp(s, "\\u87f9\\u1f980") == 0); + flb_sds_destroy(s); +} + +TEST_LIST = { + { "sds_usage" , test_sds_usage}, + { "sds_printf", test_sds_printf}, + { "sds_cat_utf8", test_sds_cat_utf8}, + { "test_sds_printf_7143_off_by_1", test_sds_printf_7143_off_by_1}, + { 0 } +}; |