cmCTestScriptHandler.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. /*=========================================================================
  2. Program: CMake - Cross-Platform Makefile Generator
  3. Module: $RCSfile$
  4. Language: C++
  5. Date: $Date$
  6. Version: $Revision$
  7. Copyright (c) 2002 Kitware, Inc. All rights reserved.
  8. See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
  9. This software is distributed WITHOUT ANY WARRANTY; without even
  10. the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
  11. PURPOSE. See the above copyright notices for more information.
  12. =========================================================================*/
  13. #ifndef cmCTestScriptHandler_h
  14. #define cmCTestScriptHandler_h
  15. #include "cmCTestGenericHandler.h"
  16. #include "cmListFileCache.h"
  17. class cmMakefile;
  18. class cmLocalGenerator;
  19. class cmGlobalGenerator;
  20. class cmake;
  21. class cmCTestCommand;
  22. /** \class cmCTestScriptHandler
  23. * \brief A class that handles ctest -S invocations
  24. *
  25. * CTest script is controlled using several variables that script has to
  26. * specify and some optional ones. Required ones are:
  27. * CTEST_SOURCE_DIRECTORY - Source directory of the project
  28. * CTEST_BINARY_DIRECTORY - Binary directory of the project
  29. * CTEST_COMMAND - Testing commands
  30. *
  31. * Optional variables are:
  32. * CTEST_BACKUP_AND_RESTORE
  33. * CTEST_CMAKE_COMMAND
  34. * CTEST_CMAKE_OUTPUT_FILE_NAME
  35. * CTEST_CONTINUOUS_DURATION
  36. * CTEST_CONTINUOUS_MINIMUM_INTERVAL
  37. * CTEST_CVS_CHECKOUT
  38. * CTEST_CVS_COMMAND
  39. * CTEST_UPDATE_COMMAND
  40. * CTEST_DASHBOARD_ROOT
  41. * CTEST_ENVIRONMENT
  42. * CTEST_INITIAL_CACHE
  43. * CTEST_START_WITH_EMPTY_BINARY_DIRECTORY
  44. * CTEST_START_WITH_EMPTY_BINARY_DIRECTORY_ONCE
  45. *
  46. * In addition the following variables can be used. The number can be 1-10.
  47. * CTEST_EXTRA_UPDATES_1
  48. * CTEST_EXTRA_UPDATES_2
  49. * ...
  50. * CTEST_EXTRA_UPDATES_10
  51. *
  52. * CTest script can use the following arguments CTest provides:
  53. * CTEST_SCRIPT_ARG
  54. * CTEST_SCRIPT_DIRECTORY
  55. * CTEST_SCRIPT_NAME
  56. *
  57. */
  58. class cmCTestScriptHandler : public cmCTestGenericHandler
  59. {
  60. public:
  61. cmTypeMacro(cmCTestScriptHandler, cmCTestGenericHandler);
  62. /**
  63. * Add a script to run, and if is should run in the current process
  64. */
  65. void AddConfigurationScript(const char *, bool pscope);
  66. /**
  67. * Run a dashboard using a specified confiuration script
  68. */
  69. int ProcessHandler();
  70. /*
  71. * Run a script
  72. */
  73. static bool RunScript(cmCTest* ctest, const char *script, bool InProcess,
  74. int* returnValue);
  75. int RunCurrentScript();
  76. /*
  77. * Empty Binary Directory
  78. */
  79. static bool EmptyBinaryDirectory(const char *dir);
  80. /*
  81. * Write an initial CMakeCache.txt from the given contents.
  82. */
  83. static bool WriteInitialCache(const char* directory, const char* text);
  84. /*
  85. * Some elapsed time handling functions
  86. */
  87. static void SleepInSeconds(unsigned int secondsToWait);
  88. void UpdateElapsedTime();
  89. /**
  90. * Return the time remaianing that the script is allowed to run in
  91. * seconds if the user has set the variable CTEST_TIME_LIMIT. If that has
  92. * not been set it returns 1e7 seconds
  93. */
  94. double GetRemainingTimeAllowed();
  95. cmCTestScriptHandler();
  96. ~cmCTestScriptHandler();
  97. void Initialize();
  98. void CreateCMake();
  99. void GetCommandDocumentation(std::vector<cmDocumentationEntry>& v) const;
  100. cmake* GetCMake() { return this->CMake;}
  101. private:
  102. // reads in a script
  103. int ReadInScript(const std::string& total_script_arg);
  104. int ExecuteScript(const std::string& total_script_arg);
  105. // extract vars from the script to set ivars
  106. int ExtractVariables();
  107. // perform a CVS checkout of the source dir
  108. int CheckOutSourceDir();
  109. // perform any extra cvs updates that were requested
  110. int PerformExtraUpdates();
  111. // backup and restore dirs
  112. int BackupDirectories();
  113. void RestoreBackupDirectories();
  114. int RunConfigurationScript(const std::string& script, bool pscope);
  115. int RunConfigurationDashboard();
  116. // Add ctest command
  117. void AddCTestCommand(cmCTestCommand* command);
  118. std::vector<cmStdString> ConfigurationScripts;
  119. std::vector<bool> ScriptProcessScope;
  120. bool Backup;
  121. bool EmptyBinDir;
  122. bool EmptyBinDirOnce;
  123. cmStdString SourceDir;
  124. cmStdString BinaryDir;
  125. cmStdString BackupSourceDir;
  126. cmStdString BackupBinaryDir;
  127. cmStdString CTestRoot;
  128. cmStdString CVSCheckOut;
  129. cmStdString CTestCmd;
  130. cmStdString UpdateCmd;
  131. cmStdString CTestEnv;
  132. cmStdString InitialCache;
  133. cmStdString CMakeCmd;
  134. cmStdString CMOutFile;
  135. std::vector<cmStdString> ExtraUpdates;
  136. double MinimumInterval;
  137. double ContinuousDuration;
  138. // what time in seconds did this script start running
  139. double ScriptStartTime;
  140. cmMakefile *Makefile;
  141. cmLocalGenerator *LocalGenerator;
  142. cmGlobalGenerator *GlobalGenerator;
  143. cmake *CMake;
  144. };
  145. #endif