diff options
author | Brad King <brad.king@kitware.com> | 2017-12-15 12:49:26 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2018-01-08 17:55:00 (GMT) |
commit | 2567e5df69c1a4276c5e51dfa6c49482b24b1545 (patch) | |
tree | 6e37780463de7b012829388d4873f3624392f3b3 /Source/CTest | |
parent | 1138feb38f4e6d259ded23312b7f0f2184ac816a (diff) | |
download | CMake-2567e5df69c1a4276c5e51dfa6c49482b24b1545.zip CMake-2567e5df69c1a4276c5e51dfa6c49482b24b1545.tar.gz CMake-2567e5df69c1a4276c5e51dfa6c49482b24b1545.tar.bz2 |
cmCTest: Refactor stop time calculations
Calculate the stop time up front instead of re-parsing its string for
every test.
Diffstat (limited to 'Source/CTest')
-rw-r--r-- | Source/CTest/cmCTestRunTest.cxx | 43 |
1 files changed, 3 insertions, 40 deletions
diff --git a/Source/CTest/cmCTestRunTest.cxx b/Source/CTest/cmCTestRunTest.cxx index 0a27138..8050b9a 100644 --- a/Source/CTest/cmCTestRunTest.cxx +++ b/Source/CTest/cmCTestRunTest.cxx @@ -9,7 +9,6 @@ #include "cmSystemTools.h" #include "cmWorkingDirectory.h" -#include "cm_curl.h" #include "cm_zlib.h" #include "cmsys/Base64.h" #include "cmsys/Process.h" @@ -18,7 +17,6 @@ #include <iomanip> #include <sstream> #include <stdio.h> -#include <time.h> #include <utility> cmCTestRunTest::cmCTestRunTest(cmCTestTestHandler* handler) @@ -607,48 +605,13 @@ std::chrono::duration<double> cmCTestRunTest::ResolveTimeout() { auto timeout = this->TestProperties->Timeout; - if (this->CTest->GetStopTime().empty()) { + std::chrono::system_clock::time_point stop_time = this->CTest->GetStopTime(); + if (stop_time == std::chrono::system_clock::time_point()) { return timeout; } - struct tm* lctime; - time_t current_time = time(nullptr); - lctime = gmtime(¤t_time); - int gm_hour = lctime->tm_hour; - time_t gm_time = mktime(lctime); - lctime = localtime(¤t_time); - int local_hour = lctime->tm_hour; - int tzone_offset = local_hour - gm_hour; - if (gm_time > current_time && gm_hour < local_hour) { - // this means gm_time is on the next day - tzone_offset -= 24; - } else if (gm_time < current_time && gm_hour > local_hour) { - // this means gm_time is on the previous day - tzone_offset += 24; - } - - tzone_offset *= 100; - char buf[1024]; - // add todays year day and month to the time in str because - // curl_getdate no longer assumes the day is today - sprintf(buf, "%d%02d%02d %s %+05i", lctime->tm_year + 1900, - lctime->tm_mon + 1, lctime->tm_mday, - this->CTest->GetStopTime().c_str(), tzone_offset); - - time_t stop_time_t = curl_getdate(buf, ¤t_time); - if (stop_time_t == -1) { - return timeout; - } - - auto stop_time = std::chrono::system_clock::from_time_t(stop_time_t); - - // the stop time refers to the next day - if (this->CTest->NextDayStopTime) { - stop_time += std::chrono::hours(24); - } auto stop_timeout = - (stop_time - std::chrono::system_clock::from_time_t(current_time)) % - std::chrono::hours(24); + (stop_time - std::chrono::system_clock::now()) % std::chrono::hours(24); if (stop_timeout <= std::chrono::duration<double>::zero()) { cmCTestLog(this->CTest, ERROR_MESSAGE, "The stop time has been passed. " |