From 377bebb9101b2bcf67e92143243fe26dba8abf6d Mon Sep 17 00:00:00 2001 From: Brad King Date: Wed, 7 Jan 2009 10:41:37 -0500 Subject: ENH: Teach CTest to submit test property LABELS This teaches CTest to send the test property "LABELS" in Test.xml dashboard submissions as Label elements inside a Labels element. --- Source/CTest/cmCTestTestHandler.cxx | 41 ++++++++++++++++++++++++++++++++++++- Source/CTest/cmCTestTestHandler.h | 1 + Source/cmTest.cxx | 5 +++++ 3 files changed, 46 insertions(+), 1 deletion(-) diff --git a/Source/CTest/cmCTestTestHandler.cxx b/Source/CTest/cmCTestTestHandler.cxx index 46ab467..68c5855 100644 --- a/Source/CTest/cmCTestTestHandler.cxx +++ b/Source/CTest/cmCTestTestHandler.cxx @@ -1224,6 +1224,14 @@ void cmCTestTestHandler::LoadTestList() cmSystemTools::GetLineFromStream(fin, line); p.Environment.push_back(line); } + int numLabels = 0; + ok = ok && this->GetValue("Labels:", + numLabels, fin); + for(int j =0; j < numLabels; j++) + { + cmSystemTools::GetLineFromStream(fin, line); + p.Labels.push_back(line); + } if(!ok) { cmCTestLog(this->CTest, ERROR_MESSAGE, @@ -1316,6 +1324,13 @@ std::string cmCTestTestHandler::SaveTestList() { fout << *e << "\n"; } + fout << "Labels:\n" << + p.Labels.size() << "\n"; + for(std::vector::const_iterator e = + p.Labels.begin(); e != p.Labels.end(); ++e) + { + fout << *e << "\n"; + } } fout.close(); return fname; @@ -1513,7 +1528,21 @@ void cmCTestTestHandler::GenerateDartOutput(std::ostream& os) os << "\n" << "\t\t\t\n" - << "\t\t\n" + << "\t\t\n"; + + if(!result->Properties->Labels.empty()) + { + os << "\t\t\n"; + std::vector const& labels = result->Properties->Labels; + for(std::vector::const_iterator li = labels.begin(); + li != labels.end(); ++li) + { + os << "\t\t\t\n"; + } + os << "\t\t\n"; + } + + os << "\t" << std::endl; } @@ -2306,6 +2335,16 @@ bool cmCTestTestHandler::SetTestsProperties( rtit->Environment.push_back(*crit); } } + if ( key == "LABELS" ) + { + std::vector lval; + cmSystemTools::ExpandListArgument(val.c_str(), lval); + std::vector::iterator crit; + for ( crit = lval.begin(); crit != lval.end(); ++ crit ) + { + rtit->Labels.push_back(*crit); + } + } if ( key == "MEASUREMENT" ) { size_t pos = val.find_first_of("="); diff --git a/Source/CTest/cmCTestTestHandler.h b/Source/CTest/cmCTestTestHandler.h index 0b5fa09..e9b08cd 100644 --- a/Source/CTest/cmCTestTestHandler.h +++ b/Source/CTest/cmCTestTestHandler.h @@ -95,6 +95,7 @@ public: double Timeout; int Index; std::vector Environment; + std::vector Labels; }; struct cmCTestTestResult diff --git a/Source/cmTest.cxx b/Source/cmTest.cxx index 2abebd8..c7b1637 100644 --- a/Source/cmTest.cxx +++ b/Source/cmTest.cxx @@ -110,6 +110,11 @@ void cmTest::DefineProperties(cmake *cm) "For example: PASS_REGULAR_EXPRESSION \"[^a-z]Error;ERROR;Failed\""); cm->DefineProperty + ("LABELS", cmProperty::TEST, + "Specify a list of text labels associated with a test.", + "The list is reported in dashboard submissions."); + + cm->DefineProperty ("MEASUREMENT", cmProperty::TEST, "Specify a DART measurement and value to be reported for a test.", "If set to a name then that name will be reported to DART as a " -- cgit v0.12