1 // Copyright 2013 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_LAUNCHER_UNIT_TEST_LAUNCHER_H_
6 #define BASE_TEST_LAUNCHER_UNIT_TEST_LAUNCHER_H_
8 #include "base/callback.h"
9 #include "base/files/file_path.h"
10 #include "base/test/launcher/test_launcher.h"
14 // Callback that runs a test suite and returns exit code.
15 typedef base::Callback
<int(void)> RunTestSuiteCallback
;
17 // Launches unit tests in given test suite. Returns exit code.
18 int LaunchUnitTests(int argc
,
20 const RunTestSuiteCallback
& run_test_suite
);
22 // Same as above, but always runs tests serially.
23 int LaunchUnitTestsSerially(int argc
,
25 const RunTestSuiteCallback
& run_test_suite
);
28 // Launches unit tests in given test suite. Returns exit code.
29 // |use_job_objects| determines whether to use job objects.
30 int LaunchUnitTests(int argc
,
33 const RunTestSuiteCallback
& run_test_suite
);
34 #endif // defined(OS_WIN)
36 // Delegate to abstract away platform differences for unit tests.
37 class UnitTestPlatformDelegate
{
39 // Called to get names of tests available for running. The delegate
40 // must put the result in |output| and return true on success.
41 virtual bool GetTests(std::vector
<SplitTestName
>* output
) = 0;
43 // Called to create a temporary file. The delegate must put the resulting
44 // path in |path| and return true on success.
45 virtual bool CreateTemporaryFile(base::FilePath
* path
) = 0;
47 // Returns command line for child GTest process based on the command line
48 // of current process. |test_names| is a vector of test full names
49 // (e.g. "A.B"), |output_file| is path to the GTest XML output file.
50 virtual CommandLine
GetCommandLineForChildGTestProcess(
51 const std::vector
<std::string
>& test_names
,
52 const base::FilePath
& output_file
) = 0;
54 // Returns wrapper to use for child GTest process. Empty string means
56 virtual std::string
GetWrapperForChildGTestProcess() = 0;
58 // Relaunch tests, e.g. after a crash.
59 virtual void RelaunchTests(TestLauncher
* test_launcher
,
60 const std::vector
<std::string
>& test_names
,
61 int launch_flags
) = 0;
64 ~UnitTestPlatformDelegate() {}
67 // Runs tests serially, each in its own process.
68 void RunUnitTestsSerially(TestLauncher
* test_launcher
,
69 UnitTestPlatformDelegate
* platform_delegate
,
70 const std::vector
<std::string
>& test_names
,
73 // Runs tests in batches (each batch in its own process).
74 void RunUnitTestsBatch(TestLauncher
* test_launcher
,
75 UnitTestPlatformDelegate
* platform_delegate
,
76 const std::vector
<std::string
>& test_names
,
79 // Test launcher delegate for unit tests (mostly to support batching).
80 class UnitTestLauncherDelegate
: public TestLauncherDelegate
{
82 UnitTestLauncherDelegate(UnitTestPlatformDelegate
* delegate
,
84 bool use_job_objects
);
85 ~UnitTestLauncherDelegate() override
;
88 // TestLauncherDelegate:
89 bool GetTests(std::vector
<SplitTestName
>* output
) override
;
90 bool ShouldRunTest(const std::string
& test_case_name
,
91 const std::string
& test_name
) override
;
92 size_t RunTests(TestLauncher
* test_launcher
,
93 const std::vector
<std::string
>& test_names
) override
;
94 size_t RetryTests(TestLauncher
* test_launcher
,
95 const std::vector
<std::string
>& test_names
) override
;
97 ThreadChecker thread_checker_
;
99 UnitTestPlatformDelegate
* platform_delegate_
;
101 // Maximum number of tests to run in a single batch.
104 // Determines whether we use job objects on Windows.
105 bool use_job_objects_
;
107 DISALLOW_COPY_AND_ASSIGN(UnitTestLauncherDelegate
);
112 #endif // BASE_TEST_LAUNCHER_UNIT_TEST_LAUNCHER_H_