2023-09-08 11:35:18 +02:00
|
|
|
/* Logging utilities for unit test.
|
2018-06-25 17:03:09 +02:00
|
|
|
*
|
2023-01-07 17:20:15 +01:00
|
|
|
* Author: Steffen Vogel <post@steffenvogel.de>
|
2023-01-07 17:32:48 +01:00
|
|
|
* SPDX-FileCopyrightText: 2017 Steffen Vogel <post@steffenvogel.de>
|
2023-01-07 17:20:15 +01:00
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
2023-09-08 11:35:18 +02:00
|
|
|
*/
|
2018-06-25 17:03:09 +02:00
|
|
|
|
2018-01-31 20:23:48 +01:00
|
|
|
#include <cstdarg>
|
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
#include <criterion/logging.h>
|
|
|
|
#include <criterion/options.h>
|
|
|
|
|
|
|
|
#include <spdlog/spdlog.h>
|
2024-02-29 19:34:27 +01:00
|
|
|
#include <villas/log.hpp>
|
2018-01-31 20:23:48 +01:00
|
|
|
|
|
|
|
extern "C" {
|
2024-02-29 19:34:27 +01:00
|
|
|
// We override criterions function here
|
|
|
|
void criterion_log_noformat(enum criterion_severity severity, const char *msg);
|
|
|
|
void criterion_plog(enum criterion_logging_level level,
|
|
|
|
const struct criterion_prefix_data *prefix, const char *msg,
|
|
|
|
...);
|
|
|
|
void criterion_vlog(enum criterion_logging_level level, const char *msg,
|
|
|
|
va_list args);
|
2018-01-31 20:23:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
struct criterion_prefix_data {
|
2024-02-29 19:34:27 +01:00
|
|
|
const char *prefix;
|
|
|
|
const char *color;
|
2018-01-31 20:23:48 +01:00
|
|
|
};
|
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
static int format_msg(char *buf, size_t buflen, const char *msg, va_list args) {
|
|
|
|
int len = vsnprintf(buf, buflen, msg, args);
|
2018-02-13 16:03:38 +01:00
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
// Strip new line
|
|
|
|
char *nl = strchr(buf, '\n');
|
|
|
|
if (nl)
|
|
|
|
*nl = 0;
|
2018-02-13 16:03:38 +01:00
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
return len;
|
2018-01-31 20:23:48 +01:00
|
|
|
}
|
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
void criterion_log_noformat(enum criterion_severity severity, const char *msg) {
|
2024-07-29 12:35:42 +02:00
|
|
|
auto logger = villas::Log::get("criterion");
|
2022-08-30 12:01:47 -04:00
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
switch (severity) {
|
|
|
|
case CR_LOG_INFO:
|
|
|
|
logger->info(msg);
|
|
|
|
break;
|
2022-08-30 12:01:47 -04:00
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
case CR_LOG_WARNING:
|
|
|
|
logger->warn(msg);
|
|
|
|
break;
|
2022-08-30 12:01:47 -04:00
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
case CR_LOG_ERROR:
|
|
|
|
logger->error(msg);
|
|
|
|
break;
|
|
|
|
}
|
2018-01-31 20:23:48 +01:00
|
|
|
}
|
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
void criterion_vlog(enum criterion_logging_level level, const char *msg,
|
|
|
|
va_list args) {
|
|
|
|
char formatted_msg[1024];
|
2022-08-30 12:01:47 -04:00
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
if (level < criterion_options.logging_threshold)
|
|
|
|
return;
|
2018-01-31 20:23:48 +01:00
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
format_msg(formatted_msg, sizeof(formatted_msg), msg, args);
|
2018-01-31 20:23:48 +01:00
|
|
|
|
2024-07-29 12:35:42 +02:00
|
|
|
auto logger = villas::Log::get("criterion");
|
2024-02-29 19:34:27 +01:00
|
|
|
logger->info(formatted_msg);
|
2018-01-31 20:23:48 +01:00
|
|
|
}
|
|
|
|
|
2024-02-29 19:34:27 +01:00
|
|
|
void criterion_plog(enum criterion_logging_level level,
|
|
|
|
const struct criterion_prefix_data *prefix, const char *msg,
|
|
|
|
...) {
|
|
|
|
char formatted_msg[1024];
|
|
|
|
|
|
|
|
va_list args;
|
|
|
|
|
|
|
|
if (level < criterion_options.logging_threshold)
|
|
|
|
return;
|
|
|
|
|
|
|
|
va_start(args, msg);
|
|
|
|
format_msg(formatted_msg, sizeof(formatted_msg), msg, args);
|
|
|
|
va_end(args);
|
|
|
|
|
2024-07-29 12:35:42 +02:00
|
|
|
auto logger = villas::Log::get("criterion");
|
2024-02-29 19:34:27 +01:00
|
|
|
|
|
|
|
if (strstr(formatted_msg, "Warning"))
|
|
|
|
logger->warn(formatted_msg);
|
|
|
|
else if (strstr(formatted_msg, "Failed"))
|
|
|
|
logger->error(formatted_msg);
|
|
|
|
else if (!strcmp(prefix->prefix, "----") &&
|
|
|
|
!strcmp(prefix->color, "\33[0;34m"))
|
|
|
|
logger->info(formatted_msg);
|
|
|
|
else if (!strcmp(prefix->prefix, "----") &&
|
|
|
|
!strcmp(prefix->color, "\33[1;30m"))
|
|
|
|
logger->debug(formatted_msg);
|
|
|
|
else if (!strcmp(prefix->prefix, "===="))
|
|
|
|
logger->info(formatted_msg);
|
|
|
|
else if (!strcmp(prefix->prefix, "RUN "))
|
|
|
|
logger->info("Run: {}", formatted_msg);
|
|
|
|
else if (!strcmp(prefix->prefix, "SKIP"))
|
|
|
|
logger->info("Skip: {}", formatted_msg);
|
|
|
|
else if (!strcmp(prefix->prefix, "PASS"))
|
|
|
|
logger->info("Pass: {}", formatted_msg);
|
|
|
|
else if (!strcmp(prefix->prefix, "FAIL"))
|
|
|
|
logger->error("Fail: {}", formatted_msg);
|
|
|
|
else if (!strcmp(prefix->prefix, "WARN"))
|
|
|
|
logger->warn(formatted_msg);
|
|
|
|
else if (!strcmp(prefix->prefix, "ERR "))
|
|
|
|
logger->error(formatted_msg);
|
2018-01-31 20:23:48 +01:00
|
|
|
}
|