benchmark/test
Brian Wolfe 99c52f1414
use rfc3339-formatted timestamps in output [output format change] (#965)
* timestamp: use rfc3339-formatted timestamps in output

Replace localized timestamps with machine-readable IETF RFC 3339 format
timestamps. This is an attempt to make the output timestamps easily
machine-readable. ISO8601 specifies standards for time interchange
formats. IETF RFC 3339: https://tools.ietf.org/html/rfc3339 defines a
subset of these for use in the internet. The general form for these
timestamps is:

YYYY-MM-DDTHH:mm:SS[+-]hhmm

This replaces the localized time formats that are currently being used
in the benchmark output to prioritize interchangeability and
machine-readability.

This might break existing programs that rely on the particular date-time
format. This might also may make times less human readable. RFC3339 was
intended to balance human readability and simplicity for machine
readability, but it is primarily intended as an internal representation.

* timers: remove utc string formatting

We only ever need local time printing. Remove the UTC printing
and cosnolidate the logic slightly.

* timers: manually create rfc3339 string

The C++ standard library does not output the time offset in RFC3339
format, it is missing the : between hours and minutes. VS does not
appear to support timezone information by default. To avoid adding too
much complexity to benchmark around timezone handling e.g. a full
date library like https://github.com/HowardHinnant/date, we fall back
to outputting GMT time with a -00:00 offset for those cases.

* timers: use reentrant form for localtime_r & tmtime_r

For non-windows, use the reentrant form for the time conversion
functions.

* timers: cleanup

Use strtol instead of brittle moving characters around.

* timers: only call strftime twice.

Also size buffers to known maximum necessary size and name constants
more appropriately.

* timers: fix unused variable warning
2020-06-15 17:28:17 +01:00
..
AssemblyTests.cmake
basic_test.cc
benchmark_gtest.cc
benchmark_name_gtest.cc
benchmark_test.cc
BUILD
clobber_memory_assembly_test.cc
CMakeLists.txt
commandlineflags_gtest.cc
complexity_test.cc
cxx03_test.cc
diagnostics_test.cc
display_aggregates_only_test.cc
donotoptimize_assembly_test.cc
donotoptimize_test.cc
filter_test.cc
fixture_test.cc
internal_threading_test.cc
link_main_test.cc
map_test.cc
memory_manager_test.cc
multiple_ranges_test.cc
options_test.cc
output_test.h
output_test_helper.cc
register_benchmark_test.cc
report_aggregates_only_test.cc
reporter_output_test.cc
skip_with_error_test.cc
state_assembly_test.cc
statistics_gtest.cc
string_util_gtest.cc
templated_fixture_test.cc
user_counters_tabular_test.cc
user_counters_test.cc
user_counters_thousands_test.cc