// 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) … // 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) … #endif // BASE_GTEST_PROD_UTIL_H_