mirror of
https://github.com/gabime/spdlog.git
synced 2025-02-05 12:16:46 +08:00
ae1de0dc8c
Some checks failed
linux / ${{ matrix.config.compiler}} ${{ matrix.config.version }} (C++${{ matrix.config.cppstd }} ${{ matrix.config.build_type }} ${{ matrix.config.asan == 'ON' && 'ASAN' || '' }}${{ matrix.config.tsan == 'ON' && 'TSAN' || '' }}) (map[asan:ON build_type:Debug … (push) Failing after 3s
linux / ${{ matrix.config.compiler}} ${{ matrix.config.version }} (C++${{ matrix.config.cppstd }} ${{ matrix.config.build_type }} ${{ matrix.config.asan == 'ON' && 'ASAN' || '' }}${{ matrix.config.tsan == 'ON' && 'TSAN' || '' }}) (map[build_type:Debug compiler… (push) Failing after 2s
linux / ${{ matrix.config.compiler}} ${{ matrix.config.version }} (C++${{ matrix.config.cppstd }} ${{ matrix.config.build_type }} ${{ matrix.config.asan == 'ON' && 'ASAN' || '' }}${{ matrix.config.tsan == 'ON' && 'TSAN' || '' }}) (map[build_type:Release compil… (push) Failing after 3s
linux / OS X Clang (C++11, Release) (push) Has been cancelled
macos / macOS Clang (C++11, Release) (map[BUILD_EXAMPLE:OFF USE_STD_FORMAT:ON]) (push) Has been cancelled
macos / macOS Clang (C++11, Release) (map[BUILD_EXAMPLE:ON USE_STD_FORMAT:OFF]) (push) Has been cancelled
windows / build (map[BUILD_EXAMPLE:OFF BUILD_SHARED:ON BUILD_TYPE:Release CXX_STANDARD:20 FATAL_ERRORS:ON GENERATOR:Visual Studio 17 2022 USE_STD_FORMAT:ON WCHAR:OFF WCHAR_FILES:OFF]) (push) Has been cancelled
windows / build (map[BUILD_EXAMPLE:OFF BUILD_SHARED:ON BUILD_TYPE:Release CXX_STANDARD:20 FATAL_ERRORS:ON GENERATOR:Visual Studio 17 2022 USE_STD_FORMAT:ON WCHAR:ON WCHAR_FILES:ON]) (push) Has been cancelled
windows / build (map[BUILD_EXAMPLE:ON BUILD_SHARED:ON BUILD_TYPE:Release CXX_STANDARD:17 FATAL_ERRORS:ON GENERATOR:Visual Studio 17 2022 USE_STD_FORMAT:OFF WCHAR:OFF WCHAR_FILES:OFF]) (push) Has been cancelled
windows / build_2019 (map[BUILD_EXAMPLE:ON BUILD_SHARED:ON BUILD_TYPE:Release CXX_STANDARD:11 FATAL_ERRORS:ON GENERATOR:Visual Studio 16 2019 USE_STD_FORMAT:OFF WCHAR:OFF WCHAR_FILES:OFF]) (push) Has been cancelled
windows / build_2019 (map[BUILD_EXAMPLE:ON BUILD_SHARED:ON BUILD_TYPE:Release CXX_STANDARD:14 FATAL_ERRORS:ON GENERATOR:Visual Studio 16 2019 USE_STD_FORMAT:OFF WCHAR:OFF WCHAR_FILES:OFF]) (push) Has been cancelled
windows / build_2019 (map[BUILD_EXAMPLE:ON BUILD_SHARED:ON BUILD_TYPE:Release CXX_STANDARD:17 FATAL_ERRORS:ON GENERATOR:Visual Studio 16 2019 USE_STD_FORMAT:OFF WCHAR:OFF WCHAR_FILES:OFF]) (push) Has been cancelled
SPDLOG_LEVEL is currently supported to control log levels via load_env_levels. This patch adds support for other environment variable names, such as MYAPP_LEVEL, for load_env_levels.
179 lines
5.7 KiB
C++
179 lines
5.7 KiB
C++
|
|
#include "includes.h"
|
|
#include "test_sink.h"
|
|
|
|
#include <spdlog/cfg/env.h>
|
|
#include <spdlog/cfg/argv.h>
|
|
|
|
using spdlog::cfg::load_argv_levels;
|
|
using spdlog::cfg::load_env_levels;
|
|
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");
|
|
#else
|
|
setenv("SPDLOG_LEVEL", "l1=warn", 1);
|
|
#endif
|
|
load_env_levels();
|
|
REQUIRE(l1->level() == spdlog::level::warn);
|
|
|
|
#ifdef CATCH_PLATFORM_WINDOWS
|
|
_putenv_s("MYAPP_LEVEL", "l1=trace");
|
|
#else
|
|
setenv("MYAPP_LEVEL", "l1=trace", 1);
|
|
#endif
|
|
load_env_levels("MYAPP_LEVEL");
|
|
REQUIRE(l1->level() == spdlog::level::trace);
|
|
|
|
spdlog::set_default_logger(spdlog::create<test_sink_st>("cfg-default"));
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::info);
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
TEST_CASE("level-not-set-test2", "[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);
|
|
|
|
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("level-not-set-test3", "[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);
|
|
}
|
|
|
|
TEST_CASE("level-not-set-test4", "[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);
|
|
}
|
|
|
|
TEST_CASE("level-not-set-test5", "[cfg]") {
|
|
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->level() == spdlog::level::warn);
|
|
REQUIRE(l2->level() == spdlog::level::warn);
|
|
REQUIRE(spdlog::default_logger()->level() == spdlog::level::warn);
|
|
}
|
|
|
|
TEST_CASE("restore-to-default", "[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);
|
|
}
|