|
|
|
@ -11,173 +11,139 @@ using spdlog::sinks::test_sink_st;
|
|
|
|
|
|
|
|
|
|
TEST_CASE("env", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::drop("l1");
|
|
|
|
|
auto l1 = spdlog::create<test_sink_st>("l1");
|
|
|
|
|
#ifdef CATCH_PLATFORM_WINDOWS
|
|
|
|
|
_putenv_s("SPDLOG_LEVEL", "l1=warn");
|
|
|
|
|
_putenv_s("SPDLOG_LEVEL", "warn");
|
|
|
|
|
#else
|
|
|
|
|
setenv("SPDLOG_LEVEL", "l1=warn", 1);
|
|
|
|
|
setenv("SPDLOG_LEVEL", "warn", 1);
|
|
|
|
|
#endif
|
|
|
|
|
load_env_levels();
|
|
|
|
|
REQUIRE(l1->level() == spdlog::level::warn);
|
|
|
|
|
spdlog::set_default_logger(spdlog::create<test_sink_st>("cfg-default"));
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::info);
|
|
|
|
|
auto levels = load_env_levels();
|
|
|
|
|
auto it = levels.find(spdlog::default_logger()->name());
|
|
|
|
|
REQUIRE(levels == spdlog::cfg::level_map {{"", spdlog::level::warn}});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("argv1", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::drop("l1");
|
|
|
|
|
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=warn"};
|
|
|
|
|
load_argv_levels(2, argv);
|
|
|
|
|
auto l1 = spdlog::create<spdlog::sinks::test_sink_st>("l1");
|
|
|
|
|
REQUIRE(l1->level() == spdlog::level::warn);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::info);
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels == spdlog::cfg::level_map {{"l1", spdlog::level::warn}});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("argv2", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::drop("l1");
|
|
|
|
|
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=warn,trace"};
|
|
|
|
|
load_argv_levels(2, argv);
|
|
|
|
|
auto l1 = spdlog::create<test_sink_st>("l1");
|
|
|
|
|
REQUIRE(l1->level() == spdlog::level::warn);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::trace);
|
|
|
|
|
auto levels = load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels == spdlog::cfg::level_map {
|
|
|
|
|
{"l1", spdlog::level::warn},
|
|
|
|
|
{"", spdlog::level::trace}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("argv3", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::set_level(spdlog::level::trace);
|
|
|
|
|
|
|
|
|
|
spdlog::drop("l1");
|
|
|
|
|
const char *argv[] = {"ignore", "SPDLOG_LEVEL=junk_name=warn"};
|
|
|
|
|
load_argv_levels(2, argv);
|
|
|
|
|
auto l1 = spdlog::create<test_sink_st>("l1");
|
|
|
|
|
REQUIRE(l1->level() == spdlog::level::trace);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::trace);
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels == spdlog::cfg::level_map {{"junk_name", spdlog::level::warn}});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("argv4", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::set_level(spdlog::level::info);
|
|
|
|
|
spdlog::drop("l1");
|
|
|
|
|
const char *argv[] = {"ignore", "SPDLOG_LEVEL=junk"};
|
|
|
|
|
load_argv_levels(2, argv);
|
|
|
|
|
auto l1 = spdlog::create<test_sink_st>("l1");
|
|
|
|
|
REQUIRE(l1->level() == spdlog::level::info);
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("argv5", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::set_level(spdlog::level::info);
|
|
|
|
|
spdlog::drop("l1");
|
|
|
|
|
const char *argv[] = {"ignore", "ignore", "SPDLOG_LEVEL=l1=warn,trace"};
|
|
|
|
|
load_argv_levels(3, argv);
|
|
|
|
|
auto l1 = spdlog::create<test_sink_st>("l1");
|
|
|
|
|
REQUIRE(l1->level() == spdlog::level::warn);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::trace);
|
|
|
|
|
spdlog::set_level(spdlog::level::info);
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels == spdlog::cfg::level_map {
|
|
|
|
|
{"l1", spdlog::level::warn},
|
|
|
|
|
{"", spdlog::level::trace}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("argv6", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::set_level(spdlog::level::err);
|
|
|
|
|
const char *argv[] = {""};
|
|
|
|
|
load_argv_levels(1, argv);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::err);
|
|
|
|
|
spdlog::set_level(spdlog::level::info);
|
|
|
|
|
const char *argv[] = {"SPDLOG_LEVEL=info"};
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("argv7", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::set_level(spdlog::level::err);
|
|
|
|
|
const char *argv[] = {""};
|
|
|
|
|
load_argv_levels(0, argv);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::err);
|
|
|
|
|
spdlog::set_level(spdlog::level::info);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("level-not-set-test1", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
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->level() == spdlog::level::trace);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::info);
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("level-not-set-test2", "[cfg]")
|
|
|
|
|
TEST_CASE("argv8", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::drop("l1");
|
|
|
|
|
spdlog::drop("l2");
|
|
|
|
|
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=trace"};
|
|
|
|
|
|
|
|
|
|
auto l1 = spdlog::create<spdlog::sinks::test_sink_st>("l1");
|
|
|
|
|
l1->set_level(spdlog::level::warn);
|
|
|
|
|
auto l2 = spdlog::create<spdlog::sinks::test_sink_st>("l2");
|
|
|
|
|
l2->set_level(spdlog::level::warn);
|
|
|
|
|
const char *argv[] = {"ignore"};
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
load_argv_levels(2, argv);
|
|
|
|
|
|
|
|
|
|
REQUIRE(l1->level() == spdlog::level::trace);
|
|
|
|
|
REQUIRE(l2->level() == spdlog::level::warn);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::info);
|
|
|
|
|
TEST_CASE("argv9", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
const char *argv[] = {"ignore", "arg1"};
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("level-not-set-test3", "[cfg]")
|
|
|
|
|
TEST_CASE("argv10", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::drop("l1");
|
|
|
|
|
spdlog::drop("l2");
|
|
|
|
|
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=trace"};
|
|
|
|
|
|
|
|
|
|
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->level() == spdlog::level::trace);
|
|
|
|
|
REQUIRE(l2->level() == spdlog::level::info);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::info);
|
|
|
|
|
const char *argv[] = {"ignore", "junk", "SPDLOG_LEVEL=info"};
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels == spdlog::cfg::level_map {{"", spdlog::level::info}});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("level-not-set-test4", "[cfg]")
|
|
|
|
|
TEST_CASE("argv11", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
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->level() == spdlog::level::trace);
|
|
|
|
|
REQUIRE(l2->level() == spdlog::level::warn);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::warn);
|
|
|
|
|
const char *argv[] = {};
|
|
|
|
|
auto levels= load_argv_levels(0, argv);
|
|
|
|
|
REQUIRE(levels.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("level-not-set-test5", "[cfg]")
|
|
|
|
|
TEST_CASE("argv12", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::drop("l1");
|
|
|
|
|
spdlog::drop("l2");
|
|
|
|
|
const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=junk,warn"};
|
|
|
|
|
|
|
|
|
|
load_argv_levels(2, argv);
|
|
|
|
|
const char *argv[] = {"ignore", "junk", "SPDLOG_LEVEL=info,l1=debug,l2=warn,l3=off"};
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels == spdlog::cfg::level_map {
|
|
|
|
|
{"", spdlog::level::info},
|
|
|
|
|
{"l1", spdlog::level::debug},
|
|
|
|
|
{"l2", spdlog::level::warn},
|
|
|
|
|
{"l3", spdlog::level::off}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
auto l1 = spdlog::create<spdlog::sinks::test_sink_st>("l1");
|
|
|
|
|
auto l2 = spdlog::create<spdlog::sinks::test_sink_st>("l2");
|
|
|
|
|
TEST_CASE("argv13", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
//test that only first SPDLOG_LEVEL is handled
|
|
|
|
|
const char *argv[] = {"ignore", "junk", "SPDLOG_LEVEL=info,l1=debug,l2=warn,l3=off", "SPDLOG_LEVEL=off"};
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels == spdlog::cfg::level_map {
|
|
|
|
|
{"", spdlog::level::info},
|
|
|
|
|
{"l1", spdlog::level::debug},
|
|
|
|
|
{"l2", spdlog::level::warn},
|
|
|
|
|
{"l3", spdlog::level::off}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
REQUIRE(l1->level() == spdlog::level::warn);
|
|
|
|
|
REQUIRE(l2->level() == spdlog::level::warn);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::warn);
|
|
|
|
|
TEST_CASE("argv14", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
//test that only first SPDLOG_LEVEL is handled
|
|
|
|
|
const char *argv[] = {"ignore", "SPDLOG_LEVEL="};
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels.empty());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_CASE("restore-to-default", "[cfg]")
|
|
|
|
|
TEST_CASE("argv15", "[cfg]")
|
|
|
|
|
{
|
|
|
|
|
spdlog::drop("l1");
|
|
|
|
|
spdlog::drop("l2");
|
|
|
|
|
const char *argv[] = {"ignore", "SPDLOG_LEVEL=info"};
|
|
|
|
|
load_argv_levels(2, argv);
|
|
|
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::info);
|
|
|
|
|
//test that only first SPDLOG_LEVEL is handled
|
|
|
|
|
const char *argv[] = {"ignore", "SPDLOG_LEVEL=info,l1=junk,l2=debug"};
|
|
|
|
|
auto levels= load_argv_levels(sizeof(argv)/sizeof (const char*), argv);
|
|
|
|
|
REQUIRE(levels == spdlog::cfg::level_map {
|
|
|
|
|
{"", spdlog::level::info},
|
|
|
|
|
{"l2", spdlog::level::debug},
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|