Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "content/test/content_browser_test.h" | 5 #include "content/test/content_browser_test.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/debug/stack_trace.h" | 8 #include "base/debug/stack_trace.h" |
| 9 #include "base/file_path.h" | 9 #include "base/file_path.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| 11 #include "base/message_loop.h" | 11 #include "base/message_loop.h" |
| 12 #include "base/path_service.h" | 12 #include "base/path_service.h" |
| 13 #include "content/public/browser/render_process_host.h" | 13 #include "content/public/browser/render_process_host.h" |
| 14 #include "content/public/common/content_switches.h" | 14 #include "content/public/common/content_switches.h" |
| 15 #include "content/shell/shell.h" | 15 #include "content/shell/shell.h" |
| 16 #include "content/shell/shell_main_delegate.h" | 16 #include "content/shell/shell_main_delegate.h" |
| 17 #include "content/shell/shell_switches.h" | 17 #include "content/shell/shell_switches.h" |
| 18 #include "content/test/test_content_client.h" | 18 #include "content/test/test_content_client.h" |
| 19 | 19 |
| 20 #if defined(OS_CHROMEOS) | |
| 21 #include "chromeos/dbus/mock_dbus_thread_manager.h" | |
| 22 #endif | |
| 23 | |
| 20 #if defined(OS_MACOSX) | 24 #if defined(OS_MACOSX) |
| 21 #include "base/mac/scoped_nsautorelease_pool.h" | 25 #include "base/mac/scoped_nsautorelease_pool.h" |
| 22 #endif | 26 #endif |
| 23 | 27 |
| 24 namespace content { | 28 namespace content { |
| 25 | 29 |
| 26 ContentBrowserTest::ContentBrowserTest() { | 30 ContentBrowserTest::ContentBrowserTest() { |
| 27 #if defined(OS_MACOSX) | 31 #if defined(OS_MACOSX) |
| 28 // See comment in InProcessBrowserTest::InProcessBrowserTest(). | 32 // See comment in InProcessBrowserTest::InProcessBrowserTest(). |
| 29 FilePath content_shell_path; | 33 FilePath content_shell_path; |
| 30 CHECK(PathService::Get(base::FILE_EXE, &content_shell_path)); | 34 CHECK(PathService::Get(base::FILE_EXE, &content_shell_path)); |
| 31 content_shell_path = content_shell_path.DirName(); | 35 content_shell_path = content_shell_path.DirName(); |
| 32 content_shell_path = content_shell_path.Append( | 36 content_shell_path = content_shell_path.Append( |
| 33 FILE_PATH_LITERAL("Content Shell.app/Contents/MacOS/Content Shell")); | 37 FILE_PATH_LITERAL("Content Shell.app/Contents/MacOS/Content Shell")); |
| 34 CHECK(PathService::Override(base::FILE_EXE, content_shell_path)); | 38 CHECK(PathService::Override(base::FILE_EXE, content_shell_path)); |
| 35 #endif | 39 #endif |
| 36 } | 40 } |
| 37 | 41 |
| 38 ContentBrowserTest::~ContentBrowserTest() { | 42 ContentBrowserTest::~ContentBrowserTest() { |
| 39 } | 43 } |
| 40 | 44 |
| 41 void ContentBrowserTest::SetUp() { | 45 void ContentBrowserTest::SetUp() { |
| 46 #if defined(OS_CHROMEOS) | |
| 47 chromeos::MockDBusThreadManager* mock_dbus_thread_manager = | |
| 48 new chromeos::MockDBusThreadManager; | |
| 49 chromeos::DBusThreadManager::InitializeForTesting(mock_dbus_thread_manager); | |
|
jam
2012/07/25 16:29:02
a CrOS person should maybe look at this, but are y
| |
| 50 #endif | |
| 51 | |
| 42 shell_main_delegate_.reset(new ShellMainDelegate); | 52 shell_main_delegate_.reset(new ShellMainDelegate); |
| 43 shell_main_delegate_->PreSandboxStartup(); | 53 shell_main_delegate_->PreSandboxStartup(); |
| 44 | 54 |
| 45 CommandLine* command_line = CommandLine::ForCurrentProcess(); | 55 CommandLine* command_line = CommandLine::ForCurrentProcess(); |
| 46 command_line->AppendSwitch(switches::kContentBrowserTest); | 56 command_line->AppendSwitch(switches::kContentBrowserTest); |
| 47 | 57 |
| 48 SetUpCommandLine(command_line); | 58 SetUpCommandLine(command_line); |
| 49 | 59 |
| 50 #if defined(OS_MACOSX) | 60 #if defined(OS_MACOSX) |
| 51 // See InProcessBrowserTest::PrepareTestCommandLine(). | 61 // See InProcessBrowserTest::PrepareTestCommandLine(). |
| 52 FilePath subprocess_path; | 62 FilePath subprocess_path; |
| 53 PathService::Get(base::FILE_EXE, &subprocess_path); | 63 PathService::Get(base::FILE_EXE, &subprocess_path); |
| 54 subprocess_path = subprocess_path.DirName().DirName(); | 64 subprocess_path = subprocess_path.DirName().DirName(); |
| 55 DCHECK_EQ(subprocess_path.BaseName().value(), "Contents"); | 65 DCHECK_EQ(subprocess_path.BaseName().value(), "Contents"); |
| 56 subprocess_path = subprocess_path.Append( | 66 subprocess_path = subprocess_path.Append( |
| 57 "Frameworks/Content Shell Helper.app/Contents/MacOS/Content Shell Helper") ; | 67 "Frameworks/Content Shell Helper.app/Contents/MacOS/Content Shell Helper") ; |
| 58 command_line->AppendSwitchPath(switches::kBrowserSubprocessPath, | 68 command_line->AppendSwitchPath(switches::kBrowserSubprocessPath, |
| 59 subprocess_path); | 69 subprocess_path); |
| 60 #endif | 70 #endif |
| 61 | 71 |
| 62 BrowserTestBase::SetUp(); | 72 BrowserTestBase::SetUp(); |
| 63 } | 73 } |
| 64 | 74 |
| 65 void ContentBrowserTest::TearDown() { | 75 void ContentBrowserTest::TearDown() { |
| 66 BrowserTestBase::TearDown(); | 76 BrowserTestBase::TearDown(); |
| 67 | 77 |
| 68 shell_main_delegate_.reset(); | 78 shell_main_delegate_.reset(); |
| 79 | |
| 80 #if defined(OS_CHROMEOS) | |
| 81 chromeos::DBusThreadManager::Shutdown(); | |
| 82 #endif | |
| 69 } | 83 } |
| 70 | 84 |
| 71 #if defined(OS_POSIX) | 85 #if defined(OS_POSIX) |
| 72 // On SIGTERM (sent by the runner on timeouts), dump a stack trace (to make | 86 // On SIGTERM (sent by the runner on timeouts), dump a stack trace (to make |
| 73 // debugging easier) and also exit with a known error code (so that the test | 87 // debugging easier) and also exit with a known error code (so that the test |
| 74 // framework considers this a failure -- http://crbug.com/57578). | 88 // framework considers this a failure -- http://crbug.com/57578). |
| 75 static void DumpStackTraceSignalHandler(int signal) { | 89 static void DumpStackTraceSignalHandler(int signal) { |
| 76 base::debug::StackTrace().PrintBacktrace(); | 90 base::debug::StackTrace().PrintBacktrace(); |
| 77 _exit(128 + signal); | 91 _exit(128 + signal); |
| 78 } | 92 } |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 111 pool.Recycle(); | 125 pool.Recycle(); |
| 112 #endif | 126 #endif |
| 113 | 127 |
| 114 for (RenderProcessHost::iterator i(RenderProcessHost::AllHostsIterator()); | 128 for (RenderProcessHost::iterator i(RenderProcessHost::AllHostsIterator()); |
| 115 !i.IsAtEnd(); i.Advance()) { | 129 !i.IsAtEnd(); i.Advance()) { |
| 116 i.GetCurrentValue()->FastShutdownIfPossible(); | 130 i.GetCurrentValue()->FastShutdownIfPossible(); |
| 117 } | 131 } |
| 118 } | 132 } |
| 119 | 133 |
| 120 } // namespace content | 134 } // namespace content |
| OLD | NEW |