annotate gtest/src/gtest-test-part.cc @ 48:91fcf87e570d

duktape: upgrade to 2.0.1
author David Demelier <markand@malikania.fr>
date Mon, 30 Jan 2017 13:45:36 +0100
parents 5d17168ea0af
children afef802824c1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
11
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
1 // Copyright 2008, Google Inc.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
2 // All rights reserved.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
3 //
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
4 // Redistribution and use in source and binary forms, with or without
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
5 // modification, are permitted provided that the following conditions are
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
6 // met:
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
7 //
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
8 // * Redistributions of source code must retain the above copyright
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
9 // notice, this list of conditions and the following disclaimer.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
10 // * Redistributions in binary form must reproduce the above
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
11 // copyright notice, this list of conditions and the following disclaimer
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
12 // in the documentation and/or other materials provided with the
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
13 // distribution.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
14 // * Neither the name of Google Inc. nor the names of its
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
15 // contributors may be used to endorse or promote products derived from
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
16 // this software without specific prior written permission.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
17 //
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
18 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
19 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
20 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
21 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
22 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
23 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
24 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
25 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
26 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
27 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
28 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
29 //
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
30 // Author: mheule@google.com (Markus Heule)
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
31 //
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
32 // The Google C++ Testing Framework (Google Test)
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
33
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
34 #include "gtest/gtest-test-part.h"
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
35
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
36 // Indicates that this translation unit is part of Google Test's
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
37 // implementation. It must come before gtest-internal-inl.h is
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
38 // included, or there will be a compiler error. This trick is to
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
39 // prevent a user from accidentally including gtest-internal-inl.h in
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
40 // his code.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
41 #define GTEST_IMPLEMENTATION_ 1
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
42 #include "src/gtest-internal-inl.h"
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
43 #undef GTEST_IMPLEMENTATION_
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
44
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
45 namespace testing {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
46
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
47 using internal::GetUnitTestImpl;
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
48
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
49 // Gets the summary of the failure message by omitting the stack trace
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
50 // in it.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
51 std::string TestPartResult::ExtractSummary(const char* message) {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
52 const char* const stack_trace = strstr(message, internal::kStackTraceMarker);
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
53 return stack_trace == NULL ? message :
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
54 std::string(message, stack_trace);
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
55 }
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
56
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
57 // Prints a TestPartResult object.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
58 std::ostream& operator<<(std::ostream& os, const TestPartResult& result) {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
59 return os
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
60 << result.file_name() << ":" << result.line_number() << ": "
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
61 << (result.type() == TestPartResult::kSuccess ? "Success" :
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
62 result.type() == TestPartResult::kFatalFailure ? "Fatal failure" :
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
63 "Non-fatal failure") << ":\n"
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
64 << result.message() << std::endl;
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
65 }
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
66
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
67 // Appends a TestPartResult to the array.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
68 void TestPartResultArray::Append(const TestPartResult& result) {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
69 array_.push_back(result);
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
70 }
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
71
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
72 // Returns the TestPartResult at the given index (0-based).
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
73 const TestPartResult& TestPartResultArray::GetTestPartResult(int index) const {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
74 if (index < 0 || index >= size()) {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
75 printf("\nInvalid index (%d) into TestPartResultArray.\n", index);
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
76 internal::posix::Abort();
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
77 }
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
78
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
79 return array_[index];
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
80 }
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
81
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
82 // Returns the number of TestPartResult objects in the array.
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
83 int TestPartResultArray::size() const {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
84 return static_cast<int>(array_.size());
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
85 }
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
86
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
87 namespace internal {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
88
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
89 HasNewFatalFailureHelper::HasNewFatalFailureHelper()
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
90 : has_new_fatal_failure_(false),
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
91 original_reporter_(GetUnitTestImpl()->
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
92 GetTestPartResultReporterForCurrentThread()) {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
93 GetUnitTestImpl()->SetTestPartResultReporterForCurrentThread(this);
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
94 }
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
95
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
96 HasNewFatalFailureHelper::~HasNewFatalFailureHelper() {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
97 GetUnitTestImpl()->SetTestPartResultReporterForCurrentThread(
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
98 original_reporter_);
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
99 }
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
100
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
101 void HasNewFatalFailureHelper::ReportTestPartResult(
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
102 const TestPartResult& result) {
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
103 if (result.fatally_failed())
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
104 has_new_fatal_failure_ = true;
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
105 original_reporter_->ReportTestPartResult(result);
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
106 }
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
107
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
108 } // namespace internal
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
109
5d17168ea0af gtest: import 1.7.0
David Demelier <markand@malikania.fr>
parents:
diff changeset
110 } // namespace testing