Read Bazel's $XML_OUTPUT_FILE environment variable

If $XML_OUTPUT_FILE is set, and $GTEST_OUTPUT and --gtest_output are not
specified, produce output as if GTEST_OUTPUT=xml:$XML_OUTPUT_FILE had
been set.
This commit is contained in:
Doug Greiman 2016-02-23 18:50:08 -08:00
parent ff5ffd457e
commit d6790f26ca
4 changed files with 34 additions and 2 deletions

View File

@ -2547,9 +2547,9 @@ bool ParseInt32(const Message& src_text, const char* str, Int32* value);
bool BoolFromGTestEnv(const char* flag, bool default_val); bool BoolFromGTestEnv(const char* flag, bool default_val);
GTEST_API_ Int32 Int32FromGTestEnv(const char* flag, Int32 default_val); GTEST_API_ Int32 Int32FromGTestEnv(const char* flag, Int32 default_val);
const char* StringFromGTestEnv(const char* flag, const char* default_val); const char* StringFromGTestEnv(const char* flag, const char* default_val);
std::string OutputFromGTestEnv(const char * default_val);
} // namespace internal } // namespace internal
} // namespace testing } // namespace testing
#endif // GTEST_INCLUDE_GTEST_INTERNAL_GTEST_PORT_H_ #endif // GTEST_INCLUDE_GTEST_INTERNAL_GTEST_PORT_H_

View File

@ -1235,5 +1235,24 @@ const char* StringFromGTestEnv(const char* flag, const char* default_value) {
return value == NULL ? default_value : value; return value == NULL ? default_value : value;
} }
// Reads and returns GTEST_OUTPUT and/or XML_OUTPUT_FILE environment
// variables; if neither is set, returns default value.
// XML_OUTPUT_FILE is set by the Bazel build system, and its format is
// a filename without the "xml:" prefix of GTEST_OUTPUT.
std::string OutputFromGTestEnv(const char* default_value) {
#if defined(GTEST_GET_STRING_FROM_ENV_)
return GTEST_GET_STRING_FROM_ENV_("output", default_value);
#endif // defined(GTEST_GET_STRING_FROM_ENV_)
const char* value = StringFromGTestEnv("output", NULL);
if (value) {
return value;
}
value = posix::GetEnv("XML_OUTPUT_FILE");
if (value) {
return std::string("xml:") + value;
}
return default_value;
}
} // namespace internal } // namespace internal
} // namespace testing } // namespace testing

View File

@ -237,7 +237,7 @@ GTEST_DEFINE_bool_(list_tests, false,
GTEST_DEFINE_string_( GTEST_DEFINE_string_(
output, output,
internal::StringFromGTestEnv("output", ""), internal::OutputFromGTestEnv(""),
"A format (currently must be \"xml\"), optionally followed " "A format (currently must be \"xml\"), optionally followed "
"by a colon and an output file name or directory. A directory " "by a colon and an output file name or directory. A directory "
"is indicated by a trailing pathname separator. " "is indicated by a trailing pathname separator. "

View File

@ -98,6 +98,19 @@ class GTestEnvVarTest(gtest_test_utils.TestCase):
TestFlag('death_test_use_fork', '1', '0') TestFlag('death_test_use_fork', '1', '0')
TestFlag('stack_trace_depth', '0', '100') TestFlag('stack_trace_depth', '0', '100')
def testXmlOutputFile(self):
"""Test that $XML_OUTPUT_FILE affects the output flag."""
# $XML_OUTPUT_FILE sets output flag
SetEnvVar('XML_OUTPUT_FILE', 'tmp/bar.xml')
AssertEq('xml:tmp/bar.xml', GetFlag('output'))
# $XML_OUTPUT_FILE is overridden by $GTEST_OUTPUT
SetEnvVar('GTEST_OUTPUT', 'xml:tmp/foo.xml')
AssertEq('xml:tmp/foo.xml', GetFlag('output'))
# If neither set, flag has default value
SetEnvVar('XML_OUTPUT_FILE', None)
SetEnvVar('GTEST_OUTPUT', None)
AssertEq('', GetFlag('output'))
if __name__ == '__main__': if __name__ == '__main__':
gtest_test_utils.Main() gtest_test_utils.Main()