summaryrefslogtreecommitdiffstats
path: root/Source/cmCTest.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmCTest.cxx')
-rw-r--r--Source/cmCTest.cxx174
1 files changed, 6 insertions, 168 deletions
diff --git a/Source/cmCTest.cxx b/Source/cmCTest.cxx
index e75efd4..53ea159 100644
--- a/Source/cmCTest.cxx
+++ b/Source/cmCTest.cxx
@@ -33,8 +33,8 @@
#include "cmCTestScriptHandler.h"
#include "cmCTestTestHandler.h"
#include "cmCTestUpdateHandler.h"
+#include "cmCTestSubmitHandler.h"
-#include "cmCTestSubmit.h"
#include "cmVersion.h"
#include <cmsys/RegularExpression.hxx>
@@ -250,6 +250,7 @@ cmCTest::cmCTest()
m_TestingHandlers["update"] = new cmCTestUpdateHandler;
m_TestingHandlers["configure"] = new cmCTestConfigureHandler;
m_TestingHandlers["memcheck"] = new cmCTestMemCheckHandler;
+ m_TestingHandlers["submit"] = new cmCTestSubmitHandler;
cmCTest::t_TestingHandlers::iterator it;
for ( it = m_TestingHandlers.begin(); it != m_TestingHandlers.end(); ++ it )
@@ -575,163 +576,6 @@ bool cmCTest::AddIfExists(tm_VectorOfStrings& files, const char* file)
return true;
}
-int cmCTest::SubmitResults()
-{
- cmGeneratedFileStream ofs;
- this->OpenOutputFile("Temporary", "LastSubmit.log", ofs);
-
- cmCTest::tm_VectorOfStrings files;
- std::string prefix = this->GetSubmitResultsPrefix();
- // TODO:
- // Check if test is enabled
- this->AddIfExists(files, "Update.xml");
- this->AddIfExists(files, "Configure.xml");
- this->AddIfExists(files, "Build.xml");
- this->AddIfExists(files, "Test.xml");
- if ( this->AddIfExists(files, "Coverage.xml") )
- {
- cmCTest::tm_VectorOfStrings gfiles;
- std::string gpath = m_BinaryDir + "/Testing/" + m_CurrentTag;
- std::string::size_type glen = gpath.size() + 1;
- gpath = gpath + "/CoverageLog*";
- //std::cout << "Globbing for: " << gpath.c_str() << std::endl;
- if ( cmSystemTools::SimpleGlob(gpath, gfiles, 1) )
- {
- size_t cc;
- for ( cc = 0; cc < gfiles.size(); cc ++ )
- {
- gfiles[cc] = gfiles[cc].substr(glen);
- //std::cout << "Glob file: " << gfiles[cc].c_str() << std::endl;
- files.push_back(gfiles[cc]);
- }
- }
- else
- {
- std::cerr << "Problem globbing" << std::endl;
- }
- }
- this->AddIfExists(files, "DynamicAnalysis.xml");
- this->AddIfExists(files, "Purify.xml");
- this->AddIfExists(files, "Notes.xml");
-
- if ( ofs )
- {
- ofs << "Upload files:" << std::endl;
- int cnt = 0;
- cmCTest::tm_VectorOfStrings::iterator it;
- for ( it = files.begin(); it != files.end(); ++ it )
- {
- ofs << cnt << "\t" << it->c_str() << std::endl;
- cnt ++;
- }
- }
- std::cout << "Submit files (using " << m_DartConfiguration["DropMethod"] << ")"
- << std::endl;
- cmCTestSubmit submit;
- submit.SetVerbose(m_ExtraVerbose);
- submit.SetLogFile(&ofs);
- if ( m_DartConfiguration["DropMethod"] == "" ||
- m_DartConfiguration["DropMethod"] == "ftp" )
- {
- ofs << "Using drop method: FTP" << std::endl;
- std::cout << " Using FTP submit method" << std::endl;
- std::string url = "ftp://";
- url += cmCTest::MakeURLSafe(m_DartConfiguration["DropSiteUser"]) + ":" +
- cmCTest::MakeURLSafe(m_DartConfiguration["DropSitePassword"]) + "@" +
- m_DartConfiguration["DropSite"] +
- cmCTest::MakeURLSafe(m_DartConfiguration["DropLocation"]);
- if ( !submit.SubmitUsingFTP(m_BinaryDir+"/Testing/"+m_CurrentTag,
- files, prefix, url) )
- {
- std::cerr << " Problems when submitting via FTP" << std::endl;
- ofs << " Problems when submitting via FTP" << std::endl;
- return 0;
- }
- if ( !submit.TriggerUsingHTTP(files, prefix, m_DartConfiguration["TriggerSite"]) )
- {
- std::cerr << " Problems when triggering via HTTP" << std::endl;
- ofs << " Problems when triggering via HTTP" << std::endl;
- return 0;
- }
- std::cout << " Submission successful" << std::endl;
- ofs << " Submission successful" << std::endl;
- return 1;
- }
- else if ( m_DartConfiguration["DropMethod"] == "http" )
- {
- ofs << "Using drop method: HTTP" << std::endl;
- std::cout << " Using HTTP submit method" << std::endl;
- std::string url = "http://";
- if ( m_DartConfiguration["DropSiteUser"].size() > 0 )
- {
- url += m_DartConfiguration["DropSiteUser"];
- if ( m_DartConfiguration["DropSitePassword"].size() > 0 )
- {
- url += ":" + m_DartConfiguration["DropSitePassword"];
- }
- url += "@";
- }
- url += m_DartConfiguration["DropSite"] + m_DartConfiguration["DropLocation"];
- if ( !submit.SubmitUsingHTTP(m_BinaryDir+"/Testing/"+m_CurrentTag, files, prefix, url) )
- {
- std::cerr << " Problems when submitting via HTTP" << std::endl;
- ofs << " Problems when submitting via HTTP" << std::endl;
- return 0;
- }
- if ( !submit.TriggerUsingHTTP(files, prefix, m_DartConfiguration["TriggerSite"]) )
- {
- std::cerr << " Problems when triggering via HTTP" << std::endl;
- ofs << " Problems when triggering via HTTP" << std::endl;
- return 0;
- }
- std::cout << " Submission successful" << std::endl;
- ofs << " Submission successful" << std::endl;
- return 1;
- }
- else if ( m_DartConfiguration["DropMethod"] == "xmlrpc" )
- {
- ofs << "Using drop method: XML-RPC" << std::endl;
- std::cout << " Using XML-RPC submit method" << std::endl;
- std::string url = m_DartConfiguration["DropSite"];
- prefix = m_DartConfiguration["DropLocation"];
- if ( !submit.SubmitUsingXMLRPC(m_BinaryDir+"/Testing/"+m_CurrentTag, files, prefix, url) )
- {
- std::cerr << " Problems when submitting via XML-RPC" << std::endl;
- ofs << " Problems when submitting via XML-RPC" << std::endl;
- return 0;
- }
- std::cout << " Submission successful" << std::endl;
- ofs << " Submission successful" << std::endl;
- return 1;
- }
- else if ( m_DartConfiguration["DropMethod"] == "scp" )
- {
- std::string url;
- if ( m_DartConfiguration["DropSiteUser"].size() > 0 )
- {
- url += m_DartConfiguration["DropSiteUser"] + "@";
- }
- url += m_DartConfiguration["DropSite"] + ":" + m_DartConfiguration["DropLocation"];
-
- if ( !submit.SubmitUsingSCP(m_DartConfiguration["ScpCommand"],
- m_BinaryDir+"/Testing/"+m_CurrentTag, files, prefix, url) )
- {
- std::cerr << " Problems when submitting via SCP" << std::endl;
- ofs << " Problems when submitting via SCP" << std::endl;
- return 0;
- }
- std::cout << " Submission successful" << std::endl;
- ofs << " Submission successful" << std::endl;
- }
- else
- {
- std::cout << " Unknown submission method: \"" << m_DartConfiguration["DropMethod"] << "\"" << std::endl;
- return 0;
- }
-
- return 0;
-}
-
bool cmCTest::CTestFileExists(const std::string& filename)
{
std::string testingDir = m_BinaryDir + "/Testing/" + m_CurrentTag + "/" +
@@ -739,15 +583,6 @@ bool cmCTest::CTestFileExists(const std::string& filename)
return cmSystemTools::FileExists(testingDir.c_str());
}
-std::string cmCTest::GetSubmitResultsPrefix()
-{
- std::string name = m_DartConfiguration["Site"] +
- "___" + m_DartConfiguration["BuildName"] +
- "___" + m_CurrentTag + "-" +
- this->GetTestModelString() + "___XML___";
- return name;
-}
-
cmCTestGenericHandler* cmCTest::GetHandler(const char* handler)
{
cmCTest::t_TestingHandlers::iterator it = m_TestingHandlers.find(handler);
@@ -872,7 +707,10 @@ int cmCTest::ProcessTests()
if ( m_Tests[SUBMIT_TEST] || m_Tests[ALL_TEST] )
{
this->UpdateCTestConfiguration();
- this->SubmitResults();
+ if (this->GetHandler("submit")->ProcessHandler() < 0)
+ {
+ res |= cmCTest::SUBMIT_ERRORS;
+ }
}
return res;
}