summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmCTest.cxx89
-rw-r--r--Source/cmCTest.h10
-rw-r--r--Source/ctest.cxx12
3 files changed, 108 insertions, 3 deletions
diff --git a/Source/cmCTest.cxx b/Source/cmCTest.cxx
index 136f2d2..c1c3331 100644
--- a/Source/cmCTest.cxx
+++ b/Source/cmCTest.cxx
@@ -470,6 +470,10 @@ bool cmCTest::SetTest(const char* ttype)
{
m_Tests[cmCTest::MEMCHECK_TEST] = 1;
}
+ else if ( cmSystemTools::LowerCase(ttype) == "notes" )
+ {
+ m_Tests[cmCTest::NOTES_TEST] = 1;
+ }
else if ( cmSystemTools::LowerCase(ttype) == "submit" )
{
m_Tests[cmCTest::SUBMIT_TEST] = 1;
@@ -924,7 +928,8 @@ int cmCTest::ConfigureDirectory()
std::ofstream os;
if ( !this->OpenOutputFile(m_CurrentTag, "Configure.xml", os) )
{
- std::cerr << "Cannot open log file" << std::endl;
+ std::cerr << "Cannot open configure file" << std::endl;
+ return 1;
}
std::string start_time = ::CurrentTime();
@@ -2194,6 +2199,10 @@ int cmCTest::SubmitResults()
{
files.push_back("Purify.xml");
}
+ if ( this->CTestFileExists("Notes.xml") )
+ {
+ files.push_back("Notes.xml");
+ }
cmCTestSubmit submit;
submit.SetVerbose(m_Verbose);
if ( m_DartConfiguration["DropMethod"] == "" ||
@@ -3259,3 +3268,81 @@ bool cmCTest::ProcessMemCheckOutput(const std::string& str, std::string& log, in
return true;
}
+
+int cmCTest::GenerateDartNotesOutput(std::ostream& os, const cmCTest::tm_VectorOfStrings& files)
+{
+ cmCTest::tm_VectorOfStrings::const_iterator it;
+ for ( it = files.begin(); it != files.end(); it ++ )
+ {
+ if ( !cmSystemTools::FileExists(it->c_str()) )
+ {
+ std::cerr << "Error creating notes. File " << it->c_str() << " does not exists" << std::endl;
+ return 0;
+ }
+ }
+
+ os << "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
+ << "<?xml-stylesheet type=\"text/xsl\" href=\"Dart/Source/Server/XSL/Build.xsl <file:///Dart/Source/Server/XSL/Build.xsl> \"?>\n"
+ << "<Site BuildName=\"" << m_DartConfiguration["BuildName"] << "\" BuildStamp=\""
+ << m_CurrentTag << "-" << this->GetTestModelString() << "\" Name=\""
+ << m_DartConfiguration["Site"] << "\">\n"
+ << "<Notes>" << std::endl;
+
+ for ( it = files.begin(); it != files.end(); it ++ )
+ {
+ std::cout << "\tAdd file: " << it->c_str() << std::endl;
+ std::string note_time = ::CurrentTime();
+ os << "<Note>\n"
+ << "<DateTime>" << note_time << "</DateTime>\n"
+ << "<Text>" << std::endl;
+ std::ifstream ifs(it->c_str());
+ if ( ifs )
+ {
+ std::string line;
+ while ( cmSystemTools::GetLineFromStream(ifs, line) )
+ {
+ os << this->MakeXMLSafe(line) << std::endl;
+ }
+ ifs.close();
+ }
+ else
+ {
+ os << "Problem reading file: " << it->c_str() << std::endl;
+ std::cerr << "Problem reading file: " << it->c_str() << " while creating notes" << std::endl;
+ }
+ os << "</Text>\n"
+ << "</Note>" << std::endl;
+ }
+ os << "</Notes>\n"
+ << "</Site>" << std::endl;
+ return 1;
+}
+
+int cmCTest::GenerateNotesFile(const char* cfiles)
+{
+ if ( !cfiles )
+ {
+ return 1;
+ }
+
+ std::vector<cmStdString> files;
+
+ std::cout << "Create notes file" << std::endl;
+
+ files = cmSystemTools::SplitString(cfiles, ';');
+ if ( files.size() == 0 )
+ {
+ return 1;
+ }
+
+ std::ofstream ofs;
+ if ( !this->OpenOutputFile(m_CurrentTag, "Notes.xml", ofs) )
+ {
+ std::cerr << "Cannot open notes file" << std::endl;
+ return 1;
+ }
+
+ this->GenerateDartNotesOutput(ofs, files);
+ return 0;
+}
+
diff --git a/Source/cmCTest.h b/Source/cmCTest.h
index 8321581..6fe457b 100644
--- a/Source/cmCTest.h
+++ b/Source/cmCTest.h
@@ -137,6 +137,8 @@ public:
CONTINUOUS
};
+ int GenerateNotesFile(const char* files);
+
private:
enum {
FIRST_TEST = 0,
@@ -148,8 +150,9 @@ private:
COVERAGE_TEST = 6,
MEMCHECK_TEST = 7,
SUBMIT_TEST = 8,
- ALL_TEST = 9,
- LAST_TEST = 10
+ NOTES_TEST = 9,
+ ALL_TEST = 10,
+ LAST_TEST = 11
};
enum { // Program statuses
@@ -313,6 +316,9 @@ private:
//! End CTest XML output file
void EndXML(std::ostream& ostr);
+ //! Create not from files.
+ int GenerateDartNotesOutput(std::ostream& os, const tm_VectorOfStrings& files);
+
//! Parse Valgrind/Purify/Bounds Checker result out of the output string. After running,
// log holds the output and results hold the different memmory errors.
bool ProcessMemCheckOutput(const std::string& str, std::string& log, int* results);
diff --git a/Source/ctest.cxx b/Source/ctest.cxx
index 902955d..1c037b2 100644
--- a/Source/ctest.cxx
+++ b/Source/ctest.cxx
@@ -79,6 +79,8 @@ static const cmDocumentationEntry cmDocumentationOptions[] =
"ctest will do what is required to create and run a dashboard. This "
"option basically sets up a dashboard and then runs ctest -D with the "
"appropriate options."},
+ {"-A <Notes file>", "Add a notes file with submission",
+ "This option tells ctest to include a notes file when submitting dashboard. "},
{0,0,0}
};
@@ -376,6 +378,16 @@ int main (int argc, char *argv[])
inst.m_ExcludeRegExp = args[i+1];
inst.m_UseExcludeRegExpFirst = inst.m_UseIncludeRegExp ? false : true;
}
+
+ if(arg.find("-A",0) == 0 && i < args.size() - 1)
+ {
+ inst.m_DartMode = true;
+ inst.SetTest("Notes");
+ inst.Initialize();
+ int ires = inst.GenerateNotesFile(args[i+1].c_str());
+ inst.Finalize();
+ return ires;
+ }
}
// call process directory