#include #include #include #include #include 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; }