123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- /* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
- file Copyright.txt or https://cmake.org/licensing for details. */
- #include "cmCTestConfigureHandler.h"
- #include "cmCTest.h"
- #include "cmDuration.h"
- #include "cmGeneratedFileStream.h"
- #include "cmXMLWriter.h"
- #include <chrono>
- #include <ostream>
- #include <string>
- cmCTestConfigureHandler::cmCTestConfigureHandler()
- {
- }
- void cmCTestConfigureHandler::Initialize()
- {
- this->Superclass::Initialize();
- }
- // clearly it would be nice if this were broken up into a few smaller
- // functions and commented...
- int cmCTestConfigureHandler::ProcessHandler()
- {
- cmCTestOptionalLog(this->CTest, HANDLER_OUTPUT,
- "Configure project" << std::endl, this->Quiet);
- std::string cCommand =
- this->CTest->GetCTestConfiguration("ConfigureCommand");
- if (cCommand.empty()) {
- cmCTestLog(this->CTest, ERROR_MESSAGE,
- "Cannot find ConfigureCommand key in the DartConfiguration.tcl"
- << std::endl);
- return -1;
- }
- std::string buildDirectory =
- this->CTest->GetCTestConfiguration("BuildDirectory");
- if (buildDirectory.empty()) {
- cmCTestLog(this->CTest, ERROR_MESSAGE,
- "Cannot find BuildDirectory key in the DartConfiguration.tcl"
- << std::endl);
- return -1;
- }
- auto elapsed_time_start = std::chrono::steady_clock::now();
- std::string output;
- int retVal = 0;
- int res = 0;
- if (!this->CTest->GetShowOnly()) {
- cmGeneratedFileStream os;
- if (!this->StartResultingXML(cmCTest::PartConfigure, "Configure", os)) {
- cmCTestLog(this->CTest, ERROR_MESSAGE, "Cannot open configure file"
- << std::endl);
- return 1;
- }
- std::string start_time = this->CTest->CurrentTime();
- auto start_time_time = std::chrono::system_clock::now();
- cmGeneratedFileStream ofs;
- this->StartLogFile("Configure", ofs);
- cmCTestOptionalLog(this->CTest, HANDLER_VERBOSE_OUTPUT,
- "Configure with command: " << cCommand << std::endl,
- this->Quiet);
- res = this->CTest->RunMakeCommand(cCommand.c_str(), output, &retVal,
- buildDirectory.c_str(),
- cmDuration::zero(), ofs);
- if (ofs) {
- ofs.close();
- }
- if (os) {
- cmXMLWriter xml(os);
- this->CTest->StartXML(xml, this->AppendXML);
- this->CTest->GenerateSubprojectsOutput(xml);
- xml.StartElement("Configure");
- xml.Element("StartDateTime", start_time);
- xml.Element("StartConfigureTime", start_time_time);
- xml.Element("ConfigureCommand", cCommand);
- cmCTestOptionalLog(this->CTest, DEBUG, "End" << std::endl, this->Quiet);
- xml.Element("Log", output);
- xml.Element("ConfigureStatus", retVal);
- xml.Element("EndDateTime", this->CTest->CurrentTime());
- xml.Element("EndConfigureTime", std::chrono::system_clock::now());
- xml.Element("ElapsedMinutes",
- std::chrono::duration_cast<std::chrono::minutes>(
- std::chrono::steady_clock::now() - elapsed_time_start)
- .count());
- xml.EndElement(); // Configure
- this->CTest->EndXML(xml);
- }
- } else {
- cmCTestOptionalLog(this->CTest, DEBUG,
- "Configure with command: " << cCommand << std::endl,
- this->Quiet);
- }
- if (!res || retVal) {
- cmCTestLog(this->CTest, ERROR_MESSAGE,
- "Error(s) when configuring the project" << std::endl);
- return -1;
- }
- return 0;
- }
|