Files
spdlog/tests/test_cfg.cpp

169 lines
5.6 KiB
C++
Raw Normal View History

2020-09-26 14:41:33 +03:00
2019-12-21 18:52:35 +02:00
#include "includes.h"
2023-09-28 23:00:20 +03:00
#include "spdlog/cfg/argv.h"
2023-09-29 00:20:26 +03:00
#include "spdlog/cfg/env.h"
#include "test_sink.h"
2019-12-21 19:45:14 +02:00
2020-03-06 15:09:46 +02:00
using spdlog::cfg::load_argv_levels;
using spdlog::cfg::load_env_levels;
2019-12-22 22:33:19 +02:00
using spdlog::sinks::test_sink_st;
2019-12-21 18:52:35 +02:00
TEST_CASE("env", "[cfg]") {
2019-12-21 20:15:18 +02:00
spdlog::drop("l1");
2019-12-22 22:33:19 +02:00
auto l1 = spdlog::create<test_sink_st>("l1");
2020-03-18 09:46:32 +00:00
#ifdef CATCH_PLATFORM_WINDOWS
2019-12-22 00:17:32 +02:00
_putenv_s("SPDLOG_LEVEL", "l1=warn");
#else
2019-12-21 19:25:54 +02:00
setenv("SPDLOG_LEVEL", "l1=warn", 1);
2019-12-22 00:17:32 +02:00
#endif
2020-03-06 15:09:46 +02:00
load_env_levels();
REQUIRE(l1->log_level() == spdlog::level::warn);
2019-12-22 22:33:19 +02:00
spdlog::set_default_logger(spdlog::create<test_sink_st>("cfg-default"));
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::info);
2019-12-21 18:52:35 +02:00
}
TEST_CASE("argv1", "[cfg]") {
2019-12-21 20:15:18 +02:00
spdlog::drop("l1");
2019-12-21 19:52:37 +02:00
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=warn"};
2020-04-08 17:04:10 +03:00
load_argv_levels(2, argv);
2019-12-21 19:25:54 +02:00
auto l1 = spdlog::create<spdlog::sinks::test_sink_st>("l1");
REQUIRE(l1->log_level() == spdlog::level::warn);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::info);
2019-12-21 19:25:54 +02:00
}
TEST_CASE("argv2", "[cfg]") {
2019-12-21 20:15:18 +02:00
spdlog::drop("l1");
2019-12-21 19:52:37 +02:00
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=warn,trace"};
2020-04-08 17:04:10 +03:00
load_argv_levels(2, argv);
2019-12-22 22:33:19 +02:00
auto l1 = spdlog::create<test_sink_st>("l1");
REQUIRE(l1->log_level() == spdlog::level::warn);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::trace);
2019-12-21 19:25:54 +02:00
}
TEST_CASE("argv3", "[cfg]") {
spdlog::set_level(spdlog::level::trace);
2020-09-27 02:08:24 +03:00
2019-12-21 20:15:18 +02:00
spdlog::drop("l1");
2020-09-27 02:08:24 +03:00
const char *argv[] = {"ignore", "SPDLOG_LEVEL=junk_name=warn"};
2020-04-08 17:04:10 +03:00
load_argv_levels(2, argv);
2019-12-22 22:33:19 +02:00
auto l1 = spdlog::create<test_sink_st>("l1");
REQUIRE(l1->log_level() == spdlog::level::trace);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::trace);
2019-12-21 19:25:54 +02:00
}
TEST_CASE("argv4", "[cfg]") {
spdlog::set_level(spdlog::level::info);
2019-12-21 20:15:18 +02:00
spdlog::drop("l1");
2019-12-21 19:52:37 +02:00
const char *argv[] = {"ignore", "SPDLOG_LEVEL=junk"};
2020-04-08 17:04:10 +03:00
load_argv_levels(2, argv);
2019-12-22 22:33:19 +02:00
auto l1 = spdlog::create<test_sink_st>("l1");
REQUIRE(l1->log_level() == spdlog::level::info);
2019-12-21 19:25:54 +02:00
}
2019-12-21 20:01:25 +02:00
TEST_CASE("argv5", "[cfg]") {
spdlog::set_level(spdlog::level::info);
2019-12-21 20:15:18 +02:00
spdlog::drop("l1");
2019-12-21 20:01:25 +02:00
const char *argv[] = {"ignore", "ignore", "SPDLOG_LEVEL=l1=warn,trace"};
2020-04-08 17:04:10 +03:00
load_argv_levels(3, argv);
2019-12-22 22:33:19 +02:00
auto l1 = spdlog::create<test_sink_st>("l1");
REQUIRE(l1->log_level() == spdlog::level::warn);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::trace);
spdlog::set_level(spdlog::level::info);
2019-12-21 20:15:18 +02:00
}
TEST_CASE("argv6", "[cfg]") {
spdlog::set_level(spdlog::level::err);
2019-12-21 20:15:18 +02:00
const char *argv[] = {""};
2020-04-08 17:04:10 +03:00
load_argv_levels(1, argv);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::err);
spdlog::set_level(spdlog::level::info);
2019-12-21 20:15:18 +02:00
}
TEST_CASE("argv7", "[cfg]") {
spdlog::set_level(spdlog::level::err);
2019-12-21 20:15:18 +02:00
const char *argv[] = {""};
2020-04-08 17:04:10 +03:00
load_argv_levels(0, argv);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::err);
spdlog::set_level(spdlog::level::info);
2019-12-21 20:01:25 +02:00
}
2020-09-25 14:44:01 +03:00
TEST_CASE("level-not-set-test1", "[cfg]") {
2020-09-25 14:44:01 +03:00
spdlog::drop("l1");
const char *argv[] = {"ignore", ""};
load_argv_levels(2, argv);
auto l1 = spdlog::create<spdlog::sinks::test_sink_st>("l1");
l1->set_level(spdlog::level::trace);
REQUIRE(l1->log_level() == spdlog::level::trace);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::info);
2020-09-25 14:44:01 +03:00
}
TEST_CASE("level-not-set-test2", "[cfg]") {
2020-09-25 14:44:01 +03:00
spdlog::drop("l1");
2020-09-25 18:19:50 +03:00
spdlog::drop("l2");
2020-09-25 14:44:01 +03:00
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=trace"};
2020-09-25 18:19:50 +03:00
auto l1 = spdlog::create<spdlog::sinks::test_sink_st>("l1");
l1->set_level(spdlog::level::warn);
2020-09-25 18:19:50 +03:00
auto l2 = spdlog::create<spdlog::sinks::test_sink_st>("l2");
l2->set_level(spdlog::level::warn);
2020-09-25 18:19:50 +03:00
load_argv_levels(2, argv);
REQUIRE(l1->log_level() == spdlog::level::trace);
REQUIRE(l2->log_level() == spdlog::level::warn);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::info);
2020-09-25 18:19:50 +03:00
}
TEST_CASE("level-not-set-test3", "[cfg]") {
2020-09-25 18:19:50 +03:00
spdlog::drop("l1");
spdlog::drop("l2");
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=trace"};
2020-09-25 14:44:01 +03:00
load_argv_levels(2, argv);
auto l1 = spdlog::create<spdlog::sinks::test_sink_st>("l1");
auto l2 = spdlog::create<spdlog::sinks::test_sink_st>("l2");
REQUIRE(l1->log_level() == spdlog::level::trace);
REQUIRE(l2->log_level() == spdlog::level::info);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::info);
2020-09-25 14:44:01 +03:00
}
2020-09-25 18:19:50 +03:00
TEST_CASE("level-not-set-test4", "[cfg]") {
2020-09-25 18:19:50 +03:00
spdlog::drop("l1");
spdlog::drop("l2");
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=trace,warn"};
load_argv_levels(2, argv);
auto l1 = spdlog::create<spdlog::sinks::test_sink_st>("l1");
auto l2 = spdlog::create<spdlog::sinks::test_sink_st>("l2");
REQUIRE(l1->log_level() == spdlog::level::trace);
REQUIRE(l2->log_level() == spdlog::level::warn);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::warn);
2020-09-26 14:41:33 +03:00
}
TEST_CASE("level-not-set-test5", "[cfg]") {
2020-09-26 14:41:33 +03:00
spdlog::drop("l1");
spdlog::drop("l2");
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=junk,warn"};
load_argv_levels(2, argv);
auto l1 = spdlog::create<spdlog::sinks::test_sink_st>("l1");
auto l2 = spdlog::create<spdlog::sinks::test_sink_st>("l2");
REQUIRE(l1->log_level() == spdlog::level::warn);
REQUIRE(l2->log_level() == spdlog::level::warn);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::warn);
2020-09-25 18:19:50 +03:00
}
2020-09-26 14:41:33 +03:00
TEST_CASE("restore-to-default", "[cfg]") {
2020-09-26 14:41:33 +03:00
spdlog::drop("l1");
spdlog::drop("l2");
const char *argv[] = {"ignore", "SPDLOG_LEVEL=info"};
load_argv_levels(2, argv);
REQUIRE(spdlog::default_logger()->log_level() == spdlog::level::info);
2020-09-26 14:41:33 +03:00
}