1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef BASE_TEST_TEST_SUITE_H_
6 #define BASE_TEST_TEST_SUITE_H_
8 // Defines a basic test suite framework for running gtest based tests. You can
9 // instantiate this class in your main function and call its Run method to run
10 // any gtest based tests that are linked into your executable.
14 #include "base/at_exit.h"
15 #include "base/memory/scoped_ptr.h"
25 // Match function used by the GetTestCount method.
26 typedef bool (*TestMatch
)(const testing::TestInfo
&);
28 TestSuite(int argc
, char** argv
);
31 // Returns true if the test is marked as flaky.
32 static bool IsMarkedFlaky(const testing::TestInfo
& test
);
34 // Returns true if the test is marked as failing.
35 static bool IsMarkedFailing(const testing::TestInfo
& test
);
37 // Returns true if the test is marked as "MAYBE_".
38 // When using different prefixes depending on platform, we use MAYBE_ and
39 // preprocessor directives to replace MAYBE_ with the target prefix.
40 static bool IsMarkedMaybe(const testing::TestInfo
& test
);
42 // Returns true if the test failure should be ignored.
43 static bool ShouldIgnoreFailure(const testing::TestInfo
& test
);
45 // Returns true if the test failed and the failure shouldn't be ignored.
46 static bool NonIgnoredFailures(const testing::TestInfo
& test
);
48 // Returns the number of tests where the match function returns true.
49 int GetTestCount(TestMatch test_match
);
51 void CatchMaybeTests();
53 void ResetCommandLine();
57 // A command-line flag that makes a test failure always result in a non-zero
59 static const char kStrictFailureHandling
[];
62 // This constructor is only accessible to specialized test suite
63 // implementations which need to control the creation of an AtExitManager
64 // instance for the duration of the test.
65 TestSuite(int argc
, char** argv
, bool create_at_exit_manager
);
67 // By default fatal log messages (e.g. from DCHECKs) result in error dialogs
68 // which gum up buildbots. Use a minimalistic assert handler which just
69 // terminates the process.
70 static void UnitTestAssertHandler(const std::string
& str
);
72 // Disable crash dialogs so that it doesn't gum up the buildbot
73 virtual void SuppressErrorDialogs();
75 // Override these for custom initialization and shutdown handling. Use these
76 // instead of putting complex code in your constructor/destructor.
78 virtual void Initialize();
79 virtual void Shutdown();
81 // Make sure that we setup an AtExitManager so Singleton objects will be
83 scoped_ptr
<base::AtExitManager
> at_exit_manager_
;
86 // Basic initialization for the test suite happens here.
87 void PreInitialize(int argc
, char** argv
, bool create_at_exit_manager
);
89 bool initialized_command_line_
;
91 DISALLOW_COPY_AND_ASSIGN(TestSuite
);
96 // TODO(brettw) remove this. This is a temporary hack to allow WebKit to compile
97 // until we can update it to use "base::" (preventing a two-sided patch).
98 using base::TestSuite
;
100 #endif // BASE_TEST_TEST_SUITE_H_