Update .DEPS.git
[chromium-blink-merge.git] / base / test / test_suite.h
blob1758f867c3515ad9fe4ced9b7e76be6d7d378fed
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.
12 #include <string>
14 #include "base/at_exit.h"
15 #include "base/memory/scoped_ptr.h"
17 namespace testing {
18 class TestInfo;
21 namespace base {
23 class TestSuite {
24 public:
25 // Match function used by the GetTestCount method.
26 typedef bool (*TestMatch)(const testing::TestInfo&);
28 TestSuite(int argc, char** argv);
29 virtual ~TestSuite();
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();
55 int Run();
57 // A command-line flag that makes a test failure always result in a non-zero
58 // process exit code.
59 static const char kStrictFailureHandling[];
61 protected:
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
82 // destroyed.
83 scoped_ptr<base::AtExitManager> at_exit_manager_;
85 private:
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);
94 } // namespace base
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_