xref: /aosp_15_r20/external/libchrome/base/test/gtest_util.h (revision 635a864187cb8b6c713ff48b7e790a6b21769273)
1*635a8641SAndroid Build Coastguard Worker // Copyright 2014 The Chromium Authors. All rights reserved.
2*635a8641SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*635a8641SAndroid Build Coastguard Worker // found in the LICENSE file.
4*635a8641SAndroid Build Coastguard Worker 
5*635a8641SAndroid Build Coastguard Worker #ifndef BASE_TEST_GTEST_UTIL_H_
6*635a8641SAndroid Build Coastguard Worker #define BASE_TEST_GTEST_UTIL_H_
7*635a8641SAndroid Build Coastguard Worker 
8*635a8641SAndroid Build Coastguard Worker #include <string>
9*635a8641SAndroid Build Coastguard Worker #include <utility>
10*635a8641SAndroid Build Coastguard Worker #include <vector>
11*635a8641SAndroid Build Coastguard Worker 
12*635a8641SAndroid Build Coastguard Worker #include "base/compiler_specific.h"
13*635a8641SAndroid Build Coastguard Worker #include "base/logging.h"
14*635a8641SAndroid Build Coastguard Worker #include "build/build_config.h"
15*635a8641SAndroid Build Coastguard Worker #include "testing/gtest/include/gtest/gtest.h"
16*635a8641SAndroid Build Coastguard Worker 
17*635a8641SAndroid Build Coastguard Worker // EXPECT/ASSERT_DCHECK_DEATH is intended to replace EXPECT/ASSERT_DEBUG_DEATH
18*635a8641SAndroid Build Coastguard Worker // when the death is expected to be caused by a DCHECK. Contrary to
19*635a8641SAndroid Build Coastguard Worker // EXPECT/ASSERT_DEBUG_DEATH however, it doesn't execute the statement in non-
20*635a8641SAndroid Build Coastguard Worker // dcheck builds as DCHECKs are intended to catch things that should never
21*635a8641SAndroid Build Coastguard Worker // happen and as such executing the statement results in undefined behavior
22*635a8641SAndroid Build Coastguard Worker // (|statement| is compiled in unsupported configurations nonetheless).
23*635a8641SAndroid Build Coastguard Worker // Death tests misbehave on Android.
24*635a8641SAndroid Build Coastguard Worker #if DCHECK_IS_ON() && defined(GTEST_HAS_DEATH_TEST) && !defined(OS_ANDROID)
25*635a8641SAndroid Build Coastguard Worker 
26*635a8641SAndroid Build Coastguard Worker // EXPECT/ASSERT_DCHECK_DEATH tests verify that a DCHECK is hit ("Check failed"
27*635a8641SAndroid Build Coastguard Worker // is part of the error message), but intentionally do not expose the gtest
28*635a8641SAndroid Build Coastguard Worker // death test's full |regex| parameter to avoid users having to verify the exact
29*635a8641SAndroid Build Coastguard Worker // syntax of the error message produced by the DCHECK.
30*635a8641SAndroid Build Coastguard Worker #define EXPECT_DCHECK_DEATH(statement) EXPECT_DEATH(statement, "Check failed")
31*635a8641SAndroid Build Coastguard Worker #define ASSERT_DCHECK_DEATH(statement) ASSERT_DEATH(statement, "Check failed")
32*635a8641SAndroid Build Coastguard Worker 
33*635a8641SAndroid Build Coastguard Worker #else
34*635a8641SAndroid Build Coastguard Worker // DCHECK_IS_ON() && defined(GTEST_HAS_DEATH_TEST) && !defined(OS_ANDROID)
35*635a8641SAndroid Build Coastguard Worker 
36*635a8641SAndroid Build Coastguard Worker #define EXPECT_DCHECK_DEATH(statement) \
37*635a8641SAndroid Build Coastguard Worker     GTEST_UNSUPPORTED_DEATH_TEST(statement, "Check failed", )
38*635a8641SAndroid Build Coastguard Worker #define ASSERT_DCHECK_DEATH(statement) \
39*635a8641SAndroid Build Coastguard Worker     GTEST_UNSUPPORTED_DEATH_TEST(statement, "Check failed", return)
40*635a8641SAndroid Build Coastguard Worker 
41*635a8641SAndroid Build Coastguard Worker #endif
42*635a8641SAndroid Build Coastguard Worker // DCHECK_IS_ON() && defined(GTEST_HAS_DEATH_TEST) && !defined(OS_ANDROID)
43*635a8641SAndroid Build Coastguard Worker 
44*635a8641SAndroid Build Coastguard Worker namespace base {
45*635a8641SAndroid Build Coastguard Worker 
46*635a8641SAndroid Build Coastguard Worker class FilePath;
47*635a8641SAndroid Build Coastguard Worker 
48*635a8641SAndroid Build Coastguard Worker struct TestIdentifier {
49*635a8641SAndroid Build Coastguard Worker   TestIdentifier();
50*635a8641SAndroid Build Coastguard Worker   TestIdentifier(const TestIdentifier& other);
51*635a8641SAndroid Build Coastguard Worker 
52*635a8641SAndroid Build Coastguard Worker   std::string test_case_name;
53*635a8641SAndroid Build Coastguard Worker   std::string test_name;
54*635a8641SAndroid Build Coastguard Worker   std::string file;
55*635a8641SAndroid Build Coastguard Worker   int line;
56*635a8641SAndroid Build Coastguard Worker };
57*635a8641SAndroid Build Coastguard Worker 
58*635a8641SAndroid Build Coastguard Worker // Constructs a full test name given a test case name and a test name,
59*635a8641SAndroid Build Coastguard Worker // e.g. for test case "A" and test name "B" returns "A.B".
60*635a8641SAndroid Build Coastguard Worker std::string FormatFullTestName(const std::string& test_case_name,
61*635a8641SAndroid Build Coastguard Worker                                const std::string& test_name);
62*635a8641SAndroid Build Coastguard Worker 
63*635a8641SAndroid Build Coastguard Worker // Returns the full test name with the "DISABLED_" prefix stripped out.
64*635a8641SAndroid Build Coastguard Worker // e.g. for the full test names "A.DISABLED_B", "DISABLED_A.B", and
65*635a8641SAndroid Build Coastguard Worker // "DISABLED_A.DISABLED_B", returns "A.B".
66*635a8641SAndroid Build Coastguard Worker std::string TestNameWithoutDisabledPrefix(const std::string& full_test_name);
67*635a8641SAndroid Build Coastguard Worker 
68*635a8641SAndroid Build Coastguard Worker // Returns a vector of gtest-based tests compiled into
69*635a8641SAndroid Build Coastguard Worker // current executable.
70*635a8641SAndroid Build Coastguard Worker std::vector<TestIdentifier> GetCompiledInTests();
71*635a8641SAndroid Build Coastguard Worker 
72*635a8641SAndroid Build Coastguard Worker // Writes the list of gtest-based tests compiled into
73*635a8641SAndroid Build Coastguard Worker // current executable as a JSON file. Returns true on success.
74*635a8641SAndroid Build Coastguard Worker bool WriteCompiledInTestsToFile(const FilePath& path) WARN_UNUSED_RESULT;
75*635a8641SAndroid Build Coastguard Worker 
76*635a8641SAndroid Build Coastguard Worker // Reads the list of gtest-based tests from |path| into |output|.
77*635a8641SAndroid Build Coastguard Worker // Returns true on success.
78*635a8641SAndroid Build Coastguard Worker bool ReadTestNamesFromFile(
79*635a8641SAndroid Build Coastguard Worker     const FilePath& path,
80*635a8641SAndroid Build Coastguard Worker     std::vector<TestIdentifier>* output) WARN_UNUSED_RESULT;
81*635a8641SAndroid Build Coastguard Worker 
82*635a8641SAndroid Build Coastguard Worker }  // namespace base
83*635a8641SAndroid Build Coastguard Worker 
84*635a8641SAndroid Build Coastguard Worker #endif  // BASE_TEST_GTEST_UTIL_H_
85