g3log/test_unit/test_message.cpp
Kjell Hedström 86473c60e0 Gimesketvirtadien's time requested changes (#104)
* 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
2016-08-11 00:27:52 -06:00

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