37 #ifndef GTEST_INCLUDE_GTEST_INTERNAL_GTEST_INTERNAL_H_
38 #define GTEST_INCLUDE_GTEST_INTERNAL_GTEST_INTERNAL_H_
44 # include <sys/types.h>
45 # include <sys/wait.h>
47 #endif // GTEST_OS_LINUX
49 #if GTEST_HAS_EXCEPTIONS
61 #include <type_traits>
77 #define GTEST_CONCAT_TOKEN_(foo, bar) GTEST_CONCAT_TOKEN_IMPL_(foo, bar)
78 #define GTEST_CONCAT_TOKEN_IMPL_(foo, bar) foo ## bar
81 #define GTEST_STRINGIFY_(name) #name
83 class ProtocolMessage;
84 namespace proto2 {
class Message; }
90 class AssertionResult;
121 template <
typename T,
130 template <
typename T>
153 #define GTEST_IS_NULL_LITERAL_(x) \
154 decltype(::testing::internal::IsNullLiteralHelper( \
156 ::testing::internal::TypeIsValidNullptrConstant<decltype(x)>()))::value
160 const std::string& gtest_msg,
const Message& user_msg);
162 #if GTEST_HAS_EXCEPTIONS
173 class
GTEST_API_ GoogleTestFailureException : public ::
std::runtime_error {
175 explicit GoogleTestFailureException(
const TestPartResult& failure);
180 #endif // GTEST_HAS_EXCEPTIONS
182 namespace edit_distance {
190 const std::vector<size_t>&
left,
const std::vector<size_t>& right);
194 const std::vector<std::string>&
left,
195 const std::vector<std::string>& right);
199 const std::vector<std::string>& right,
210 size_t* total_line_count);
228 const char* actual_expression,
235 const AssertionResult& assertion_result,
236 const char* expression_text,
237 const char* actual_predicate_value,
238 const char* expected_predicate_value);
269 template <
typename RawType>
283 std::numeric_limits<RawType>::digits - 1;
337 static RawType
Max();
413 return (biased1 >= biased2) ? (biased1 - biased2) : (biased2 - biased1);
439 template <
typename T>
448 template <
typename T>
454 template <
typename T>
489 template <
class TestClass>
501 GTEST_API_ AssertionResult IsHRESULTSuccess(
const char* expr,
503 GTEST_API_ AssertionResult IsHRESULTFailure(
const char* expr,
506 #endif // GTEST_OS_WINDOWS
528 return a == def ? nullptr :
a;
531 template <
typename T>
548 <<
"Test can not provide both SetUpTestSuite and SetUpTestCase, please "
549 "make sure there is only one present ";
551 return test_case_fp !=
nullptr ? test_case_fp : test_suite_fp;
561 <<
"Test can not provide both TearDownTestSuite and TearDownTestCase,"
562 " please make sure there is only one present ";
564 return test_case_fp !=
nullptr ? test_case_fp : test_suite_fp;
587 const char* test_suite_name,
const char*
name,
const char* type_param,
588 const char* value_param, CodeLocation code_location,
597 #if GTEST_HAS_TYPED_TEST || GTEST_HAS_TYPED_TEST_P
605 TypedTestSuitePState() : registered_(
false) {}
610 bool AddTestName(
const char* file,
int line,
const char* case_name,
611 const char* test_name) {
614 "%s Test %s must be defined before "
615 "REGISTER_TYPED_TEST_SUITE_P(%s, ...).\n",
620 registered_tests_.insert(
621 ::std::make_pair(test_name, CodeLocation(file, line)));
625 bool TestExists(
const std::string& test_name)
const {
626 return registered_tests_.count(test_name) > 0;
629 const CodeLocation& GetCodeLocation(
const std::string& test_name)
const {
630 RegisteredTestsMap::const_iterator
it = registered_tests_.find(test_name);
638 const char* VerifyRegisteredTestNames(
639 const char* file,
int line,
const char* registered_tests);
642 typedef ::std::map<std::string, CodeLocation> RegisteredTestsMap;
645 RegisteredTestsMap registered_tests_;
649 #ifndef GTEST_REMOVE_LEGACY_TEST_CASEAPI_
650 using TypedTestCasePState = TypedTestSuitePState;
651 #endif // GTEST_REMOVE_LEGACY_TEST_CASEAPI_
658 const char* comma = strchr(
str,
',');
659 if (comma ==
nullptr) {
669 const char* comma = strchr(
str,
',');
676 ::std::vector< ::std::string>*
dest);
680 struct DefaultNameGenerator {
681 template <
typename T>
687 template <
typename Prov
ided = DefaultNameGenerator>
688 struct NameGeneratorSelector {
689 typedef Provided
type;
692 template <
typename NameGenerator>
693 void GenerateNamesRecursively(Types0, std::vector<std::string>*,
int) {}
695 template <
typename NameGenerator,
typename Types>
696 void GenerateNamesRecursively(Types, std::vector<std::string>* result,
int i) {
697 result->push_back(NameGenerator::template GetName<typename Types::Head>(
i));
698 GenerateNamesRecursively<NameGenerator>(
typename Types::Tail(), result,
702 template <
typename NameGenerator,
typename Types>
703 std::vector<std::string> GenerateNames() {
704 std::vector<std::string> result;
705 GenerateNamesRecursively<NameGenerator>(Types(), &result, 0);
716 template <GTEST_TEMPLATE_ Fixture,
class TestSel,
typename Types>
717 class TypeParameterizedTest {
723 static bool Register(
const char*
prefix,
const CodeLocation& code_location,
724 const char* case_name,
const char* test_names,
int index,
725 const std::vector<std::string>& type_names =
726 GenerateNames<DefaultNameGenerator, Types>()) {
727 typedef typename Types::Head
Type;
729 typedef typename GTEST_BIND_(TestSel,
Type) TestClass;
735 "/" + type_names[
index])
738 GetTypeName<Type>().c_str(),
740 code_location, GetTypeId<FixtureClass>(),
743 new TestFactoryImpl<TestClass>);
746 return TypeParameterizedTest<
Fixture, TestSel,
747 typename Types::Tail>::Register(
prefix,
757 template <GTEST_TEMPLATE_ Fixture,
class TestSel>
758 class TypeParameterizedTest<
Fixture, TestSel, Types0> {
760 static bool Register(
const char* ,
const CodeLocation&,
761 const char* ,
const char* ,
763 const std::vector<std::string>& =
764 std::vector<std::string>() ) {
773 template <GTEST_TEMPLATE_ Fixture,
typename Tests,
typename Types>
774 class TypeParameterizedTestSuite {
776 static bool Register(
const char*
prefix, CodeLocation code_location,
777 const TypedTestSuitePState* state,
const char* case_name,
778 const char* test_names,
779 const std::vector<std::string>& type_names =
780 GenerateNames<DefaultNameGenerator, Types>()) {
782 GetPrefixUntilComma(test_names));
783 if (!state->TestExists(test_name)) {
784 fprintf(stderr,
"Failed to get code location for test %s.%s at %s.",
785 case_name, test_name.c_str(),
787 code_location.line).c_str());
791 const CodeLocation& test_location = state->GetCodeLocation(test_name);
793 typedef typename Tests::Head Head;
796 TypeParameterizedTest<Fixture, Head, Types>::Register(
797 prefix, test_location, case_name, test_names, 0, type_names);
800 return TypeParameterizedTestSuite<
Fixture,
typename Tests::Tail,
801 Types>::Register(
prefix, code_location,
803 SkipComma(test_names),
809 template <GTEST_TEMPLATE_ Fixture,
typename Types>
810 class TypeParameterizedTestSuite<
Fixture, Templates0, Types> {
812 static bool Register(
const char* ,
const CodeLocation&,
813 const TypedTestSuitePState* ,
814 const char* ,
const char* ,
815 const std::vector<std::string>& =
816 std::vector<std::string>() ) {
821 #endif // GTEST_HAS_TYPED_TEST || GTEST_HAS_TYPED_TEST_P
834 UnitTest* unit_test,
int skip_count);
850 operator bool()
const {
return true; }
861 static const UInt32 kMaxRange = 1u << 31;
878 template <
typename T1,
typename T2>
881 template <
typename T>
888 template <
typename T>
890 template <
typename T>
895 #define GTEST_REMOVE_REFERENCE_(T) \
896 typename ::testing::internal::RemoveReference<T>::type
901 template <
typename T>
903 template <
typename T>
909 template <
typename T,
size_t N>
916 #define GTEST_REMOVE_CONST_(T) \
917 typename ::testing::internal::RemoveConst<T>::type
920 #define GTEST_REMOVE_REFERENCE_AND_CONST_(T) \
921 GTEST_REMOVE_CONST_(GTEST_REMOVE_REFERENCE_(T))
926 template <
typename T>
929 std::is_convertible<const T*, const ::ProtocolMessage*>::value ||
930 std::is_convertible<const T*, const ::proto2::Message*>::value> {
959 class Iterator = decltype(::std::declval<const C&>().
begin()),
960 class = decltype(::std::declval<const C&>().
end()),
961 class = decltype(++::std::declval<Iterator&>()),
962 class = decltype(*::std::declval<Iterator>()),
963 class =
typename C::const_iterator>
976 template <
typename T>
979 template <
typename U>
980 static char test(
typename U::hasher*,
typename U::reverse_iterator*);
981 template <
typename U>
982 static int test(
typename U::hasher*, ...);
983 template <
typename U>
984 static char test(...);
987 static const bool value =
sizeof(test<T>(
nullptr,
nullptr)) ==
sizeof(
int);
990 template <
typename T>
993 template <
typename C,
994 bool =
sizeof(IsContainerTest<C>(0)) ==
sizeof(
IsContainer)>
997 template <
typename C>
1004 template <
typename C>
1006 using value_type = decltype(*std::declval<typename C::const_iterator>());
1008 is_same<
typename std::remove_const<
1019 template <
typename C>
1035 template <
typename T,
typename U>
1039 template <
typename T,
typename U>
1040 inline bool ArrayEq(
const T& lhs,
const U& rhs) {
return lhs == rhs; }
1043 template <
typename T,
typename U,
size_t N>
1044 inline bool ArrayEq(
const T(&lhs)[N],
const U(&rhs)[N]) {
1051 template <
typename T,
typename U>
1053 for (
size_t i = 0;
i !=
size;
i++) {
1062 template <
typename Iter,
typename Element>
1075 template <
typename T,
typename U>
1079 template <
typename T,
typename U>
1083 template <
typename T,
typename U,
size_t N>
1091 template <
typename T,
typename U>
1093 for (
size_t i = 0;
i !=
size;
i++) {
1113 template <
typename Element>
1158 Element*
const copy =
new Element[a_size];
1180 template <
size_t... Is>
1186 template <
bool plus_one,
typename T,
size_t sizeofT>
1188 template <
size_t... I,
size_t sizeofT>
1192 template <
size_t... I,
size_t sizeofT>
1201 :
DoubleSequence<N % 2 == 1, typename MakeIndexSequence<N / 2>::type,
1210 template <
typename T,
size_t,
size_t>
1213 template <
typename T,
size_t I>
1220 template <
size_t N,
typename I,
typename...
T>
1223 template <
size_t N,
size_t... I,
typename...
T>
1227 template <
typename...
T>
1230 template <
typename Derived,
size_t I>
1233 template <
typename...
T,
size_t I>
1243 template <
typename Derived,
typename Idx>
1246 template <
size_t... Idx,
typename...
T>
1264 template <
typename...
T>
1266 :
private FlatTupleBase<FlatTuple<T...>,
1267 typename MakeIndexSequence<sizeof...(T)>::type> {
1268 using Indices =
typename FlatTuple::FlatTupleBase::Indices;
1288 #define GTEST_MESSAGE_AT_(file, line, message, result_type) \
1289 ::testing::internal::AssertHelper(result_type, file, line, message) \
1290 = ::testing::Message()
1292 #define GTEST_MESSAGE_(message, result_type) \
1293 GTEST_MESSAGE_AT_(__FILE__, __LINE__, message, result_type)
1295 #define GTEST_FATAL_FAILURE_(message) \
1296 return GTEST_MESSAGE_(message, ::testing::TestPartResult::kFatalFailure)
1298 #define GTEST_NONFATAL_FAILURE_(message) \
1299 GTEST_MESSAGE_(message, ::testing::TestPartResult::kNonFatalFailure)
1301 #define GTEST_SUCCESS_(message) \
1302 GTEST_MESSAGE_(message, ::testing::TestPartResult::kSuccess)
1304 #define GTEST_SKIP_(message) \
1305 return GTEST_MESSAGE_(message, ::testing::TestPartResult::kSkip)
1310 #define GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement) \
1311 if (::testing::internal::AlwaysTrue()) { statement; }
1313 #define GTEST_TEST_THROW_(statement, expected_exception, fail) \
1314 GTEST_AMBIGUOUS_ELSE_BLOCKER_ \
1315 if (::testing::internal::ConstCharPtr gtest_msg = "") { \
1316 bool gtest_caught_expected = false; \
1318 GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement); \
1320 catch (expected_exception const&) { \
1321 gtest_caught_expected = true; \
1325 "Expected: " #statement " throws an exception of type " \
1326 #expected_exception ".\n Actual: it throws a different type."; \
1327 goto GTEST_CONCAT_TOKEN_(gtest_label_testthrow_, __LINE__); \
1329 if (!gtest_caught_expected) { \
1331 "Expected: " #statement " throws an exception of type " \
1332 #expected_exception ".\n Actual: it throws nothing."; \
1333 goto GTEST_CONCAT_TOKEN_(gtest_label_testthrow_, __LINE__); \
1336 GTEST_CONCAT_TOKEN_(gtest_label_testthrow_, __LINE__): \
1337 fail(gtest_msg.value)
1339 #define GTEST_TEST_NO_THROW_(statement, fail) \
1340 GTEST_AMBIGUOUS_ELSE_BLOCKER_ \
1341 if (::testing::internal::AlwaysTrue()) { \
1343 GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement); \
1346 goto GTEST_CONCAT_TOKEN_(gtest_label_testnothrow_, __LINE__); \
1349 GTEST_CONCAT_TOKEN_(gtest_label_testnothrow_, __LINE__): \
1350 fail("Expected: " #statement " doesn't throw an exception.\n" \
1351 " Actual: it throws.")
1353 #define GTEST_TEST_ANY_THROW_(statement, fail) \
1354 GTEST_AMBIGUOUS_ELSE_BLOCKER_ \
1355 if (::testing::internal::AlwaysTrue()) { \
1356 bool gtest_caught_any = false; \
1358 GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement); \
1361 gtest_caught_any = true; \
1363 if (!gtest_caught_any) { \
1364 goto GTEST_CONCAT_TOKEN_(gtest_label_testanythrow_, __LINE__); \
1367 GTEST_CONCAT_TOKEN_(gtest_label_testanythrow_, __LINE__): \
1368 fail("Expected: " #statement " throws an exception.\n" \
1369 " Actual: it doesn't.")
1375 #define GTEST_TEST_BOOLEAN_(expression, text, actual, expected, fail) \
1376 GTEST_AMBIGUOUS_ELSE_BLOCKER_ \
1377 if (const ::testing::AssertionResult gtest_ar_ = \
1378 ::testing::AssertionResult(expression)) \
1381 fail(::testing::internal::GetBoolAssertionFailureMessage(\
1382 gtest_ar_, text, #actual, #expected).c_str())
1384 #define GTEST_TEST_NO_FATAL_FAILURE_(statement, fail) \
1385 GTEST_AMBIGUOUS_ELSE_BLOCKER_ \
1386 if (::testing::internal::AlwaysTrue()) { \
1387 ::testing::internal::HasNewFatalFailureHelper gtest_fatal_failure_checker; \
1388 GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement); \
1389 if (gtest_fatal_failure_checker.has_new_fatal_failure()) { \
1390 goto GTEST_CONCAT_TOKEN_(gtest_label_testnofatal_, __LINE__); \
1393 GTEST_CONCAT_TOKEN_(gtest_label_testnofatal_, __LINE__): \
1394 fail("Expected: " #statement " doesn't generate new fatal " \
1395 "failures in the current thread.\n" \
1396 " Actual: it does.")
1399 #define GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
1400 test_suite_name##_##test_name##_Test
1403 #define GTEST_TEST_(test_suite_name, test_name, parent_class, parent_id) \
1404 class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
1405 : public parent_class { \
1407 GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)() {} \
1410 virtual void TestBody(); \
1411 static ::testing::TestInfo* const test_info_ GTEST_ATTRIBUTE_UNUSED_; \
1412 GTEST_DISALLOW_COPY_AND_ASSIGN_(GTEST_TEST_CLASS_NAME_(test_suite_name, \
1416 ::testing::TestInfo* const GTEST_TEST_CLASS_NAME_(test_suite_name, \
1417 test_name)::test_info_ = \
1418 ::testing::internal::MakeAndRegisterTestInfo( \
1419 #test_suite_name, #test_name, nullptr, nullptr, \
1420 ::testing::internal::CodeLocation(__FILE__, __LINE__), (parent_id), \
1421 ::testing::internal::SuiteApiResolver< \
1422 parent_class>::GetSetUpCaseOrSuite(), \
1423 ::testing::internal::SuiteApiResolver< \
1424 parent_class>::GetTearDownCaseOrSuite(), \
1425 new ::testing::internal::TestFactoryImpl<GTEST_TEST_CLASS_NAME_( \
1426 test_suite_name, test_name)>); \
1427 void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::TestBody()
1437 #if defined(_MSC_VER)
1438 #define GTEST_INTERNAL_DEPRECATED(message) __declspec(deprecated(message))
1439 #elif defined(__GNUC__)
1440 #define GTEST_INTERNAL_DEPRECATED(message) __attribute__((deprecated(message)))
1442 #define GTEST_INTERNAL_DEPRECATED(message)
1444 #endif // GTEST_INCLUDE_GTEST_INTERNAL_GTEST_INTERNAL_H_