Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(87)

Unified Diff: chrome/test/in_process_browser_test.cc

Issue 4724004: Group commandline settings in UI test and in process browser test. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 10 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/test/in_process_browser_test.h ('k') | chrome/test/ui/ui_test.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/test/in_process_browser_test.cc
===================================================================
--- chrome/test/in_process_browser_test.cc (revision 65553)
+++ chrome/test/in_process_browser_test.cc (working copy)
@@ -138,57 +138,18 @@
// Allow subclasses the opportunity to make changes to the command line before
// running any tests.
SetUpCommandLine(command_line);
+ // Add command line arguments that are used by all InProcessBrowserTests.
+ PrepareCommonInProcessBrowserTestCommandLine(command_line);
+ // Add browser command line arguments that are used by all tests.
+ test_launcher_utils::PrepareBrowserCommandLineForTests(command_line);
-#if defined(OS_WIN)
- // Hide windows on show.
- if (!command_line->HasSwitch(kUnitTestShowWindows) && !show_window_)
- BrowserView::SetShowState(SW_HIDE);
-#endif
-
- if (dom_automation_enabled_)
- command_line->AppendSwitch(switches::kDomAutomationController);
-
- // This is a Browser test.
- command_line->AppendSwitchASCII(switches::kTestType, kBrowserTestType);
-
- // Single-process mode is not set in BrowserMain so it needs to be processed
- // explicitly.
+ // Save the single process mode state before it was reset in this test. This
+ // state will be recovered in TearDown(). single-process mode is not set in
+ // BrowserMain so it needs to be processed explicitly.
original_single_process_ = RenderProcessHost::run_renderer_in_process();
if (command_line->HasSwitch(switches::kSingleProcess))
RenderProcessHost::set_run_renderer_in_process(true);
-#if defined(OS_WIN)
- // The Windows sandbox requires that the browser and child processes are the
- // same binary. So we launch browser_process.exe which loads chrome.dll
- command_line->AppendSwitchPath(switches::kBrowserSubprocessPath,
- command_line->GetProgram());
-#else
- // Explicitly set the path of the binary used for child processes, otherwise
- // they'll try to use browser_tests which doesn't contain ChromeMain.
- FilePath subprocess_path;
- PathService::Get(base::FILE_EXE, &subprocess_path);
- subprocess_path = subprocess_path.DirName();
- subprocess_path = subprocess_path.AppendASCII(WideToASCII(
- chrome::kBrowserProcessExecutablePath));
-#if defined(OS_MACOSX)
- // Recreate the real environment, run the helper within the app bundle.
- subprocess_path = subprocess_path.DirName().DirName();
- DCHECK_EQ(subprocess_path.BaseName().value(), "Contents");
- subprocess_path =
- subprocess_path.Append("Versions").Append(chrome::kChromeVersion);
- subprocess_path =
- subprocess_path.Append(chrome::kHelperProcessExecutablePath);
-#endif
- command_line->AppendSwitchPath(switches::kBrowserSubprocessPath,
- subprocess_path);
-#endif
-
- // If ncecessary, disable TabCloseableStateWatcher.
- if (!tab_closeable_state_watcher_enabled_)
- command_line->AppendSwitch(switches::kDisableTabCloseableStateWatcher);
-
- test_launcher_utils::PrepareBrowserCommandLineForTests(command_line);
-
#if defined(OS_CHROMEOS)
chromeos::CrosLibrary::Get()->GetTestApi()->SetUseStubImpl();
@@ -243,6 +204,52 @@
TearDownInProcessBrowserTestFixture();
}
+void InProcessBrowserTest::PrepareCommonInProcessBrowserTestCommandLine(
+ CommandLine* command_line) {
+#if defined(OS_WIN)
+ // Hide windows on show.
+ if (!command_line->HasSwitch(kUnitTestShowWindows) && !show_window_)
+ BrowserView::SetShowState(SW_HIDE);
+#endif
+
+ if (dom_automation_enabled_)
+ command_line->AppendSwitch(switches::kDomAutomationController);
+
+ // This is a Browser test.
+ command_line->AppendSwitchASCII(switches::kTestType, kBrowserTestType);
+
+#if defined(OS_WIN)
+ // The Windows sandbox requires that the browser and child processes are the
+ // same binary. So we launch browser_process.exe which loads chrome.dll
+ command_line->AppendSwitchPath(switches::kBrowserSubprocessPath,
+ command_line->GetProgram());
+#else
+ // Explicitly set the path of the binary used for child processes, otherwise
+ // they'll try to use browser_tests which doesn't contain ChromeMain.
+ FilePath subprocess_path;
+ PathService::Get(base::FILE_EXE, &subprocess_path);
+ subprocess_path = subprocess_path.DirName();
+ subprocess_path = subprocess_path.AppendASCII(WideToASCII(
+ chrome::kBrowserProcessExecutablePath));
+#if defined(OS_MACOSX)
+ // Recreate the real environment, run the helper within the app bundle.
+ subprocess_path = subprocess_path.DirName().DirName();
+ DCHECK_EQ(subprocess_path.BaseName().value(), "Contents");
+ subprocess_path =
+ subprocess_path.Append("Versions").Append(chrome::kChromeVersion);
+ subprocess_path =
+ subprocess_path.Append(chrome::kHelperProcessExecutablePath);
Scott Hess - ex-Googler 2010/11/10 23:29:31 Wow, this Mac-specific code is messed up.
+#endif
+ command_line->AppendSwitchPath(switches::kBrowserSubprocessPath,
+ subprocess_path);
+#endif
+
+ // If ncecessary, disable TabCloseableStateWatcher.
+ if (!tab_closeable_state_watcher_enabled_)
+ command_line->AppendSwitch(switches::kDisableTabCloseableStateWatcher);
+}
+
+
bool InProcessBrowserTest::CreateUserDataDirectory() {
CommandLine* command_line = CommandLine::ForCurrentProcessMutable();
FilePath user_data_dir =
« no previous file with comments | « chrome/test/in_process_browser_test.h ('k') | chrome/test/ui/ui_test.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698