21static constexpr std::array<std::string_view, 7>
weekdays{
"Thu",
"Fri",
"Sat",
"Sun",
"Mon",
"Tue",
"Wed"};
22static constexpr std::array<std::string_view, 12>
months{
"Jan",
"Feb",
"Mar",
"Apr",
"May",
"Jun",
"Jul",
"Aug",
"Sep",
"Oct",
"Nov",
"Dec"};
32 const auto mocktime{
g_mock_time.load(std::memory_order_relaxed)};
33 if (!mocktime.count()) {
39 std::chrono::system_clock::now().time_since_epoch()};
60 if (!mocktime.count()) {
66 std::chrono::steady_clock::now().time_since_epoch()};
85 const std::chrono::sys_seconds
secs{std::chrono::seconds{nTime}};
86 const auto days{std::chrono::floor<std::chrono::days>(
secs)};
87 const std::chrono::year_month_day
ymd{
days};
89 return strprintf(
"%04i-%02u-%02uT%02i:%02i:%02iZ",
signed{
ymd.year()},
unsigned{
ymd.month()},
unsigned{
ymd.day()},
hms.hours().
count(),
hms.minutes().count(),
hms.seconds().count());
94 const std::chrono::sys_seconds
secs{std::chrono::seconds{nTime}};
95 const auto days{std::chrono::floor<std::chrono::days>(
secs)};
96 const std::chrono::year_month_day
ymd{
days};
97 return strprintf(
"%04i-%02u-%02u",
signed{
ymd.year()},
unsigned{
ymd.month()},
unsigned{
ymd.day()});
102 constexpr auto FMT_SIZE{std::string_view{
"2000-01-01T01:01:01Z"}.size()};
103 if (str.size() !=
FMT_SIZE || str[4] !=
'-' || str[7] !=
'-' || str[10] !=
'T' || str[13] !=
':' || str[16] !=
':' || str[19] !=
'Z') {
115 const std::chrono::year_month_day
ymd{std::chrono::year{*
year}, std::chrono::month{*
month}, std::chrono::day{*
day}};
119 const auto time{std::chrono::hours{*
hour} + std::chrono::minutes{*min} + std::chrono::seconds{*
sec}};
120 const auto tp{std::chrono::sys_days{
ymd} + time};
126 if (time < -62167219200 || 253402300799 < time) {
130 const std::chrono::sys_seconds
secs{std::chrono::seconds{time}};
131 const auto days{std::chrono::floor<std::chrono::days>(
secs)};
132 const auto w{
days.time_since_epoch().count() % 7};
134 const std::chrono::year_month_day
ymd{
days};
145 timeout.tv_sec = nTimeout / 1000;
146 timeout.tv_usec = (nTimeout % 1000) * 1000;
#define Assert(val)
Identity function.
std::atomic< bool > g_used_system_time
static void SetMockTime(mock_time_point::duration mock_time_in)
Set mock time for testing.
static time_point now() noexcept
Return current system time or mocked time, if set.
static void ClearMockTime()
Clear mock time, go back to system steady clock.
std::chrono::time_point< MockableSteadyClock > time_point
static time_point now() noexcept
Return current system time or mocked time, if set.
std::chrono::time_point< NodeClock > time_point
struct timeval MillisToTimeval(int64_t nTimeout)
Convert milliseconds to a struct timeval for e.g.
void UninterruptibleSleep(const std::chrono::microseconds &n)
std::chrono::seconds GetMockTime()
For testing.
int64_t GetTime()
DEPRECATED Use either ClockType::now() or Now<TimePointType>() if a cast is needed.
static constexpr std::array< std::string_view, 7 > weekdays
std::string FormatISO8601Date(int64_t nTime)
void SetMockTime(int64_t nMockTimeIn)
DEPRECATED Use SetMockTime with chrono type.
std::optional< int64_t > ParseISO8601DateTime(std::string_view str)
std::string FormatRFC1123DateTime(int64_t time)
RFC1123 formatting https://www.rfc-editor.org/rfc/rfc1123#section-5.2.14 Used in HTTP/1....
static std::atomic< std::chrono::seconds > g_mock_time
For testing.
static constexpr std::array< std::string_view, 12 > months
static std::atomic< MockableSteadyClock::mock_time_point::duration > g_mock_steady_time
For testing.
std::string FormatISO8601DateTime(int64_t nTime)
ISO 8601 formatting is preferred.
std::atomic< bool > g_used_system_time
constexpr int64_t count_milliseconds(std::chrono::milliseconds t)
constexpr auto Ticks(Dur2 d)
Helper to count the seconds of a duration/time_point.