summaryrefslogtreecommitdiffstats
path: root/Source/cmCTest.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmCTest.cxx')
-rw-r--r--Source/cmCTest.cxx57
1 files changed, 52 insertions, 5 deletions
diff --git a/Source/cmCTest.cxx b/Source/cmCTest.cxx
index 7eb2ba3..88cc4aa 100644
--- a/Source/cmCTest.cxx
+++ b/Source/cmCTest.cxx
@@ -3530,12 +3530,9 @@ int cmCTest::RunConfigurationScript(const std::string& total_script_arg)
const char *srcDir = mf->GetDefinition("CTEST_SOURCE_DIRECTORY");
const char *binDir = mf->GetDefinition("CTEST_BINARY_DIRECTORY");
const char *ctestCmd = mf->GetDefinition("CTEST_COMMAND");
- const char *ctestEnv = mf->GetDefinition("CTEST_ENVIRONMENT");
- const char *ctestRoot = mf->GetDefinition("CTEST_DASHBOARD_ROOT");
bool backup = mf->IsOn("CTEST_BACKUP_AND_RESTORE");
// in order to back we also must have the cvs root
- const char *cvsCmd = mf->GetDefinition("CTEST_CVS_COMMAND");
const char *cvsCheckOut = mf->GetDefinition("CTEST_CVS_CHECKOUT");
if (backup && !cvsCheckOut)
{
@@ -3551,6 +3548,7 @@ int cmCTest::RunConfigurationScript(const std::string& total_script_arg)
}
// set any environment variables
+ const char *ctestEnv = mf->GetDefinition("CTEST_ENVIRONMENT");
if (ctestEnv)
{
std::vector<std::string> envArgs;
@@ -3562,6 +3560,55 @@ int cmCTest::RunConfigurationScript(const std::string& total_script_arg)
}
}
+ // now that we have done most of the error checking finally run the
+ // dashboard, we may be asked to repeatedly run this dashboard, such as
+ // for a continuous
+ if (mf->GetDefinition("CTEST_CONTINUOUS_DURATION"))
+ {
+ // the *60 is becuase the settings are in minutes but GetTime is seconds
+ double minimumInterval = 30*60;
+ if (mf->GetDefinition("CTEST_CONTINUOUS_MINIMUM_INTERVAL"))
+ {
+ minimumInterval =
+ 60*atof(mf->GetDefinition("CTEST_CONTINUOUS_MINIMUM_INTERVAL"));
+ }
+ double duration = 60.0*atof(mf->GetDefinition("CTEST_CONTINUOUS_DURATION"));
+ double clock_start = cmSystemTools::GetTime();
+ while (cmSystemTools::GetTime() < clock_start + duration)
+ {
+ double clock_recent_start = cmSystemTools::GetTime();
+ this->RunConfigurationDashboard(mf, srcDir, binDir, backup,
+ cvsCheckOut, ctestCmd);
+ double interval = cmSystemTools::GetTime() - clock_recent_start;
+ if (interval < minimumInterval)
+ {
+ unsigned int secondsToWait =
+ static_cast<unsigned int>(minimumInterval - interval);
+#if defined(_WIN32)
+ Sleep(1000*secondsToWait);
+#else
+ sleep(secondsToWait);
+#endif
+ }
+ }
+ }
+ // otherwise just run it once
+ else
+ {
+ return this->RunConfigurationDashboard(mf, srcDir, binDir,
+ backup, cvsCheckOut, ctestCmd);
+ }
+ return 0;
+}
+
+int cmCTest::RunConfigurationDashboard(cmMakefile *mf,
+ const char *srcDir, const char *binDir,
+ bool backup, const char *cvsCheckOut,
+ const char *ctestCmd)
+{
+ const char *ctestRoot = mf->GetDefinition("CTEST_DASHBOARD_ROOT");
+ const char *cvsCmd = mf->GetDefinition("CTEST_CVS_COMMAND");
+
// local variables
std::string command;
std::string output;
@@ -3598,8 +3645,8 @@ int cmCTest::RunConfigurationScript(const std::string& total_script_arg)
std::cerr << "Run cvs: " << cvsCheckOut << std::endl;
}
res = cmSystemTools::RunSingleCommand(cvsCheckOut, &output,
- &retVal, ctestRoot,
- m_Verbose, 0 /*m_TimeOut*/);
+ &retVal, ctestRoot,
+ m_Verbose, 0 /*m_TimeOut*/);
if (!res || retVal != 0)
{
cmSystemTools::Error("Unable to perform cvs checkout ");