Index: base/test/multiprocess_test.h |
=================================================================== |
--- base/test/multiprocess_test.h (revision 55077) |
+++ base/test/multiprocess_test.h (working copy) |
@@ -1,27 +1,22 @@ |
-// Copyright (c) 2009 The Chromium Authors. All rights reserved. |
+// Copyright (c) 2010 The Chromium Authors. All rights reserved. |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#ifndef BASE_MULTIPROCESS_TEST_H_ |
-#define BASE_MULTIPROCESS_TEST_H_ |
+#ifndef BASE_TEST_MULTIPROCESS_TEST_H_ |
+#define BASE_TEST_MULTIPROCESS_TEST_H_ |
#pragma once |
-#include "base/base_switches.h" |
-#include "base/command_line.h" |
+#include <string> |
+ |
+#include "base/basictypes.h" |
+#include "base/process.h" |
#include "base/process_util.h" |
-#include "base/string_util.h" |
-#include "testing/gtest/include/gtest/gtest.h" |
-#include "testing/multiprocess_func_list.h" |
+#include "build/build_config.h" |
#include "testing/platform_test.h" |
-#if defined(OS_POSIX) |
-#include <sys/types.h> |
-#include <unistd.h> |
-#endif |
+class CommandLine; |
-// Command line switch to invoke a child process rather than |
-// to run the normal test suite. |
-static const char kRunClientProcess[] = "client"; |
+namespace base { |
// A MultiProcessTest is a test class which makes it easier to |
// write a test which requires code running out of process. |
@@ -44,8 +39,10 @@ |
// 3) Call SpawnChild("foo"), where "foo" is the name of |
// the function you wish to run in the child processes. |
// That's it! |
-// |
class MultiProcessTest : public PlatformTest { |
+ public: |
+ MultiProcessTest(); |
+ |
protected: |
// Run a child process. |
// 'procname' is the name of a function which the child will |
@@ -58,64 +55,32 @@ |
// } |
// |
// Returns the handle to the child, or NULL on failure |
- // |
- // TODO(darin): re-enable this once we have base/debug_util.h |
- // ProcessDebugFlags(&cl, DebugUtil::UNKNOWN, false); |
- base::ProcessHandle SpawnChild(const std::string& procname) { |
- return SpawnChild(procname, false); |
- } |
+ ProcessHandle SpawnChild(const std::string& procname, bool debug_on_start); |
- base::ProcessHandle SpawnChild(const std::string& procname, |
- bool debug_on_start) { |
-#if defined(OS_WIN) |
- return SpawnChildImpl(procname, debug_on_start); |
-#elif defined(OS_POSIX) |
- base::file_handle_mapping_vector empty_file_list; |
- return SpawnChildImpl(procname, empty_file_list, debug_on_start); |
-#endif |
- } |
- |
#if defined(OS_POSIX) |
- base::ProcessHandle SpawnChild( |
- const std::string& procname, |
- const base::file_handle_mapping_vector& fds_to_map, |
- bool debug_on_start) { |
- return SpawnChildImpl(procname, fds_to_map, debug_on_start); |
- } |
+ ProcessHandle SpawnChild(const std::string& procname, |
+ const file_handle_mapping_vector& fds_to_map, |
+ bool debug_on_start); |
#endif |
-protected: |
- CommandLine MakeCmdLine(const std::string& procname, bool debug_on_start) { |
- CommandLine cl(*CommandLine::ForCurrentProcess()); |
- cl.AppendSwitchASCII(kRunClientProcess, procname); |
- if (debug_on_start) |
- cl.AppendSwitch(switches::kDebugOnStart); |
- return cl; |
- } |
+ CommandLine MakeCmdLine(const std::string& procname, bool debug_on_start); |
private: |
#if defined(OS_WIN) |
- base::ProcessHandle SpawnChildImpl(const std::string& procname, |
- bool debug_on_start) { |
- base::ProcessHandle handle = static_cast<base::ProcessHandle>(NULL); |
- base::LaunchApp(MakeCmdLine(procname, debug_on_start), |
- false, true, &handle); |
- return handle; |
- } |
+ ProcessHandle SpawnChildImpl(const std::string& procname, |
+ bool debug_on_start); |
#elif defined(OS_POSIX) |
// TODO(port): with the CommandLine refactoring, this code is very similar |
// to the Windows code. Investigate whether this can be made shorter. |
- base::ProcessHandle SpawnChildImpl( |
- const std::string& procname, |
- const base::file_handle_mapping_vector& fds_to_map, |
- bool debug_on_start) { |
- base::ProcessHandle handle = base::kNullProcessHandle; |
- base::LaunchApp(MakeCmdLine(procname, debug_on_start).argv(), |
- fds_to_map, false, &handle); |
- return handle; |
- } |
+ ProcessHandle SpawnChildImpl(const std::string& procname, |
+ const file_handle_mapping_vector& fds_to_map, |
+ bool debug_on_start); |
#endif |
+ |
+ DISALLOW_COPY_AND_ASSIGN(MultiProcessTest); |
}; |
-#endif // BASE_MULTIPROCESS_TEST_H_ |
+} // namespace base |
+ |
+#endif // BASE_TEST_MULTIPROCESS_TEST_H_ |