2016-08-11 00:27:52 -06:00
/** ==========================================================================
* 2016 by KjellKod . cc . This is PUBLIC DOMAIN to use at your own risk and comes
* with no warranties . This code is yours to share , use and modify with no
* strings attached and no restrictions or obligations .
*
* For more information see g3log / LICENSE or refer refer to http : //unlicense.org
* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
# include <gtest/gtest.h>
2023-11-30 16:17:45 -07:00
# include <testing_helpers.h>
# include <cstdlib>
# include <ctime>
# include <g3log/filesink.hpp>
2016-08-11 00:27:52 -06:00
# include <g3log/g3log.hpp>
2023-11-30 16:17:45 -07:00
# include <g3log/generated_definitions.hpp>
2016-08-11 00:27:52 -06:00
# include <g3log/time.hpp>
# include <iostream>
2017-04-27 22:57:04 -06:00
namespace {
// https://www.epochconverter.com/
// epoc value for: Thu, 27 Apr 2017 06:22:49 GMT
time_t k2017_April_27th = 1493274147 ;
auto kTimePoint_2017_April_27th = std : : chrono : : system_clock : : from_time_t ( k2017_April_27th ) ;
std : : chrono : : time_point < std : : chrono : : system_clock > k1970_January_1st = { } ;
2018-03-08 09:16:12 -07:00
const std : : string kFile = __FILE__ ;
const int kLine = 123 ;
const std : : string kFunction = " MyTest::Foo " ;
const LEVELS kLevel = INFO ;
const std : : string testdirectory = " ./ " ;
2023-11-30 16:17:45 -07:00
} // namespace
2018-03-08 09:16:12 -07:00
TEST ( Message , DefaultLogDetals_toString ) {
using namespace g3 ;
LogMessage msg { kFile , kLine , kFunction , kLevel } ;
auto details = LogMessage : : DefaultLogDetailsToString ( msg ) ;
auto details2 = msg . _logDetailsToStringFunc ( msg ) ;
EXPECT_EQ ( details , details2 ) ;
}
TEST ( Message , Default_toString ) {
using namespace g3 ;
LogMessage msg { kFile , kLine , kFunction , kLevel } ;
auto details = LogMessage : : DefaultLogDetailsToString ( msg ) ;
auto output = msg . toString ( ) ;
testing_helpers : : verifyContent ( output , details ) ;
2017-04-27 22:57:04 -06:00
}
2016-08-11 00:27:52 -06:00
2018-03-08 09:16:12 -07:00
TEST ( Message , UseOverride_4_DetailsWithThreadID_toString ) {
using namespace g3 ;
LogMessage msg { kFile , kLine , kFunction , kLevel } ;
msg . overrideLogDetailsFunc ( & LogMessage : : FullLogDetailsToString ) ;
auto output = msg . toString ( ) ;
std : : ostringstream thread_id_oss ;
thread_id_oss < < std : : this_thread : : get_id ( ) ;
testing_helpers : : verifyContent ( output , thread_id_oss . str ( ) ) ;
testing_helpers : : verifyContent ( output , kFile ) ;
testing_helpers : : verifyContent ( output , kLevel . text ) ;
testing_helpers : : verifyContent ( output , kFunction ) ;
testing_helpers : : verifyContent ( output , std : : to_string ( kLine ) ) ;
std : : cout < < output < < std : : endl ;
}
TEST ( Message , UseLogCall_4_DetailsWithThreadID_toString ) {
using namespace g3 ;
LogMessage msg { kFile , kLine , kFunction , kLevel } ;
auto output = msg . toString ( & LogMessage : : FullLogDetailsToString ) ;
std : : ostringstream thread_id_oss ;
thread_id_oss < < std : : this_thread : : get_id ( ) ;
testing_helpers : : verifyContent ( output , thread_id_oss . str ( ) ) ;
testing_helpers : : verifyContent ( output , kFile ) ;
testing_helpers : : verifyContent ( output , kLevel . text ) ;
testing_helpers : : verifyContent ( output , kFunction ) ;
testing_helpers : : verifyContent ( output , std : : to_string ( kLine ) ) ;
std : : cout < < output < < std : : endl ;
}
TEST ( Message , DefaultFormattingToLogFile ) {
using namespace g3 ;
std : : string file_content ;
{
testing_helpers : : RestoreFileLogger logger ( testdirectory ) ;
LOG ( WARNING ) < < " testing " ;
2023-11-30 16:17:45 -07:00
logger . reset ( ) ; // force flush of logger (which will trigger a shutdown)
file_content = testing_helpers : : readFileToText ( logger . logFile ( ) ) ; // logger is already reset
2018-03-08 09:16:12 -07:00
}
2023-11-30 16:17:45 -07:00
2018-03-08 09:16:12 -07:00
std : : ostringstream thread_id_oss ;
thread_id_oss < < " [ " < < std : : this_thread : : get_id ( ) < < " " ;
EXPECT_FALSE ( testing_helpers : : verifyContent ( file_content , thread_id_oss . str ( ) ) ) ;
}
TEST ( Message , FullFormattingToLogFile ) {
using namespace g3 ;
std : : string file_content ;
{
testing_helpers : : RestoreFileLogger logger ( testdirectory ) ;
logger . _handle - > call ( & FileSink : : overrideLogDetails , & LogMessage : : FullLogDetailsToString ) ;
LOG ( WARNING ) < < " testing " ;
2023-11-30 16:17:45 -07:00
logger . reset ( ) ; // force flush of logger (which will trigger a shutdown)
file_content = testing_helpers : : readFileToText ( logger . logFile ( ) ) ; // logger is already reset
2018-03-08 09:16:12 -07:00
}
2023-11-30 16:17:45 -07:00
2018-03-08 09:16:12 -07:00
std : : ostringstream thread_id_oss ;
thread_id_oss < < " [ " < < std : : this_thread : : get_id ( ) < < " " ;
EXPECT_TRUE ( testing_helpers : : verifyContent ( file_content , thread_id_oss . str ( ) ) ) ;
}
2016-08-11 00:27:52 -06:00
TEST ( Message , CppSupport ) {
// ref: http://www.cplusplus.com/reference/clibrary/ctime/strftime/
// ref: http://en.cppreference.com/w/cpp/io/manip/put_time
// Day Month Date Time Year: is written as "%a %b %d %H:%M:%S %Y" and formatted output as : Wed Sep 19 08:28:16 2012
// --- WARNING: The try/catch setup does NOT work,. but for fun and for fake-clarity I leave it
// --- For formatting options to std::put_time that are NOT YET implemented on Windows fatal errors/assert will occurr
// --- the last example is such an example.
try {
2023-11-30 16:17:45 -07:00
std : : cout < < g3 : : localtime_formatted ( std : : chrono : : system_clock : : now ( ) , " %a %b %d %H:%M:%S %Y " ) < < std : : endl ;
2016-08-11 00:27:52 -06:00
std : : this_thread : : sleep_for ( std : : chrono : : seconds ( 1 ) ) ;
2023-11-30 16:17:45 -07:00
std : : cout < < g3 : : localtime_formatted ( std : : chrono : : system_clock : : now ( ) , " %%Y/%%m/%%d %%H:%%M:%%S = %Y/%m/%d %H:%M:%S " ) < < std : : endl ;
2016-08-11 00:27:52 -06:00
# if (defined(WIN32) || defined(_WIN32) || defined(__WIN32__))
std : : cerr < < " Formatting options skipped due to VS2012, C++11 non-conformance for " < < std : : endl ;
2023-11-30 16:17:45 -07:00
std : : cerr < < " some formatting options. The skipped code was: \n \t \t %EX %Ec, \n (see http://en.cppreference.com/w/cpp/io/manip/put_time for details) " < < std : : endl ;
2016-08-11 00:27:52 -06:00
# else
2023-11-30 16:17:45 -07:00
std : : cout < < " C++11 new formatting options: \n "
< < g3 : : localtime_formatted ( std : : chrono : : system_clock : : now ( ) , " %%EX: %EX \n %%z: %z \n %%Ec: %Ec " ) < < std : : endl ;
2016-08-11 00:27:52 -06:00
# endif
}
2023-11-30 16:17:45 -07:00
// This does not work. Other kinds of fatal exits (on Windows) seems to be used instead of exceptions
// Maybe a signal handler catch would be better? --- TODO: Make it better, both failing and correct
2016-08-11 00:27:52 -06:00
catch ( . . . ) {
ADD_FAILURE ( ) < < " On this platform the library does not support given (C++11?) specifiers " ;
return ;
}
2023-11-30 16:17:45 -07:00
ASSERT_TRUE ( true ) ; // no exception. all good
2016-08-11 00:27:52 -06:00
}
TEST ( Message , GetFractional_Empty_buffer_ExpectDefaults ) {
auto fractional = g3 : : internal : : getFractional ( " " , 0 ) ;
const auto expected = g3 : : internal : : Fractional : : NanosecondDefault ;
EXPECT_EQ ( fractional , expected ) ;
fractional = g3 : : internal : : getFractional ( " " , 100 ) ;
EXPECT_EQ ( fractional , expected ) ;
}
TEST ( Message , GetFractional_MilliSeconds ) {
auto fractional = g3 : : internal : : getFractional ( " %f3 " , 0 ) ;
const auto expected = g3 : : internal : : Fractional : : Millisecond ;
EXPECT_EQ ( fractional , expected ) ;
}
TEST ( Message , GetFractional_Microsecond ) {
auto fractional = g3 : : internal : : getFractional ( " %f6 " , 0 ) ;
const auto expected = g3 : : internal : : Fractional : : Microsecond ;
EXPECT_EQ ( fractional , expected ) ;
}
TEST ( Message , GetFractional_Nanosecond ) {
auto fractional = g3 : : internal : : getFractional ( " %f9 " , 0 ) ;
const auto expected = g3 : : internal : : Fractional : : Nanosecond ;
EXPECT_EQ ( fractional , expected ) ;
}
TEST ( Message , GetFractional_NanosecondDefault ) {
auto fractional = g3 : : internal : : getFractional ( " %f " , 0 ) ;
const auto expected = g3 : : internal : : Fractional : : NanosecondDefault ;
EXPECT_EQ ( fractional , expected ) ;
}
TEST ( Message , GetFractional_All ) {
std : : string formatted = " %f, %f9, %f6, %f3 " ;
auto fractional = g3 : : internal : : getFractional ( formatted , 0 ) ;
auto expected = g3 : : internal : : Fractional : : NanosecondDefault ;
EXPECT_EQ ( fractional , expected ) ;
// ns
fractional = g3 : : internal : : getFractional ( formatted , 4 ) ;
expected = g3 : : internal : : Fractional : : Nanosecond ;
EXPECT_EQ ( fractional , expected ) ;
// us
fractional = g3 : : internal : : getFractional ( formatted , 9 ) ;
expected = g3 : : internal : : Fractional : : Microsecond ;
EXPECT_EQ ( fractional , expected ) ;
// ms
fractional = g3 : : internal : : getFractional ( formatted , 14 ) ;
expected = g3 : : internal : : Fractional : : Millisecond ;
EXPECT_EQ ( fractional , expected ) ;
}
2017-04-27 22:57:04 -06:00
TEST ( Message , FractionalToString_SizeCheck ) {
auto value = g3 : : internal : : to_string ( kTimePoint_2017_April_27th , g3 : : internal : : Fractional : : Nanosecond ) ;
EXPECT_EQ ( " 000000000 " , value ) ;
value = g3 : : internal : : to_string ( kTimePoint_2017_April_27th , g3 : : internal : : Fractional : : NanosecondDefault ) ;
EXPECT_EQ ( " 000000000 " , value ) ;
2016-08-11 00:27:52 -06:00
// us
2017-04-27 22:57:04 -06:00
value = g3 : : internal : : to_string ( kTimePoint_2017_April_27th , g3 : : internal : : Fractional : : Microsecond ) ;
EXPECT_EQ ( " 000000 " , value ) ;
2023-11-30 16:17:45 -07:00
// ms
2017-04-27 22:57:04 -06:00
value = g3 : : internal : : to_string ( kTimePoint_2017_April_27th , g3 : : internal : : Fractional : : Millisecond ) ;
EXPECT_EQ ( " 000 " , value ) ;
2016-08-11 00:27:52 -06:00
}
TEST ( Message , FractionalToStringNanoPadded ) {
2017-04-27 22:57:04 -06:00
auto value = g3 : : internal : : to_string ( k1970_January_1st , g3 : : internal : : Fractional : : Nanosecond ) ;
EXPECT_EQ ( " 000000000 " , value ) ;
2016-08-11 00:27:52 -06:00
// 0000000012
2017-04-27 22:57:04 -06:00
value = g3 : : internal : : to_string ( k1970_January_1st , g3 : : internal : : Fractional : : NanosecondDefault ) ;
EXPECT_EQ ( " 000000000 " , value ) ;
2016-08-11 00:27:52 -06:00
}
TEST ( Message , FractionalToString12NanoPadded ) {
2017-04-27 22:57:04 -06:00
auto value = g3 : : internal : : to_string ( k1970_January_1st , g3 : : internal : : Fractional : : Nanosecond ) ;
EXPECT_EQ ( " 000000000 " , value ) ;
2016-08-11 00:27:52 -06:00
// 0000000012
2017-04-27 22:57:04 -06:00
value = g3 : : internal : : to_string ( k1970_January_1st , g3 : : internal : : Fractional : : NanosecondDefault ) ;
EXPECT_EQ ( " 000000000 " , value ) ;
2016-08-11 00:27:52 -06:00
}
TEST ( Message , FractionalToStringMicroPadded ) {
2017-04-27 22:57:04 -06:00
auto value = g3 : : internal : : to_string ( k1970_January_1st , g3 : : internal : : Fractional : : Microsecond ) ;
EXPECT_EQ ( " 000000 " , value ) ;
value = g3 : : internal : : to_string ( k1970_January_1st , g3 : : internal : : Fractional : : Microsecond ) ;
EXPECT_EQ ( " 000000 " , value ) ;
2016-08-11 00:27:52 -06:00
}
TEST ( Message , FractionalToStringMilliPadded ) {
2017-04-27 22:57:04 -06:00
auto value = g3 : : internal : : to_string ( k1970_January_1st , g3 : : internal : : Fractional : : Millisecond ) ;
EXPECT_EQ ( " 000 " , value ) ;
value = g3 : : internal : : to_string ( k1970_January_1st , g3 : : internal : : Fractional : : Millisecond ) ;
EXPECT_EQ ( " 000 " , value ) ;
2016-08-11 00:27:52 -06:00
}
# if !(defined(WIN32) || defined(_WIN32) || defined(__WIN32__))
2017-04-27 22:57:04 -06:00
2016-08-11 00:27:52 -06:00
TEST ( Message , localtime_formatted ) {
2017-04-27 22:57:04 -06:00
char * tz = nullptr ;
std : : shared_ptr < void > RaiiTimeZoneReset ( nullptr , [ & ] ( void * ) {
if ( tz )
setenv ( " TZ " , tz , 1 ) ;
else
unsetenv ( " TZ " ) ;
tzset ( ) ;
} ) ;
tz = getenv ( " TZ " ) ;
setenv ( " TZ " , " " , 1 ) ;
tzset ( ) ;
auto time_point = std : : chrono : : system_clock : : from_time_t ( k2017_April_27th ) ;
2023-11-30 16:17:45 -07:00
auto format = g3 : : localtime_formatted ( time_point , " %Y-%m-%d %H:%M:%S " ) ; // %Y/%m/%d
2017-04-27 22:57:04 -06:00
std : : string expected = { " 2017-04-27 06:22:27 " } ;
EXPECT_EQ ( expected , format ) ;
2023-11-30 16:17:45 -07:00
auto us_format = g3 : : localtime_formatted ( time_point , g3 : : internal : : time_formatted ) ; // "%H:%M:%S %f6";
2017-04-27 22:57:04 -06:00
EXPECT_EQ ( " 06:22:27 000000 " , us_format ) ;
auto ns_format = g3 : : localtime_formatted ( time_point , " %H:%M:%S %f " ) ;
EXPECT_EQ ( " 06:22:27 000000000 " , ns_format ) ;
auto ms_format = g3 : : localtime_formatted ( time_point , " %H:%M:%S %f3 " ) ;
EXPECT_EQ ( " 06:22:27 000 " , ms_format ) ;
2016-08-11 00:27:52 -06:00
}
2023-11-30 16:17:45 -07:00
# endif // timezone
2017-04-27 22:57:04 -06:00
2017-05-09 18:26:48 +02:00
# if defined(CHANGE_G3LOG_DEBUG_TO_DBUG)
TEST ( Level , G3LogDebug_is_DBUG ) {
2023-11-30 16:17:45 -07:00
LOG ( DBUG ) < < " DBUG equals G3LOG_DEBUG " ;
LOG ( G3LOG_DEBUG ) < < " G3LOG_DEBUG equals DBUG " ;
2017-05-09 18:26:48 +02:00
}
# else
TEST ( Level , G3LogDebug_is_DEBUG ) {
2023-11-30 16:17:45 -07:00
LOG ( DEBUG ) < < " DEBUG equals G3LOG_DEBUG " ;
LOG ( G3LOG_DEBUG ) < < " G3LOG_DEBUG equals DEBUG " ;
2017-05-09 18:26:48 +02:00
}
# endif
2016-08-11 00:27:52 -06:00
2017-03-30 22:52:09 -06:00
# ifdef G3_DYNAMIC_LOGGING
namespace {
using LevelsContainer = std : : map < int , g3 : : LoggingLevel > ;
const LevelsContainer g_test_log_level_defaults = {
2023-11-30 16:17:45 -07:00
{ G3LOG_DEBUG . value , { G3LOG_DEBUG } } ,
2017-03-30 22:52:09 -06:00
{ INFO . value , { INFO } } ,
{ WARNING . value , { WARNING } } ,
2023-11-30 16:17:45 -07:00
{ FATAL . value , { FATAL } } } ;
2017-03-30 22:52:09 -06:00
const LevelsContainer g_test_all_disabled = {
2023-11-30 16:17:45 -07:00
{ G3LOG_DEBUG . value , { G3LOG_DEBUG , false } } ,
2017-03-30 22:52:09 -06:00
{ INFO . value , { INFO , false } } ,
{ WARNING . value , { WARNING , false } } ,
2023-11-30 16:17:45 -07:00
{ FATAL . value , { FATAL , false } } } ;
2017-03-30 22:52:09 -06:00
2023-11-30 16:17:45 -07:00
bool mapCompare ( LevelsContainer const & lhs , LevelsContainer const & rhs ) {
auto pred = [ ] ( auto a , auto b ) {
2017-03-30 22:52:09 -06:00
return ( a . first = = b . first ) & &
( a . second = = b . second ) ;
} ;
2023-11-30 16:17:45 -07:00
return lhs . size ( ) = = rhs . size ( ) & & std : : equal ( lhs . begin ( ) , lhs . end ( ) , rhs . begin ( ) , pred ) ;
2017-03-30 22:52:09 -06:00
}
2023-11-30 16:17:45 -07:00
} // namespace
2017-03-30 22:52:09 -06:00
TEST ( Level , Default ) {
g3 : : only_change_at_initialization : : reset ( ) ;
2017-04-05 23:03:55 -06:00
auto defaults = g3 : : log_levels : : getAll ( ) ;
2017-03-30 22:52:09 -06:00
EXPECT_EQ ( defaults . size ( ) , g_test_log_level_defaults . size ( ) ) ;
EXPECT_TRUE ( mapCompare ( defaults , g_test_log_level_defaults ) ) ;
}
2017-04-05 23:03:55 -06:00
TEST ( Level , DefaultChanged_only_change_at_initialization ) {
2017-03-30 22:52:09 -06:00
g3 : : only_change_at_initialization : : reset ( ) ;
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2017-04-05 23:03:55 -06:00
g3 : : only_change_at_initialization : : addLogLevel ( INFO , false ) ;
auto defaults = g3 : : log_levels : : getAll ( ) ;
EXPECT_EQ ( defaults . size ( ) , g_test_log_level_defaults . size ( ) ) ;
EXPECT_FALSE ( mapCompare ( defaults , g_test_log_level_defaults ) ) ;
const LevelsContainer defaultsWithInfoChangged = {
2017-05-09 18:26:48 +02:00
{ G3LOG_DEBUG . value , { G3LOG_DEBUG , true } } ,
2017-04-05 23:03:55 -06:00
{ INFO . value , { INFO , false } } ,
{ WARNING . value , { WARNING , true } } ,
2023-11-30 16:17:45 -07:00
{ FATAL . value , { FATAL , true } } } ;
2017-04-05 23:03:55 -06:00
EXPECT_TRUE ( mapCompare ( defaults , defaultsWithInfoChangged ) ) ;
}
TEST ( Level , DefaultChanged_log_levels ) {
g3 : : only_change_at_initialization : : reset ( ) ;
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
g3 : : log_levels : : disable ( INFO ) ;
auto defaults = g3 : : log_levels : : getAll ( ) ;
2017-03-30 22:52:09 -06:00
EXPECT_EQ ( defaults . size ( ) , g_test_log_level_defaults . size ( ) ) ;
EXPECT_FALSE ( mapCompare ( defaults , g_test_log_level_defaults ) ) ;
const LevelsContainer defaultsWithInfoChangged = {
2017-05-09 18:26:48 +02:00
{ G3LOG_DEBUG . value , { G3LOG_DEBUG , true } } ,
2017-03-30 22:52:09 -06:00
{ INFO . value , { INFO , false } } ,
{ WARNING . value , { WARNING , true } } ,
2023-11-30 16:17:45 -07:00
{ FATAL . value , { FATAL , true } } } ;
2017-03-30 22:52:09 -06:00
EXPECT_TRUE ( mapCompare ( defaults , defaultsWithInfoChangged ) ) ;
}
TEST ( Level , Reset ) {
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2017-04-05 23:03:55 -06:00
g3 : : log_levels : : disableAll ( ) ;
auto all_levels = g3 : : log_levels : : getAll ( ) ;
2017-03-30 22:52:09 -06:00
EXPECT_TRUE ( mapCompare ( all_levels , g_test_all_disabled ) ) ;
g3 : : only_change_at_initialization : : reset ( ) ;
2017-04-05 23:03:55 -06:00
all_levels = g3 : : log_levels : : getAll ( ) ;
2017-03-30 22:52:09 -06:00
EXPECT_TRUE ( mapCompare ( all_levels , g_test_log_level_defaults ) ) ;
}
TEST ( Level , AllDisabled ) {
g3 : : only_change_at_initialization : : reset ( ) ;
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2017-04-05 23:03:55 -06:00
auto all_levels = g3 : : log_levels : : getAll ( ) ;
2017-03-30 22:52:09 -06:00
EXPECT_EQ ( all_levels . size ( ) , g_test_all_disabled . size ( ) ) ;
EXPECT_FALSE ( mapCompare ( all_levels , g_test_all_disabled ) ) ;
2017-04-05 23:03:55 -06:00
g3 : : log_levels : : disableAll ( ) ;
all_levels = g3 : : log_levels : : getAll ( ) ;
2017-03-30 22:52:09 -06:00
EXPECT_TRUE ( mapCompare ( all_levels , g_test_all_disabled ) ) ;
}
2017-04-05 23:03:55 -06:00
TEST ( Level , setHighestLogLevel_high_end ) {
g3 : : only_change_at_initialization : : reset ( ) ;
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2017-04-27 22:57:04 -06:00
g3 : : log_levels : : enableAll ( ) ;
g3 : : log_levels : : disable ( FATAL ) ;
g3 : : log_levels : : setHighest ( FATAL ) ;
2017-04-05 23:03:55 -06:00
2017-04-27 22:57:04 -06:00
LevelsContainer expected = {
2017-05-09 18:26:48 +02:00
{ G3LOG_DEBUG . value , { G3LOG_DEBUG , false } } ,
2017-04-05 23:03:55 -06:00
{ INFO . value , { INFO , false } } ,
{ WARNING . value , { WARNING , false } } ,
2023-11-30 16:17:45 -07:00
{ FATAL . value , { FATAL , true } } } ;
2017-04-05 23:03:55 -06:00
auto all_levels = g3 : : log_levels : : getAll ( ) ;
EXPECT_TRUE ( mapCompare ( all_levels , expected ) ) < < g3 : : log_levels : : to_string ( ) ;
}
TEST ( Level , setHighestLogLevel_low_end ) {
g3 : : only_change_at_initialization : : reset ( ) ;
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2017-04-27 22:57:04 -06:00
g3 : : log_levels : : disableAll ( ) ;
2017-05-09 18:26:48 +02:00
g3 : : log_levels : : setHighest ( G3LOG_DEBUG ) ;
2017-04-05 23:03:55 -06:00
2017-04-27 22:57:04 -06:00
LevelsContainer expected = {
2023-11-30 16:17:45 -07:00
{ G3LOG_DEBUG . value , { G3LOG_DEBUG , true } } ,
2017-04-05 23:03:55 -06:00
{ INFO . value , { INFO , true } } ,
{ WARNING . value , { WARNING , true } } ,
2023-11-30 16:17:45 -07:00
{ FATAL . value , { FATAL , true } } } ;
2017-04-05 23:03:55 -06:00
auto all_levels = g3 : : log_levels : : getAll ( ) ;
EXPECT_TRUE ( mapCompare ( all_levels , expected ) ) < < g3 : : log_levels : : to_string ( ) ;
}
TEST ( Level , setHighestLogLevel_middle ) {
g3 : : only_change_at_initialization : : reset ( ) ;
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2017-04-27 22:57:04 -06:00
g3 : : log_levels : : enableAll ( ) ;
g3 : : log_levels : : setHighest ( WARNING ) ;
2017-04-05 23:03:55 -06:00
2017-04-27 22:57:04 -06:00
LevelsContainer expected = {
2017-05-09 18:26:48 +02:00
{ G3LOG_DEBUG . value , { G3LOG_DEBUG , false } } ,
2017-04-05 23:03:55 -06:00
{ INFO . value , { INFO , false } } ,
{ WARNING . value , { WARNING , true } } ,
2023-11-30 16:17:45 -07:00
{ FATAL . value , { FATAL , true } } } ;
2017-04-05 23:03:55 -06:00
auto all_levels = g3 : : log_levels : : getAll ( ) ;
EXPECT_TRUE ( mapCompare ( all_levels , expected ) ) ;
}
2017-03-30 22:52:09 -06:00
TEST ( Level , setHighestLogLevel_StepWiseDisableAll ) {
g3 : : only_change_at_initialization : : reset ( ) ;
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
LevelsContainer changing_levels = {
2017-05-09 18:26:48 +02:00
{ G3LOG_DEBUG . value , { G3LOG_DEBUG , true } } ,
2017-03-30 22:52:09 -06:00
{ INFO . value , { INFO , true } } ,
{ WARNING . value , { WARNING , true } } ,
2023-11-30 16:17:45 -07:00
{ FATAL . value , { FATAL , true } } } ;
2017-03-30 22:52:09 -06:00
2017-04-05 23:03:55 -06:00
auto all_levels = g3 : : log_levels : : getAll ( ) ;
2017-03-30 22:52:09 -06:00
EXPECT_TRUE ( mapCompare ( all_levels , g_test_log_level_defaults ) ) ;
size_t counter = 0 ;
for ( auto & lvl : changing_levels ) {
2017-04-05 23:03:55 -06:00
g3 : : log_levels : : setHighest ( lvl . second . level ) ;
all_levels = g3 : : log_levels : : getAll ( ) ;
2017-03-30 22:52:09 -06:00
2023-11-30 16:17:45 -07:00
ASSERT_TRUE ( mapCompare ( all_levels , changing_levels ) ) < < " counter: " < < counter < < " \n system: \n "
< < g3 : : log_levels : : to_string ( all_levels ) < < " \n expected: \n "
< < g3 : : log_levels : : to_string ( changing_levels ) ;
2017-03-30 22:52:09 -06:00
+ + counter ;
if ( counter ! = changing_levels . size ( ) ) {
// for next round this level will be disabled
lvl . second . status = false ;
}
}
// in the end all except the last should be disabled
auto mostly_disabled = g_test_all_disabled ;
mostly_disabled [ FATAL . value ] . status = true ;
EXPECT_TRUE ( mapCompare ( changing_levels , mostly_disabled ) ) ;
2017-04-05 23:03:55 -06:00
all_levels = g3 : : log_levels : : getAll ( ) ;
2023-11-30 16:17:45 -07:00
EXPECT_TRUE ( mapCompare ( all_levels , mostly_disabled ) ) < < " \n system: \n "
< < g3 : : log_levels : : to_string ( all_levels ) < < " \n expected: \n "
< < g3 : : log_levels : : to_string ( mostly_disabled ) ;
2017-03-30 22:52:09 -06:00
}
TEST ( Level , Print ) {
g3 : : only_change_at_initialization : : reset ( ) ;
2023-11-30 16:17:45 -07:00
std : : string expected = std : : string { " name: DEBUG level: 100 status: 1 \n " } + " name: INFO level: 300 status: 1 \n " + " name: WARNING level: 500 status: 1 \n " + " name: FATAL level: 1000 status: 1 \n " ;
2017-04-05 23:03:55 -06:00
EXPECT_EQ ( g3 : : log_levels : : to_string ( ) , expected ) ;
2017-03-30 22:52:09 -06:00
}
TEST ( Level , AddOneEnabled_option1 ) {
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2023-11-30 16:17:45 -07:00
LEVELS MYINFO { WARNING . value + 1 , " MyInfoLevel " } ;
2017-04-05 23:03:55 -06:00
g3 : : only_change_at_initialization : : addLogLevel ( MYINFO , true ) ;
2017-03-30 22:52:09 -06:00
auto modified = g_test_log_level_defaults ;
modified [ MYINFO . value ] = MYINFO ;
2017-04-05 23:03:55 -06:00
auto all_levels = g3 : : log_levels : : getAll ( ) ;
2023-11-30 16:17:45 -07:00
EXPECT_TRUE ( mapCompare ( modified , all_levels ) ) < < " \n system: \n "
< < g3 : : log_levels : : to_string ( all_levels ) < < " \n expected: \n "
< < g3 : : log_levels : : to_string ( modified ) ;
2017-03-30 22:52:09 -06:00
}
TEST ( Level , AddOneEnabled_option2 ) {
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2023-11-30 16:17:45 -07:00
LEVELS MYINFO { WARNING . value + 1 , " MyInfoLevel " } ;
2017-03-30 22:52:09 -06:00
g3 : : only_change_at_initialization : : addLogLevel ( MYINFO ) ;
auto modified = g_test_log_level_defaults ;
modified [ MYINFO . value ] = MYINFO ;
2017-04-05 23:03:55 -06:00
auto all_levels = g3 : : log_levels : : getAll ( ) ;
2023-11-30 16:17:45 -07:00
EXPECT_TRUE ( mapCompare ( modified , all_levels ) ) < < " \n system: \n "
< < g3 : : log_levels : : to_string ( all_levels ) < < " \n expected: \n "
< < g3 : : log_levels : : to_string ( modified ) ;
2017-03-30 22:52:09 -06:00
}
TEST ( Level , Addlevel_using_addLevel ) {
2017-04-05 23:03:55 -06:00
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
2017-03-30 22:52:09 -06:00
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2023-11-30 16:17:45 -07:00
LEVELS MYINFO { WARNING . value + 1 , " MyInfoLevel " } ;
2017-04-05 23:03:55 -06:00
auto status = g3 : : log_levels : : getStatus ( MYINFO ) ;
EXPECT_EQ ( status , g3 : : log_levels : : status : : Absent ) ;
2017-03-30 22:52:09 -06:00
g3 : : only_change_at_initialization : : addLogLevel ( MYINFO ) ;
2017-04-05 23:03:55 -06:00
status = g3 : : log_levels : : getStatus ( MYINFO ) ;
EXPECT_EQ ( status , g3 : : log_levels : : status : : Enabled ) ;
2017-03-30 22:52:09 -06:00
}
2017-04-05 23:03:55 -06:00
TEST ( Level , Addlevel_using_addLogLevel_disabled ) {
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
2017-03-30 22:52:09 -06:00
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2023-11-30 16:17:45 -07:00
LEVELS MYINFO { WARNING . value + 1 , " MyInfoLevel " } ;
2017-04-05 23:03:55 -06:00
auto status = g3 : : log_levels : : getStatus ( MYINFO ) ;
EXPECT_EQ ( status , g3 : : log_levels : : status : : Absent ) ;
2017-03-30 22:52:09 -06:00
2017-04-05 23:03:55 -06:00
g3 : : only_change_at_initialization : : addLogLevel ( MYINFO , false ) ;
status = g3 : : log_levels : : getStatus ( MYINFO ) ;
EXPECT_EQ ( status , g3 : : log_levels : : status : : Disabled ) ;
2017-03-30 22:52:09 -06:00
}
2017-04-05 23:03:55 -06:00
TEST ( Level , Addlevel__disabled ) {
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
2017-03-30 22:52:09 -06:00
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2023-11-30 16:17:45 -07:00
LEVELS MYINFO { WARNING . value + 1 , " MyInfoLevel " } ;
2017-04-05 23:03:55 -06:00
auto status = g3 : : log_levels : : getStatus ( MYINFO ) ;
EXPECT_EQ ( status , g3 : : log_levels : : status : : Absent ) ;
g3 : : log_levels : : enable ( MYINFO ) ;
status = g3 : : log_levels : : getStatus ( MYINFO ) ;
EXPECT_EQ ( status , g3 : : log_levels : : status : : Absent ) ;
2017-03-30 22:52:09 -06:00
2017-04-05 23:03:55 -06:00
g3 : : log_levels : : set ( MYINFO , true ) ;
status = g3 : : log_levels : : getStatus ( MYINFO ) ;
EXPECT_EQ ( status , g3 : : log_levels : : status : : Absent ) ;
g3 : : only_change_at_initialization : : addLogLevel ( MYINFO , false ) ;
status = g3 : : log_levels : : getStatus ( MYINFO ) ;
EXPECT_EQ ( status , g3 : : log_levels : : status : : Disabled ) ;
2017-03-30 22:52:09 -06:00
}
2017-04-05 23:03:55 -06:00
TEST ( Level , Addlevel__enabled ) {
std : : shared_ptr < void > RaiiLeveReset ( nullptr , [ & ] ( void * ) {
2017-03-30 22:52:09 -06:00
g3 : : only_change_at_initialization : : reset ( ) ;
} ) ;
2023-11-30 16:17:45 -07:00
LEVELS MYINFO { WARNING . value + 1 , " MyInfoLevel " } ;
2017-04-05 23:03:55 -06:00
auto status = g3 : : log_levels : : getStatus ( MYINFO ) ;
EXPECT_EQ ( status , g3 : : log_levels : : status : : Absent ) ;
2017-03-30 22:52:09 -06:00
2017-04-05 23:03:55 -06:00
g3 : : only_change_at_initialization : : addLogLevel ( MYINFO ) ;
status = g3 : : log_levels : : getStatus ( MYINFO ) ;
EXPECT_EQ ( status , g3 : : log_levels : : status : : Enabled ) ;
2017-03-30 22:52:09 -06:00
}
2023-11-30 16:17:45 -07:00
# endif // G3_DYNAMIC_LOGGING