mirror of
https://github.com/KjellKod/g3log.git
synced 2025-01-19 00:46:03 +01:00
86473c60e0
* Added "removeSink" method and related functionality to LogWorker API * Added a new API for plugging in custom Timestamp generator. * Revert "Added "removeSink" method and related functionality to LogWorker API" This reverts commit c9cee5d9a077ce1e7e68f07cc30d03e4bed19c7b. * Dropping shared_ptr<Timestamp> in log messages and using regular vars * Moving to standard timespec struct from custom Timestamp * Wiring timespec timestamps with formating routine * Falling back to clock_gettime * Reverting g3 API changes * Optimizing format string generation * Removed _microseconds from LogMessage * Implemented sec fractional format key * Optimization of format string generation * Adjusting comments * Refining localtime_formatted by introducing two helper functions * refactored and simplified code * fixed up some commented away unit tests * refactoring message specifics tests to it's own test * Use gcc 4.9 * C++14 for Linux * Update .travis.yml * Update buildAndRunTests.sh * lower case in `-std=c++14` * -lrt flag for gcc * Added support for high precision clock on Linux/gcc (already there now for OSX). Windows is still missing * intermediate comments * Clarified for some code readers the mysterious use of assert in an expression that is always true * refactored + renamed functions and constants. Added unit test for retrieving fractional type * committing changes previously fixed - finished unit testing for g3::internal::time::GetFractional(..) * added unit test for fractional to string * added missing unit tests for localtime_formatted * fixed? nano / microsec functionality to timer * test
185 lines
6.8 KiB
C++
185 lines
6.8 KiB
C++
/** ==========================================================================
|
|
* 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>
|
|
#include <g3log/g3log.hpp>
|
|
#include <g3log/time.hpp>
|
|
#include <iostream>
|
|
#include <ctime>
|
|
|
|
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 {
|
|
std::cout << g3::localtime_formatted(g3::systemtime_now(), "%a %b %d %H:%M:%S %Y") << std::endl;
|
|
std::this_thread::sleep_for(std::chrono::seconds(1));
|
|
std::cout << g3::localtime_formatted(g3::systemtime_now(), "%%Y/%%m/%%d %%H:%%M:%%S = %Y/%m/%d %H:%M:%S") << std::endl;
|
|
#if (defined(WIN32) || defined(_WIN32) || defined(__WIN32__))
|
|
std::cerr << "Formatting options skipped due to VS2012, C++11 non-conformance for" << std::endl;
|
|
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;
|
|
#else
|
|
std::cout << "C++11 new formatting options:\n" << g3::localtime_formatted(g3::systemtime_now(), "%%EX: %EX\n%%z: %z\n%%Ec: %Ec") << std::endl;
|
|
#endif
|
|
}
|
|
// 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
|
|
catch (...) {
|
|
ADD_FAILURE() << "On this platform the library does not support given (C++11?) specifiers";
|
|
return;
|
|
}
|
|
ASSERT_TRUE(true); // no exception. all good
|
|
}
|
|
|
|
|
|
|
|
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);
|
|
}
|
|
|
|
TEST(Message, FractionalToString) {
|
|
timespec ts = {};
|
|
ts.tv_nsec = 123456789;
|
|
auto value = g3::internal::to_string(ts, g3::internal::Fractional::Nanosecond);
|
|
EXPECT_EQ("123456789", value);
|
|
value = g3::internal::to_string(ts, g3::internal::Fractional::NanosecondDefault);
|
|
EXPECT_EQ("123456789", value);
|
|
|
|
// us
|
|
value = g3::internal::to_string(ts, g3::internal::Fractional::Microsecond);
|
|
EXPECT_EQ("123456", value);
|
|
// ms
|
|
value = g3::internal::to_string(ts, g3::internal::Fractional::Millisecond);
|
|
EXPECT_EQ("123", value);
|
|
}
|
|
|
|
TEST(Message, FractionalToStringNanoPadded) {
|
|
timespec ts = {};
|
|
ts.tv_nsec = 1;
|
|
auto value = g3::internal::to_string(ts, g3::internal::Fractional::Nanosecond);
|
|
EXPECT_EQ("000000001", value);
|
|
// 0000000012
|
|
value = g3::internal::to_string(ts, g3::internal::Fractional::NanosecondDefault);
|
|
EXPECT_EQ("000000001", value);
|
|
}
|
|
|
|
TEST(Message, FractionalToString12NanoPadded) {
|
|
timespec ts = {};
|
|
ts.tv_nsec = 12;
|
|
auto value = g3::internal::to_string(ts, g3::internal::Fractional::Nanosecond);
|
|
EXPECT_EQ("000000012", value);
|
|
// 0000000012
|
|
value = g3::internal::to_string(ts, g3::internal::Fractional::NanosecondDefault);
|
|
EXPECT_EQ("000000012", value);
|
|
}
|
|
|
|
|
|
TEST(Message, FractionalToStringMicroPadded) {
|
|
timespec ts = {};
|
|
ts.tv_nsec = 1000;
|
|
auto value = g3::internal::to_string(ts, g3::internal::Fractional::Microsecond);
|
|
EXPECT_EQ("000001", value);
|
|
ts.tv_nsec = 11000;
|
|
value = g3::internal::to_string(ts, g3::internal::Fractional::Microsecond);
|
|
EXPECT_EQ("000011", value);
|
|
|
|
}
|
|
|
|
|
|
TEST(Message, FractionalToStringMilliPadded) {
|
|
timespec ts = {};
|
|
ts.tv_nsec = 1000000;
|
|
auto value = g3::internal::to_string(ts, g3::internal::Fractional::Millisecond);
|
|
EXPECT_EQ("001", value);
|
|
ts.tv_nsec = 21000000;
|
|
value = g3::internal::to_string(ts, g3::internal::Fractional::Millisecond);
|
|
EXPECT_EQ("021", value);
|
|
}
|
|
|
|
|
|
|
|
#if !(defined(WIN32) || defined(_WIN32) || defined(__WIN32__))
|
|
TEST(Message, localtime_formatted) {
|
|
struct tm tm;
|
|
time_t t;
|
|
|
|
ASSERT_TRUE(nullptr != strptime("2016-08-09 22:58:45", "%Y-%m-%d %H:%M:%S", &tm));
|
|
t = mktime(&tm);
|
|
timespec ts = {};
|
|
ts.tv_sec = t;
|
|
ts.tv_nsec = 123;
|
|
auto format = g3::localtime_formatted(ts, g3::internal::date_formatted); // %Y/%m/%d
|
|
EXPECT_EQ("2016/08/09", format);
|
|
|
|
auto us_format = g3::localtime_formatted(ts, g3::internal::time_formatted); // "%H:%M:%S %f6";
|
|
EXPECT_EQ("22:58:45 000000", us_format);
|
|
|
|
auto ns_format = g3::localtime_formatted(ts, "%H:%M:%S %f");
|
|
EXPECT_EQ("22:58:45 000000123", ns_format);
|
|
|
|
ts.tv_nsec = 1234000;
|
|
auto ms_format = g3::localtime_formatted(ts, "%H:%M:%S %f3");
|
|
EXPECT_EQ("22:58:45 001", ms_format);
|
|
}
|
|
#endif
|
|
|
|
|