Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef BASE_TEST_GTEST_UTIL_H_ | 5 #ifndef BASE_TEST_GTEST_UTIL_H_ |
| 6 #define BASE_TEST_GTEST_UTIL_H_ | 6 #define BASE_TEST_GTEST_UTIL_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 #include <utility> | 9 #include <utility> |
| 10 #include <vector> | 10 #include <vector> |
| 11 | 11 |
| 12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
| 13 #include "base/logging.h" | |
| 14 #include "build/build_config.h" | |
| 15 #include "testing/gtest/include/gtest/gtest.h" | |
| 16 | |
| 17 // EXPECT/ASSERT_DCHECK_DEATH is intended to replace EXPECT/ASSERT_DEBUG_DEATH | |
| 18 // when the death is expected to be caused by a DCHECK. Contrary to | |
| 19 // EXPECT/ASSERT_DEBUG_DEATH however, it doesn't execute the statement in non- | |
| 20 // dcheck builds as DCHECKs are intended to catch things that should never | |
| 21 // happen and as such executing the statement results in undefined behavior | |
| 22 // (|statement| is compiled in unsupported configurations nonetheless). | |
| 23 // Death tests misbehave on Android. | |
| 24 #if DCHECK_IS_ON() && defined(GTEST_HAS_DEATH_TEST) && !defined(OS_ANDROID) | |
| 25 #define EXPECT_DCHECK_DEATH(statement, regex) EXPECT_DEATH(statement, regex) | |
| 26 #define ASSERT_DCHECK_DEATH(statement, regex) ASSERT_DEATH(statement, regex) | |
| 27 #else | |
| 28 #define EXPECT_DCHECK_DEATH(statement, regex) \ | |
| 29 GTEST_UNSUPPORTED_DEATH_TEST(statement, regex, ) | |
| 30 #define ASSERT_DCHECK_DEATH(statement, regex) \ | |
| 31 GTEST_UNSUPPORTED_DEATH_TEST(statement, regex, return) | |
|
gab
2016/07/20 21:21:08
This won't compile, locally I moved this from test
| |
| 32 #endif | |
| 13 | 33 |
| 14 namespace base { | 34 namespace base { |
| 15 | 35 |
| 16 class FilePath; | 36 class FilePath; |
| 17 | 37 |
| 18 struct TestIdentifier { | 38 struct TestIdentifier { |
| 19 TestIdentifier(); | 39 TestIdentifier(); |
| 20 TestIdentifier(const TestIdentifier& other); | 40 TestIdentifier(const TestIdentifier& other); |
| 21 | 41 |
| 22 std::string test_case_name; | 42 std::string test_case_name; |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 40 | 60 |
| 41 // Reads the list of gtest-based tests from |path| into |output|. | 61 // Reads the list of gtest-based tests from |path| into |output|. |
| 42 // Returns true on success. | 62 // Returns true on success. |
| 43 bool ReadTestNamesFromFile( | 63 bool ReadTestNamesFromFile( |
| 44 const FilePath& path, | 64 const FilePath& path, |
| 45 std::vector<TestIdentifier>* output) WARN_UNUSED_RESULT; | 65 std::vector<TestIdentifier>* output) WARN_UNUSED_RESULT; |
| 46 | 66 |
| 47 } // namespace base | 67 } // namespace base |
| 48 | 68 |
| 49 #endif // BASE_TEST_GTEST_UTIL_H_ | 69 #endif // BASE_TEST_GTEST_UTIL_H_ |
| OLD | NEW |