CMake/Source/CTest/cmCTestSubmitCommand.cxx

252 lines
7.4 KiB
C++
Raw Normal View History

/*=========================================================================
Program: CMake - Cross-Platform Makefile Generator
Module: $RCSfile$
Language: C++
Date: $Date$
Version: $Revision$
Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
2006-03-09 19:17:10 +03:00
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
=========================================================================*/
#include "cmCTestSubmitCommand.h"
#include "cmCTest.h"
#include "cmCTestGenericHandler.h"
#include "cmCTestSubmitHandler.h"
cmCTestGenericHandler* cmCTestSubmitCommand::InitializeHandler()
{
2006-03-09 19:17:10 +03:00
const char* ctestDropMethod
2006-03-15 19:02:08 +03:00
= this->Makefile->GetDefinition("CTEST_DROP_METHOD");
2006-03-09 19:17:10 +03:00
const char* ctestDropSite
2006-03-15 19:02:08 +03:00
= this->Makefile->GetDefinition("CTEST_DROP_SITE");
2006-03-09 19:17:10 +03:00
const char* ctestDropLocation
2006-03-15 19:02:08 +03:00
= this->Makefile->GetDefinition("CTEST_DROP_LOCATION");
2006-03-09 19:17:10 +03:00
const char* ctestTriggerSite
2006-03-15 19:02:08 +03:00
= this->Makefile->GetDefinition("CTEST_TRIGGER_SITE");
bool ctestDropSiteCDash
= this->Makefile->IsOn("CTEST_DROP_SITE_CDASH");
if ( !ctestDropMethod )
{
ctestDropMethod = "http";
}
if ( ctestDropSiteCDash )
{
// drop site is a CDash server...
//
if ( !ctestDropSite )
{
// error: CDash requires CTEST_DROP_SITE definition
// in CTestConfig.cmake
}
if ( !ctestDropLocation )
{
// error: CDash requires CTEST_DROP_LOCATION definition
// in CTestConfig.cmake
}
}
else
{
// drop site is a *NOT* a CDash server...
//
// Keep all this code in case anybody out there is still
// using newer CMake with non-CDash servers
//
if ( !ctestDropSite )
{
ctestDropSite = "public.kitware.com";
}
if ( !ctestDropLocation )
{
ctestDropLocation = "/cgi-bin/HTTPUploadDartFile.cgi";
}
if ( !ctestTriggerSite )
{
ctestTriggerSite
= "http://public.kitware.com/cgi-bin/Submit-Random-TestingResults.cgi";
cmCTestLog(this->CTest, HANDLER_OUTPUT, "* Use default trigger site: "
<< ctestTriggerSite << std::endl;);
}
}
this->CTest->SetCTestConfiguration("DropMethod", ctestDropMethod);
this->CTest->SetCTestConfiguration("DropSite", ctestDropSite);
2006-03-10 23:03:09 +03:00
this->CTest->SetCTestConfiguration("DropLocation", ctestDropLocation);
this->CTest->SetCTestConfiguration("IsCDash",
ctestDropSiteCDash ? "TRUE" : "FALSE");
// Only propagate TriggerSite for non-CDash projects:
//
if ( !ctestDropSiteCDash )
{
this->CTest->SetCTestConfiguration("TriggerSite", ctestTriggerSite);
}
this->CTest->SetCTestConfigurationFromCMakeVariable(this->Makefile,
"CurlOptions", "CTEST_CURL_OPTIONS");
2006-03-15 19:02:08 +03:00
this->CTest->SetCTestConfigurationFromCMakeVariable(this->Makefile,
2006-03-09 19:17:10 +03:00
"DropSiteUser", "CTEST_DROP_SITE_USER");
2006-03-15 19:02:08 +03:00
this->CTest->SetCTestConfigurationFromCMakeVariable(this->Makefile,
2006-03-09 19:17:10 +03:00
"DropSitePassword", "CTEST_DROP_SITE_PASSWORD");
2006-03-15 19:02:08 +03:00
this->CTest->SetCTestConfigurationFromCMakeVariable(this->Makefile,
2006-03-09 19:17:10 +03:00
"ScpCommand", "CTEST_SCP_COMMAND");
2006-03-09 19:17:10 +03:00
const char* notesFilesVariable
2006-03-15 19:02:08 +03:00
= this->Makefile->GetDefinition("CTEST_NOTES_FILES");
2005-05-08 21:49:06 +04:00
if (notesFilesVariable)
{
std::vector<std::string> notesFiles;
std::vector<cmStdString> newNotesFiles;
cmSystemTools::ExpandListArgument(notesFilesVariable,notesFiles);
std::vector<std::string>::iterator it;
2006-03-09 19:17:10 +03:00
for ( it = notesFiles.begin();
2005-05-08 21:49:06 +04:00
it != notesFiles.end();
++ it )
{
newNotesFiles.push_back(*it);
}
2006-03-10 23:03:09 +03:00
this->CTest->GenerateNotesFile(newNotesFiles);
2005-05-08 21:49:06 +04:00
}
2006-03-09 19:17:10 +03:00
const char* extraFilesVariable
2006-03-15 19:02:08 +03:00
= this->Makefile->GetDefinition("CTEST_EXTRA_SUBMIT_FILES");
if (extraFilesVariable)
{
std::vector<std::string> extraFiles;
std::vector<cmStdString> newExtraFiles;
cmSystemTools::ExpandListArgument(extraFilesVariable,extraFiles);
std::vector<std::string>::iterator it;
2006-03-09 19:17:10 +03:00
for ( it = extraFiles.begin();
it != extraFiles.end();
++ it )
{
newExtraFiles.push_back(*it);
}
2006-03-10 23:03:09 +03:00
if ( !this->CTest->SubmitExtraFiles(newExtraFiles))
{
this->SetError("problem submitting extra files.");
2006-03-29 21:33:41 +04:00
return 0;
}
}
2005-05-08 21:49:06 +04:00
2006-03-10 23:03:09 +03:00
cmCTestGenericHandler* handler
= this->CTest->GetInitializedHandler("submit");
if ( !handler )
{
this->SetError("internal CTest error. Cannot instantiate submit handler");
2006-03-29 21:33:41 +04:00
return 0;
}
// If no FILES or PARTS given, *all* PARTS are submitted by default.
//
// If FILES are given, but not PARTS, only the FILES are submitted
// and *no* PARTS are submitted.
// (This is why we select the empty "noParts" set in the
// FilesMentioned block below...)
//
// If PARTS are given, only the selected PARTS are submitted.
//
// If both PARTS and FILES are given, only the selected PARTS *and*
// all the given FILES are submitted.
// If given explicit FILES to submit, pass them to the handler.
//
if(this->FilesMentioned)
{
// Intentionally select *no* PARTS. (Pass an empty set.) If PARTS
// were also explicitly mentioned, they will be selected below...
// But FILES with no PARTS mentioned should just submit the FILES
// without any of the default parts.
//
std::set<cmCTest::Part> noParts;
static_cast<cmCTestSubmitHandler*>(handler)->SelectParts(noParts);
static_cast<cmCTestSubmitHandler*>(handler)->SelectFiles(this->Files);
}
// If a PARTS option was given, select only the named parts for submission.
//
if(this->PartsMentioned)
{
static_cast<cmCTestSubmitHandler*>(handler)->SelectParts(this->Parts);
}
return handler;
}
//----------------------------------------------------------------------------
bool cmCTestSubmitCommand::CheckArgumentKeyword(std::string const& arg)
{
// Look for arguments specific to this command.
if(arg == "PARTS")
{
this->ArgumentDoing = ArgumentDoingParts;
this->PartsMentioned = true;
return true;
}
if(arg == "FILES")
{
this->ArgumentDoing = ArgumentDoingFiles;
this->FilesMentioned = true;
return true;
}
// Look for other arguments.
return this->Superclass::CheckArgumentKeyword(arg);
}
//----------------------------------------------------------------------------
bool cmCTestSubmitCommand::CheckArgumentValue(std::string const& arg)
{
// Handle states specific to this command.
if(this->ArgumentDoing == ArgumentDoingParts)
{
cmCTest::Part p = this->CTest->GetPartFromName(arg.c_str());
if(p != cmCTest::PartCount)
{
this->Parts.insert(p);
}
else
{
cmOStringStream e;
e << "Part name \"" << arg << "\" is invalid.";
this->Makefile->IssueMessage(cmake::FATAL_ERROR, e.str());
this->ArgumentDoing = ArgumentDoingError;
}
return true;
}
if(this->ArgumentDoing == ArgumentDoingFiles)
{
cmStdString filename(arg);
if(cmSystemTools::FileExists(filename.c_str()))
{
this->Files.insert(filename);
}
else
{
cmOStringStream e;
e << "File \"" << filename << "\" does not exist. Cannot submit "
<< "a non-existent file.";
this->Makefile->IssueMessage(cmake::FATAL_ERROR, e.str());
this->ArgumentDoing = ArgumentDoingError;
}
return true;
}
// Look for other arguments.
return this->Superclass::CheckArgumentValue(arg);
}