/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying file Copyright.txt or https://cmake.org/licensing for details. */ #include "cmCTestStartCommand.h" #include "cmCTest.h" #include "cmCTestVC.h" #include "cmGeneratedFileStream.h" #include "cmMakefile.h" #include "cmSystemTools.h" #include #include class cmExecutionStatus; cmCTestStartCommand::cmCTestStartCommand() { this->CreateNewTag = true; this->Quiet = false; } bool cmCTestStartCommand::InitialPass(std::vector const& args, cmExecutionStatus& /*unused*/) { if (args.empty()) { this->SetError("called with incorrect number of arguments"); return false; } size_t cnt = 0; const char* smodel = args[cnt].c_str(); const char* src_dir = CM_NULLPTR; const char* bld_dir = CM_NULLPTR; cnt++; this->CTest->SetSpecificTrack(CM_NULLPTR); if (cnt < args.size() - 1) { if (args[cnt] == "TRACK") { cnt++; this->CTest->SetSpecificTrack(args[cnt].c_str()); cnt++; } } if (cnt < args.size()) { if (args[cnt] == "APPEND") { cnt++; this->CreateNewTag = false; } } if (cnt < args.size()) { if (args[cnt] == "QUIET") { cnt++; this->Quiet = true; } } if (cnt < args.size()) { src_dir = args[cnt].c_str(); cnt++; if (cnt < args.size()) { bld_dir = args[cnt].c_str(); } } if (!src_dir) { src_dir = this->Makefile->GetDefinition("CTEST_SOURCE_DIRECTORY"); } if (!bld_dir) { bld_dir = this->Makefile->GetDefinition("CTEST_BINARY_DIRECTORY"); } if (!src_dir) { this->SetError("source directory not specified. Specify source directory " "as an argument or set CTEST_SOURCE_DIRECTORY"); return false; } if (!bld_dir) { this->SetError("binary directory not specified. Specify binary directory " "as an argument or set CTEST_BINARY_DIRECTORY"); return false; } cmSystemTools::AddKeepPath(src_dir); cmSystemTools::AddKeepPath(bld_dir); this->CTest->EmptyCTestConfiguration(); std::string sourceDir = cmSystemTools::CollapseFullPath(src_dir); std::string binaryDir = cmSystemTools::CollapseFullPath(bld_dir); this->CTest->SetCTestConfiguration("SourceDirectory", sourceDir.c_str(), this->Quiet); this->CTest->SetCTestConfiguration("BuildDirectory", binaryDir.c_str(), this->Quiet); cmCTestOptionalLog(this->CTest, HANDLER_OUTPUT, "Run dashboard with model " << smodel << std::endl << " Source directory: " << src_dir << std::endl << " Build directory: " << bld_dir << std::endl, this->Quiet); const char* track = this->CTest->GetSpecificTrack(); if (track) { cmCTestOptionalLog(this->CTest, HANDLER_OUTPUT, " Track: " << track << std::endl, this->Quiet); } // Log startup actions. std::string startLogFile = binaryDir + "/Testing/Temporary/LastStart.log"; cmGeneratedFileStream ofs(startLogFile.c_str()); if (!ofs) { cmCTestLog(this->CTest, ERROR_MESSAGE, "Cannot create log file: LastStart.log" << std::endl); return false; } // Make sure the source directory exists. if (!this->InitialCheckout(ofs, sourceDir)) { return false; } if (!cmSystemTools::FileIsDirectory(sourceDir)) { std::ostringstream e; e << "given source path\n" << " " << sourceDir << "\n" << "which is not an existing directory. " << "Set CTEST_CHECKOUT_COMMAND to a command line to create it."; this->SetError(e.str()); return false; } this->Makefile->AddDefinition("CTEST_RUN_CURRENT_SCRIPT", "OFF"); this->CTest->SetSuppressUpdatingCTestConfiguration(true); int model = this->CTest->GetTestModelFromString(smodel); this->CTest->SetTestModel(model); this->CTest->SetProduceXML(true); return this->CTest->InitializeFromCommand(this); } bool cmCTestStartCommand::InitialCheckout(std::ostream& ofs, std::string const& sourceDir) { // Use the user-provided command to create the source tree. const char* initialCheckoutCommand = this->Makefile->GetDefinition("CTEST_CHECKOUT_COMMAND"); if (!initialCheckoutCommand) { initialCheckoutCommand = this->Makefile->GetDefinition("CTEST_CVS_CHECKOUT"); } if (initialCheckoutCommand) { // Use a generic VC object to run and log the command. cmCTestVC vc(this->CTest, ofs); vc.SetSourceDirectory(sourceDir); if (!vc.InitialCheckout(initialCheckoutCommand)) { return false; } } return true; }