1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
/*
@mindmaze_header@
*/
#if HAVE_CONFIG_H
# include <config.h>
#endif
#include "../src/log.c"
#include <check.h>
#include <stdarg.h>
#include "internals-testcases.h"
static
size_t format_string(char* buff, size_t buflen, const char* msg, ...)
{
size_t r;
va_list args;
va_start(args, msg);
r = format_log_str(buff, buflen, MM_LOG_DEBUG, "here", msg, args);
va_end(args);
return r;
}
START_TEST(log_overflow)
{
size_t len;
char buff[MM_LOG_LINE_MAXLEN + 32];
char arg[MM_LOG_LINE_MAXLEN + 32];
// Fill a message that must overflow the log string
memset(arg, 'a', sizeof(arg)-1);
arg[sizeof(arg)-1] = '\0';
// Format log string
len = format_string(buff, MM_LOG_LINE_MAXLEN, "hello %s", arg);
ck_assert(len <= MM_LOG_LINE_MAXLEN);
ck_assert(buff[len-1] == '\n');
}
END_TEST
LOCAL_SYMBOL
TCase* create_case_log_internals(void)
{
TCase *tc = tcase_create("log internals");
tcase_add_test(tc, log_overflow);
return tc;
}
|