summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndy Cedilnik <andy.cedilnik@kitware.com>2005-07-13 14:17:18 (GMT)
committerAndy Cedilnik <andy.cedilnik@kitware.com>2005-07-13 14:17:18 (GMT)
commit1e72091e8631f1a94262a1a10b58d6b0a975db01 (patch)
tree8b202ee25eff6a384365522cc8a8ffce94a7414a
parent3e020b3dccd0599bda35f801b54d35092833ee0e (diff)
downloadCMake-1e72091e8631f1a94262a1a10b58d6b0a975db01.zip
CMake-1e72091e8631f1a94262a1a10b58d6b0a975db01.tar.gz
CMake-1e72091e8631f1a94262a1a10b58d6b0a975db01.tar.bz2
ENH: Add timeout support
-rw-r--r--Source/CTest/cmCTestTestCommand.cxx12
-rw-r--r--Source/cmCTest.h1
2 files changed, 13 insertions, 0 deletions
diff --git a/Source/CTest/cmCTestTestCommand.cxx b/Source/CTest/cmCTestTestCommand.cxx
index 6be718c..a802f92 100644
--- a/Source/CTest/cmCTestTestCommand.cxx
+++ b/Source/CTest/cmCTestTestCommand.cxx
@@ -30,6 +30,18 @@ cmCTestTestCommand::cmCTestTestCommand()
cmCTestGenericHandler* cmCTestTestCommand::InitializeHandler()
{
+ const char* ctestTimeout = m_Makefile->GetDefinition("CTEST_TEST_TIMEOUT");
+ double timeout = m_CTest->GetTimeOut();
+ if ( ctestTimeout )
+ {
+ timeout = atof(ctestTimeout);
+ }
+ else
+ {
+ // By default use timeout of 10 minutes
+ timeout = 600;
+ }
+ m_CTest->SetTimeOut(timeout);
cmCTestGenericHandler* handler = m_CTest->GetInitializedHandler("test");
if ( m_Values[ctt_START] || m_Values[ctt_END] || m_Values[ctt_STRIDE] )
{
diff --git a/Source/cmCTest.h b/Source/cmCTest.h
index 3cc3fe4..9ca2844 100644
--- a/Source/cmCTest.h
+++ b/Source/cmCTest.h
@@ -92,6 +92,7 @@ public:
///! what is the configuraiton type, e.g. Debug, Release etc.
std::string GetConfigType();
double GetTimeOut() { return m_TimeOut; }
+ void SetTimeOut(double t) { m_TimeOut = t; }
/**
* Check if CTest file exists