mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-12 09:20:41 -06:00
The --gtest_output=json option is supported from gtest 1.8.1 onwards. Earlier versions output a warning about it being an unrecognized option, and builds that #define GTEST_HAS_FILE_SYSTEM 0 output an error about it being unsupported, but in both cases still continue outputting the same plain text output as before and return an exit code of 0. We now add that option and check for whether the JSON file is generated, falling back to parsing the plain text output as before if it isn't or if the environment variable NO_GTEST_JSON_OUTPUT is set. The fake executor binaries are sensitive to parameter order. This commit adds --gtest_output:json arguments to a number of tests added for the new JSON parser. The argument order has been adjusted for the invocations of those binaries. Co-Authored-By: Craig Scott <craig.scott@crascit.com> Co-Authored-By: Dennis Lambe Jr. <malsyned@malsyned.net>
58 lines
1.7 KiB
C++
58 lines
1.7 KiB
C++
#include <fstream>
|
|
#include <iostream>
|
|
#include <string>
|
|
|
|
/* Having this as a comment lets gtest_add_tests() recognize the tests we fake
|
|
here without requiring googletest
|
|
TEST_F( WorkDirWithSpaces, test1 )
|
|
{
|
|
}
|
|
TEST_F( WorkDirWithSpaces, test2 )
|
|
{
|
|
}
|
|
*/
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
// Fake gtest behavior so we don't actually require gtest.
|
|
// Both listing tests and test execution try to read a file from
|
|
// the current directory. If we are not handling spaces in the
|
|
// working directory correctly, the files we expect won't exist.
|
|
|
|
if (argc > 2 && std::string(argv[1]) == "--gtest_list_tests" &&
|
|
std::string(argv[2]).find("--gtest_output=json:") != std::string::npos) {
|
|
std::ifstream inTestListFile("test_list_output.txt");
|
|
if (!inTestListFile) {
|
|
std::cout << "ERROR: Failed to open test_list_output.txt" << std::endl;
|
|
return 1;
|
|
}
|
|
std::cout << inTestListFile.rdbuf();
|
|
|
|
std::ifstream inJsonFile("test_list_output.json");
|
|
if (!inJsonFile) {
|
|
std::cout << "ERROR: Failed to open test_list_output.json" << std::endl;
|
|
return 1;
|
|
}
|
|
std::string output_param(argv[2]);
|
|
std::string::size_type split = output_param.find(":");
|
|
std::string filepath = output_param.substr(split + 1);
|
|
// The full file path is passed
|
|
std::ofstream ostrm(filepath.c_str(), std::ios::binary);
|
|
if (!ostrm) {
|
|
std::cerr << "Failed to create file: " << filepath.c_str() << std::endl;
|
|
return 1;
|
|
}
|
|
ostrm << inJsonFile.rdbuf();
|
|
return 0;
|
|
}
|
|
|
|
std::ifstream inFile("test_output.txt");
|
|
if (!inFile) {
|
|
std::cout << "ERROR: Failed to open test_output.txt" << std::endl;
|
|
return 1;
|
|
}
|
|
std::cout << "Test output read from file to follow:" << std::endl;
|
|
std::cout << inFile.rdbuf();
|
|
return 0;
|
|
}
|