summaryrefslogtreecommitdiffstats
path: root/fluent-bit/tests/internal/log.c
diff options
context:
space:
mode:
Diffstat (limited to 'fluent-bit/tests/internal/log.c')
-rw-r--r--fluent-bit/tests/internal/log.c154
1 files changed, 154 insertions, 0 deletions
diff --git a/fluent-bit/tests/internal/log.c b/fluent-bit/tests/internal/log.c
new file mode 100644
index 000000000..662df98ec
--- /dev/null
+++ b/fluent-bit/tests/internal/log.c
@@ -0,0 +1,154 @@
+#include <fluent-bit/flb_sds.h>
+#include <fluent-bit/flb_mem.h>
+#include <fluent-bit/flb_log.h>
+
+#include "flb_tests_internal.h"
+
+#define TIMEOUT 5
+#define TEST_RECORD_01 "this is a test message"
+#define TEST_RECORD_01_SIZE sizeof(TEST_RECORD_01) - 1
+
+#define TEST_RECORD_02 "other type of message"
+#define TEST_RECORD_02_SIZE sizeof(TEST_RECORD_02) - 1
+
+static int check_interval(int timeout, int *interval)
+{
+ if (!TEST_CHECK( (*interval >= timeout - 1) && *interval <= timeout) ) {
+ TEST_MSG("interval error. got=%d expect=%d-%d", *interval, timeout -1 ,timeout);
+ return -1;
+ }
+
+ return 0;
+}
+
+static int update_and_check_interval(int timeout, int ret, int *interval)
+{
+ int ret_val;
+
+ if (ret == FLB_TRUE) {
+ *interval += 1;
+ return 0;
+ }
+
+ /* false means timeout. check interval. */
+ ret_val = check_interval(timeout, interval);
+ *interval = 0; /* reset interval */
+
+ return ret_val;
+}
+
+static void cache_basic_timeout()
+{
+ int i;
+ int ret;
+ int ret_1;
+ int ret_2;
+ int timeout = 5;
+ int interval1 = 0;
+ int interval2 = 0;
+ struct flb_log_cache *cache;
+ struct flb_log_cache_entry *entry;
+
+ printf("\n");
+
+ cache = flb_log_cache_create(10, 0);
+ TEST_CHECK(cache == NULL);
+
+ cache = flb_log_cache_create(5, 4);
+ TEST_CHECK(cache != NULL);
+
+ /* cache must be empty */
+ entry = flb_log_cache_exists(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE);
+ TEST_CHECK(entry == NULL);
+
+ /* upon trying to check for a suppress and if not found, it must be added */
+ ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE);
+ TEST_CHECK(ret_1 == FLB_FALSE);
+
+ /* double check that it was added */
+ entry = flb_log_cache_exists(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE);
+ TEST_CHECK(entry != NULL);
+
+ printf("------------------------\n");
+
+ /* reset */
+ flb_log_cache_destroy(cache);
+
+ /* create a new cache */
+ cache = flb_log_cache_create(timeout, 4);
+ TEST_CHECK(cache != NULL);
+
+ ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE);
+ ret_2 = flb_log_cache_check_suppress(cache, TEST_RECORD_02, TEST_RECORD_02_SIZE);
+ TEST_CHECK(ret_1 == FLB_FALSE);
+ TEST_CHECK(ret_2 == FLB_FALSE);
+ sleep(1);
+ interval1++;
+ interval2++;
+
+ for (i = 1; i < 10; i++) {
+ ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE);
+ ret = update_and_check_interval(timeout, ret_1, &interval1);
+ if (!TEST_CHECK(ret == 0)) {
+ TEST_MSG("update_and_check_interval for TEST_RECORD_01 failed. i=%d", i);
+ }
+
+ ret_2 = flb_log_cache_check_suppress(cache, TEST_RECORD_02, TEST_RECORD_02_SIZE);
+ ret = update_and_check_interval(timeout, ret_2, &interval2);
+ if (!TEST_CHECK(ret == 0)) {
+ TEST_MSG("update_and_check_interval for TEST_RECORD_02 failed. i=%d", i);
+ }
+
+ sleep(1);
+ }
+ ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE);
+ ret = update_and_check_interval(timeout, ret_1, &interval1);
+ TEST_CHECK(ret == 0);
+
+ ret_2 = flb_log_cache_check_suppress(cache, TEST_RECORD_02, TEST_RECORD_02_SIZE);
+ ret = update_and_check_interval(timeout, ret_2, &interval2);
+ TEST_CHECK(ret == 0);
+
+ flb_log_cache_destroy(cache);
+}
+
+static void cache_one_slot()
+{
+ int i;
+ int ret_1;
+ int ret_2;
+ struct flb_log_cache *cache;
+
+ printf("\n");
+
+ cache = flb_log_cache_create(2, 1);
+ TEST_CHECK(cache != NULL);
+
+ for (i = 0; i < 10; i++) {
+
+ if (i == 0) {
+ ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE);
+ TEST_CHECK(ret_1 == FLB_FALSE);
+
+ ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE);
+ TEST_CHECK(ret_1 == FLB_TRUE);
+ }
+ else {
+ ret_2 = flb_log_cache_check_suppress(cache, TEST_RECORD_02, TEST_RECORD_02_SIZE);
+ ret_1 = flb_log_cache_check_suppress(cache, TEST_RECORD_01, TEST_RECORD_01_SIZE);
+
+ TEST_CHECK(ret_1 == FLB_FALSE);
+ TEST_CHECK(ret_2 == FLB_FALSE);
+ }
+
+ sleep(1);
+ }
+
+ flb_log_cache_destroy(cache);
+}
+
+TEST_LIST = {
+ { "cache_basic_timeout" , cache_basic_timeout },
+ { "cache_one_slot" , cache_one_slot },
+ { 0 }
+};