CTest: Allow / to be in the build name, and be consistent with the build name
Prior to this change / was not allowed in the build name. This was tested with a CDash server and worked. In addition the safe build name was not used everywhere. This caused mismatched build names to be in the xml files going to CDash which caused different rows to be created for the same build.
This commit is contained in:
parent
39b5df2f37
commit
653529ce55
|
@ -1479,8 +1479,10 @@ int cmCTestSubmitHandler::ProcessHandler()
|
|||
//----------------------------------------------------------------------------
|
||||
std::string cmCTestSubmitHandler::GetSubmitResultsPrefix()
|
||||
{
|
||||
std::string buildname = cmCTest::SafeBuildIdField(
|
||||
this->CTest->GetCTestConfiguration("BuildName"));
|
||||
std::string name = this->CTest->GetCTestConfiguration("Site") +
|
||||
"___" + this->CTest->GetCTestConfiguration("BuildName") +
|
||||
"___" + buildname +
|
||||
"___" + this->CTest->GetCurrentTag() + "-" +
|
||||
this->CTest->GetTestModelString() + "___XML___";
|
||||
return name;
|
||||
|
|
|
@ -258,12 +258,13 @@ int cmCTestUpdateHandler::ProcessHandler()
|
|||
double elapsed_time_start = cmSystemTools::GetTime();
|
||||
|
||||
bool updated = vc->Update();
|
||||
|
||||
std::string buildname = cmCTest::SafeBuildIdField(
|
||||
this->CTest->GetCTestConfiguration("BuildName"));
|
||||
os << "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
|
||||
<< "<Update mode=\"Client\" Generator=\"ctest-"
|
||||
<< cmVersion::GetCMakeVersion() << "\">\n"
|
||||
<< "\t<Site>" << this->CTest->GetCTestConfiguration("Site") << "</Site>\n"
|
||||
<< "\t<BuildName>" << this->CTest->GetCTestConfiguration("BuildName")
|
||||
<< "\t<BuildName>" << buildname
|
||||
<< "</BuildName>\n"
|
||||
<< "\t<BuildStamp>" << this->CTest->GetCurrentTag() << "-"
|
||||
<< this->CTest->GetTestModelString() << "</BuildStamp>" << std::endl;
|
||||
|
|
|
@ -44,14 +44,15 @@ int cmCTestUploadHandler::ProcessHandler()
|
|||
"Cannot open Upload.xml file" << std::endl);
|
||||
return -1;
|
||||
}
|
||||
|
||||
std::string buildname = cmCTest::SafeBuildIdField(
|
||||
this->CTest->GetCTestConfiguration("BuildName"));
|
||||
cmCTest::SetOfStrings::const_iterator it;
|
||||
ofs << "<?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=\""
|
||||
<< this->CTest->GetCTestConfiguration("BuildName")
|
||||
<< buildname
|
||||
<< "\" BuildStamp=\""
|
||||
<< this->CTest->GetCurrentTag() << "-"
|
||||
<< this->CTest->GetTestModelString() << "\" Name=\""
|
||||
|
|
|
@ -488,9 +488,11 @@ int cmCTest::Initialize(const char* binary_dir, cmCTestStartCommand* command)
|
|||
{
|
||||
cmCTestLog(this, DEBUG, "Here: " << __LINE__ << std::endl);
|
||||
cmCTestLog(this, OUTPUT,
|
||||
" Site: " << this->GetCTestConfiguration("Site") << std::endl
|
||||
<< " Build name: " << this->GetCTestConfiguration("BuildName")
|
||||
<< std::endl);
|
||||
" Site: " << this->GetCTestConfiguration("Site") << std::endl
|
||||
<< " Build name: "
|
||||
<< cmCTest::SafeBuildIdField(
|
||||
this->GetCTestConfiguration("BuildName"))
|
||||
<< std::endl);
|
||||
cmCTestLog(this, DEBUG, "Produce XML is on" << std::endl);
|
||||
if ( this->TestModel == cmCTest::NIGHTLY &&
|
||||
this->GetCTestConfiguration("NightlyStartTime").empty() )
|
||||
|
@ -1441,7 +1443,7 @@ std::string cmCTest::SafeBuildIdField(const std::string& value)
|
|||
// Disallow non-filename and non-space whitespace characters.
|
||||
// If they occur, replace them with ""
|
||||
//
|
||||
const char *disallowed = "\\/:*?\"<>|\n\r\t\f\v";
|
||||
const char *disallowed = "\\:*?\"<>|\n\r\t\f\v";
|
||||
|
||||
if (safevalue.find_first_of(disallowed) != value.npos)
|
||||
{
|
||||
|
@ -1582,12 +1584,14 @@ void cmCTest::EndXML(std::ostream& ostr)
|
|||
int cmCTest::GenerateCTestNotesOutput(std::ostream& os,
|
||||
const cmCTest::VectorOfStrings& files)
|
||||
{
|
||||
std::string buildname = cmCTest::SafeBuildIdField(
|
||||
this->GetCTestConfiguration("BuildName"));
|
||||
cmCTest::VectorOfStrings::const_iterator it;
|
||||
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=\"" << this->GetCTestConfiguration("BuildName")
|
||||
<< "<Site BuildName=\"" << buildname
|
||||
<< "\" BuildStamp=\""
|
||||
<< this->CurrentTag << "-" << this->GetTestModelString() << "\" Name=\""
|
||||
<< this->GetCTestConfiguration("Site") << "\" Generator=\"ctest"
|
||||
|
|
Loading…
Reference in New Issue