File: log-internals.c

package info (click to toggle)
mmlib 1.4.2-2.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,716 kB
  • sloc: ansic: 18,071; makefile: 431; sh: 135; python: 63
file content (57 lines) | stat: -rw-r--r-- 953 bytes parent folder | download
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;
}