summaryrefslogtreecommitdiffstats
path: root/winpr/libwinpr/utils/test/TestWLog.c
blob: 92f11147e04bd742297984c94461a3b8589d6258 (plain)
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
58
59
60
61
62
63
64
65
66
67
68
69
#include <winpr/crt.h>
#include <winpr/tchar.h>
#include <winpr/path.h>
#include <winpr/file.h>
#include <winpr/wlog.h>

int TestWLog(int argc, char* argv[])
{
	wLog* root = NULL;
	wLog* logA = NULL;
	wLog* logB = NULL;
	wLogLayout* layout = NULL;
	wLogAppender* appender = NULL;
	char* tmp_path = NULL;
	char* wlog_file = NULL;
	int result = 1;

	WINPR_UNUSED(argc);
	WINPR_UNUSED(argv);

	if (!(tmp_path = GetKnownPath(KNOWN_PATH_TEMP)))
	{
		fprintf(stderr, "Failed to get temporary directory!\n");
		goto out;
	}

	root = WLog_GetRoot();

	WLog_SetLogAppenderType(root, WLOG_APPENDER_BINARY);

	appender = WLog_GetLogAppender(root);
	if (!WLog_ConfigureAppender(appender, "outputfilename", "test_w.log"))
		goto out;
	if (!WLog_ConfigureAppender(appender, "outputfilepath", tmp_path))
		goto out;

	layout = WLog_GetLogLayout(root);
	WLog_Layout_SetPrefixFormat(root, layout, "[%lv:%mn] [%fl|%fn|%ln] - ");

	WLog_OpenAppender(root);

	logA = WLog_Get("com.test.ChannelA");
	logB = WLog_Get("com.test.ChannelB");

	WLog_SetLogLevel(logA, WLOG_INFO);
	WLog_SetLogLevel(logB, WLOG_ERROR);

	WLog_Print(logA, WLOG_INFO, "this is a test");
	WLog_Print(logA, WLOG_WARN, "this is a %dnd %s", 2, "test");
	WLog_Print(logA, WLOG_ERROR, "this is an error");
	WLog_Print(logA, WLOG_TRACE, "this is a trace output");

	WLog_Print(logB, WLOG_INFO, "just some info");
	WLog_Print(logB, WLOG_WARN, "we're warning a %dnd %s", 2, "time");
	WLog_Print(logB, WLOG_ERROR, "we've got an error");
	WLog_Print(logB, WLOG_TRACE, "leaving a trace behind");

	WLog_CloseAppender(root);

	if ((wlog_file = GetCombinedPath(tmp_path, "test_w.log")))
		winpr_DeleteFile(wlog_file);

	result = 0;
out:
	free(wlog_file);
	free(tmp_path);

	return result;
}