mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-07 06:09:52 -06:00
It was reported in issue #17345 that CTest does not use monotonic time to report test duration. Monotonic clocks are not affected by large NTP adjustments or things like daylight savings time. As CMake 3.10 requires C++11, which introduced std::chrono, this commit moves the time keeping in CTest from cmSystemTools::GetTime() to std::chrono::steady_clock. Fixes: #17345
169 lines
4.3 KiB
C++
169 lines
4.3 KiB
C++
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
|
#ifndef cmCTestScriptHandler_h
|
|
#define cmCTestScriptHandler_h
|
|
|
|
#include "cmConfigure.h" // IWYU pragma: keep
|
|
|
|
#include "cmCTestGenericHandler.h"
|
|
|
|
#include <chrono>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
class cmCTest;
|
|
class cmCTestCommand;
|
|
class cmGlobalGenerator;
|
|
class cmMakefile;
|
|
class cmake;
|
|
|
|
/** \class cmCTestScriptHandler
|
|
* \brief A class that handles ctest -S invocations
|
|
*
|
|
* CTest script is controlled using several variables that script has to
|
|
* specify and some optional ones. Required ones are:
|
|
* CTEST_SOURCE_DIRECTORY - Source directory of the project
|
|
* CTEST_BINARY_DIRECTORY - Binary directory of the project
|
|
* CTEST_COMMAND - Testing commands
|
|
*
|
|
* Optional variables are:
|
|
* CTEST_BACKUP_AND_RESTORE
|
|
* CTEST_CMAKE_COMMAND
|
|
* CTEST_CMAKE_OUTPUT_FILE_NAME
|
|
* CTEST_CONTINUOUS_DURATION
|
|
* CTEST_CONTINUOUS_MINIMUM_INTERVAL
|
|
* CTEST_CVS_CHECKOUT
|
|
* CTEST_CVS_COMMAND
|
|
* CTEST_UPDATE_COMMAND
|
|
* CTEST_DASHBOARD_ROOT
|
|
* CTEST_ENVIRONMENT
|
|
* CTEST_INITIAL_CACHE
|
|
* CTEST_START_WITH_EMPTY_BINARY_DIRECTORY
|
|
* CTEST_START_WITH_EMPTY_BINARY_DIRECTORY_ONCE
|
|
*
|
|
* In addition the following variables can be used. The number can be 1-10.
|
|
* CTEST_EXTRA_UPDATES_1
|
|
* CTEST_EXTRA_UPDATES_2
|
|
* ...
|
|
* CTEST_EXTRA_UPDATES_10
|
|
*
|
|
* CTest script can use the following arguments CTest provides:
|
|
* CTEST_SCRIPT_ARG
|
|
* CTEST_SCRIPT_DIRECTORY
|
|
* CTEST_SCRIPT_NAME
|
|
*
|
|
*/
|
|
class cmCTestScriptHandler : public cmCTestGenericHandler
|
|
{
|
|
public:
|
|
typedef cmCTestGenericHandler Superclass;
|
|
|
|
/**
|
|
* Add a script to run, and if is should run in the current process
|
|
*/
|
|
void AddConfigurationScript(const char*, bool pscope);
|
|
|
|
/**
|
|
* Run a dashboard using a specified confiuration script
|
|
*/
|
|
int ProcessHandler() override;
|
|
|
|
/*
|
|
* Run a script
|
|
*/
|
|
static bool RunScript(cmCTest* ctest, const char* script, bool InProcess,
|
|
int* returnValue);
|
|
int RunCurrentScript();
|
|
|
|
/*
|
|
* Empty Binary Directory
|
|
*/
|
|
static bool EmptyBinaryDirectory(const char* dir);
|
|
|
|
/*
|
|
* Write an initial CMakeCache.txt from the given contents.
|
|
*/
|
|
static bool WriteInitialCache(const char* directory, const char* text);
|
|
|
|
/*
|
|
* Some elapsed time handling functions
|
|
*/
|
|
static void SleepInSeconds(unsigned int secondsToWait);
|
|
void UpdateElapsedTime();
|
|
|
|
/**
|
|
* Return the time remaianing that the script is allowed to run in
|
|
* seconds if the user has set the variable CTEST_TIME_LIMIT. If that has
|
|
* not been set it returns 1e7 seconds
|
|
*/
|
|
double GetRemainingTimeAllowed();
|
|
|
|
cmCTestScriptHandler();
|
|
~cmCTestScriptHandler() override;
|
|
|
|
void Initialize() override;
|
|
|
|
void CreateCMake();
|
|
cmake* GetCMake() { return this->CMake; }
|
|
|
|
private:
|
|
// reads in a script
|
|
int ReadInScript(const std::string& total_script_arg);
|
|
int ExecuteScript(const std::string& total_script_arg);
|
|
|
|
// extract vars from the script to set ivars
|
|
int ExtractVariables();
|
|
|
|
// perform a CVS checkout of the source dir
|
|
int CheckOutSourceDir();
|
|
|
|
// perform any extra cvs updates that were requested
|
|
int PerformExtraUpdates();
|
|
|
|
// backup and restore dirs
|
|
int BackupDirectories();
|
|
void RestoreBackupDirectories();
|
|
|
|
int RunConfigurationScript(const std::string& script, bool pscope);
|
|
int RunConfigurationDashboard();
|
|
|
|
// Add ctest command
|
|
void AddCTestCommand(std::string const& name, cmCTestCommand* command);
|
|
|
|
// Try to remove the binary directory once
|
|
static bool TryToRemoveBinaryDirectoryOnce(const std::string& directoryPath);
|
|
|
|
std::vector<std::string> ConfigurationScripts;
|
|
std::vector<bool> ScriptProcessScope;
|
|
|
|
bool Backup;
|
|
bool EmptyBinDir;
|
|
bool EmptyBinDirOnce;
|
|
|
|
std::string SourceDir;
|
|
std::string BinaryDir;
|
|
std::string BackupSourceDir;
|
|
std::string BackupBinaryDir;
|
|
std::string CTestRoot;
|
|
std::string CVSCheckOut;
|
|
std::string CTestCmd;
|
|
std::string UpdateCmd;
|
|
std::string CTestEnv;
|
|
std::string InitialCache;
|
|
std::string CMakeCmd;
|
|
std::string CMOutFile;
|
|
std::vector<std::string> ExtraUpdates;
|
|
|
|
double MinimumInterval;
|
|
double ContinuousDuration;
|
|
|
|
// what time in seconds did this script start running
|
|
std::chrono::steady_clock::time_point ScriptStartTime;
|
|
|
|
cmMakefile* Makefile;
|
|
cmGlobalGenerator* GlobalGenerator;
|
|
cmake* CMake;
|
|
};
|
|
|
|
#endif
|