[#4294] --gtest_break_on_failure updated condition to not effect throw_on_failure. Updated googletest-throw-on-failure-test_.cc to set the throw_on_failure mode.

This commit is contained in:
Dan Avram 2023-11-03 18:40:23 +02:00
parent 2888f75afd
commit 553c2d5dd7
2 changed files with 4 additions and 3 deletions

View file

@ -5342,14 +5342,14 @@ void UnitTest::AddTestPartResult(TestPartResult::Type result_type,
result);
if (result_type != TestPartResult::kSuccess &&
result_type != TestPartResult::kSkip &&
result_type != TestPartResult::kNonFatalFailure) {
result_type != TestPartResult::kSkip) {
// gtest_break_on_failure takes precedence over
// gtest_throw_on_failure. This allows a user to set the latter
// in the code (perhaps in order to use Google Test assertions
// with another testing framework) and specify the former on the
// command line for debugging.
if (GTEST_FLAG_GET(break_on_failure)) {
if (GTEST_FLAG_GET(break_on_failure) &&
result_type != TestPartResult::kNonFatalFailure) {
#if defined(GTEST_OS_WINDOWS) && !defined(GTEST_OS_WINDOWS_PHONE) && \
!defined(GTEST_OS_WINDOWS_RT)
// Using DebugBreak on Windows allows gtest to still break into a debugger

View file

@ -54,6 +54,7 @@ int main(int argc, char** argv) {
std::set_terminate(&TerminateHandler);
#endif
testing::InitGoogleTest(&argc, argv);
GTEST_FLAG_SET(throw_on_failure, true);
// We want to ensure that people can use Google Test assertions in
// other testing frameworks, as long as they initialize Google Test