Commit e5b392ec authored by louiz’'s avatar louiz’

Fix parse_datetime by always using a 'z' as the timezone

Because some plateform accept Z and z, but some only accept z…
parent fca25b77
...@@ -14,8 +14,9 @@ std::string to_string(const std::time_t& timestamp) ...@@ -14,8 +14,9 @@ std::string to_string(const std::time_t& timestamp)
std::time_t parse_datetime(const std::string& stamp) std::time_t parse_datetime(const std::string& stamp)
{ {
auto stamp2 = stamp.substr(0, stamp.size() - 1) + "z";
struct tm tm; struct tm tm;
if (!::strptime(stamp.data(), "%FT%T%Z", &tm)) if (!::strptime(stamp2.data(), "%FT%T%Z", &tm))
return -1; return -1;
auto res = ::timegm(&tm); auto res = ::timegm(&tm);
return res; return res;
......
...@@ -124,10 +124,7 @@ TEST_CASE("time_to_string") ...@@ -124,10 +124,7 @@ TEST_CASE("time_to_string")
TEST_CASE("parse_datetime") TEST_CASE("parse_datetime")
{ {
const auto time = utils::parse_datetime("1970-01-01T00:00:00Z"); CHECK(utils::parse_datetime("1970-01-01T00:00:00z") == 0);
CHECK(time == 0); CHECK(utils::parse_datetime("2016-08-29T14:29:29Z") == 1472480969);
CHECK(utils::parse_datetime("2016-08-29T14:29:28Z") == 1472480968);
CHECK(utils::parse_datetime("2016-08-29T14:29:28UT") == 1472480968);
CHECK(utils::parse_datetime("2016-08-29T14:29:28GMT") == 1472480968);
CHECK(utils::parse_datetime("blah") == -1); CHECK(utils::parse_datetime("blah") == -1);
} }
\ No newline at end of file
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment