blob: 00038eb1ddef5e18f6dbc3015bad6551b7453df4 [file] [log] [blame]
// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef BASE_GTEST_PROD_UTIL_H_
#define BASE_GTEST_PROD_UTIL_H_
#include "base/base_export.h"
#include "testing/gtest/include/gtest/gtest_prod.h" // nogncheck
// This is a wrapper for gtest's FRIEND_TEST macro that friends
// test with all possible prefixes. This is very helpful when changing the test
// prefix, because the friend declarations don't need to be updated.
//
// Example usage:
//
// class MyClass {
// private:
// void MyMethod();
// FRIEND_TEST_ALL_PREFIXES(MyClassTest, TestName);
// };
#define FRIEND_TEST_ALL_PREFIXES(test_case_name, test_name) \
FRIEND_TEST(test_case_name, test_name); \
FRIEND_TEST(test_case_name, DISABLED_##test_name); \
FRIEND_TEST(test_case_name, FLAKY_##test_name)
// C++ compilers will refuse to compile the following code:
//
// namespace foo {
// class MyClass {
// private:
// FRIEND_TEST_ALL_PREFIXES(MyClassTest, TestName);
// bool private_var;
// };
// } // namespace foo
//
// class MyClassTest::TestName() {
// foo::MyClass foo_class;
// foo_class.private_var = true;
// }
//
// Unless you forward declare MyClassTest::TestName outside of namespace foo.
// Use FORWARD_DECLARE_TEST to do so for all possible prefixes.
//
// Example usage:
//
// FORWARD_DECLARE_TEST(MyClassTest, TestName);
//
// namespace foo {
// class MyClass {
// private:
// FRIEND_TEST_ALL_PREFIXES(::MyClassTest, TestName); // NOTE use of ::
// bool private_var;
// };
// } // namespace foo
//
// class MyClassTest::TestName() {
// foo::MyClass foo_class;
// foo_class.private_var = true;
// }
#define FORWARD_DECLARE_TEST(test_case_name, test_name) \
class test_case_name##_##test_name##_Test; \
class test_case_name##_##DISABLED_##test_name##_Test; \
class test_case_name##_##FLAKY_##test_name##_Test
namespace base::internal {
// Returns true if executing within the context of a death test child process.
// This is an internal utility. You do not want to call this. This is provided
// for the sole purpose of suppressing expensive diagnostic logging in these
// child processes, as this logging is ordinarily not exposed to developers.
bool InDeathTestChild();
// Sets a function that may be called to detect whether or not execution is
// within the context of a death test child process. You do not want to call
// this. This is provided so that base::TestSuite can make Google Test's
// InDeathTestChild implementation available for very specific use in production
// code; see above.
using InDeathTestChildFn = bool (*)();
BASE_EXPORT void SetInDeathTestChildFn(
InDeathTestChildFn in_death_test_child_fn);
} // namespace base::internal
#endif // BASE_GTEST_PROD_UTIL_H_