diff options
-rw-r--r-- | base/process_util_win.cc | 2 | ||||
-rw-r--r-- | chrome/test/ui/ui_test_suite.cc | 97 | ||||
-rw-r--r-- | chrome/test/ui/ui_test_suite.h | 53 |
3 files changed, 107 insertions, 45 deletions
diff --git a/base/process_util_win.cc b/base/process_util_win.cc index 9829a41..0ced788 100644 --- a/base/process_util_win.cc +++ b/base/process_util_win.cc @@ -178,7 +178,7 @@ bool KillProcess(ProcessHandle process, int exit_code, bool wait) { // The process may not end immediately due to pending I/O if (WAIT_OBJECT_0 != WaitForSingleObject(process, 60 * 1000)) DLOG(ERROR) << "Error waiting for process exit: " << GetLastError(); - } else { + } else if (!result) { DLOG(ERROR) << "Unable to terminate process: " << GetLastError(); } return result; diff --git a/chrome/test/ui/ui_test_suite.cc b/chrome/test/ui/ui_test_suite.cc index d8d24fb..3ff0fef 100644 --- a/chrome/test/ui/ui_test_suite.cc +++ b/chrome/test/ui/ui_test_suite.cc @@ -4,9 +4,106 @@ #include "chrome/test/ui/ui_test_suite.h" +#include "base/path_service.h" +#include "base/process_util.h" +#include "base/sys_info.h" +#include "chrome/common/env_vars.h" + // Force a test to use an already running browser instance. UI tests only. const wchar_t UITestSuite::kUseExistingBrowser[] = L"use-existing-browser"; // Timeout for the test in milliseconds. UI tests only. const wchar_t UITestSuite::kTestTimeout[] = L"test-timeout"; + +UITestSuite::UITestSuite(int argc, char** argv) + : ChromeTestSuite(argc, argv) { +#if defined(OS_WIN) + crash_service_ = NULL; +#endif +} + +void UITestSuite::Initialize() { + ChromeTestSuite::Initialize(); + + const CommandLine& parsed_command_line = *CommandLine::ForCurrentProcess(); + UITest::set_in_process_renderer( + parsed_command_line.HasSwitch(switches::kSingleProcess)); + UITest::set_no_sandbox( + parsed_command_line.HasSwitch(switches::kNoSandbox)); + UITest::set_full_memory_dump( + parsed_command_line.HasSwitch(switches::kFullMemoryCrashReport)); + UITest::set_safe_plugins( + parsed_command_line.HasSwitch(switches::kSafePlugins)); + UITest::set_use_existing_browser( + parsed_command_line.HasSwitch(UITestSuite::kUseExistingBrowser)); + UITest::set_dump_histograms_on_exit( + parsed_command_line.HasSwitch(switches::kDumpHistogramsOnExit)); + UITest::set_enable_dcheck( + parsed_command_line.HasSwitch(switches::kEnableDCHECK)); + UITest::set_silent_dump_on_dcheck( + parsed_command_line.HasSwitch(switches::kSilentDumpOnDCHECK)); + UITest::set_disable_breakpad( + parsed_command_line.HasSwitch(switches::kDisableBreakpad)); + std::wstring test_timeout = + parsed_command_line.GetSwitchValue(UITestSuite::kTestTimeout); + if (!test_timeout.empty()) { + UITest::set_test_timeout_ms(StringToInt(WideToUTF16Hack(test_timeout))); + } + std::wstring js_flags = + parsed_command_line.GetSwitchValue(switches::kJavaScriptFlags); + if (!js_flags.empty()) { + UITest::set_js_flags(js_flags); + } + std::wstring log_level = + parsed_command_line.GetSwitchValue(switches::kLoggingLevel); + if (!log_level.empty()) { + UITest::set_log_level(log_level); + } + +#if defined(OS_WIN) + LoadCrashService(); +#endif +} + +void UITestSuite::Shutdown() { +#if defined(OS_WIN) + if (crash_service_) + base::KillProcess(crash_service_, 0, false); +#endif + + ChromeTestSuite::Shutdown(); +} + +void UITestSuite::SuppressErrorDialogs() { +#if defined(OS_WIN) + TestSuite::SuppressErrorDialogs(); +#endif + UITest::set_show_error_dialogs(false); +} + +#if defined(OS_WIN) +void UITestSuite::LoadCrashService() { + if (base::SysInfo::HasEnvVar(env_vars::kHeadless)) + return; + + if (base::GetProcessCount(L"crash_service.exe", NULL)) + return; + + FilePath exe_dir; + if (!PathService::Get(base::DIR_EXE, &exe_dir)) { + DCHECK(false); + return; + } + + FilePath crash_service = exe_dir.Append(L"crash_service.exe"); + if (!base::LaunchApp(crash_service.ToWStringHack(), false, false, + &crash_service_)) { + printf("Couldn't start crash_service.exe, so this ui_test run won't tell " \ + "you if any test crashes!\n"); + return; + } + + printf("Started crash_service.exe so you know if a test crashes!\n"); +} +#endif diff --git a/chrome/test/ui/ui_test_suite.h b/chrome/test/ui/ui_test_suite.h index 4961b3f..7da80fa 100644 --- a/chrome/test/ui/ui_test_suite.h +++ b/chrome/test/ui/ui_test_suite.h @@ -5,63 +5,28 @@ #ifndef CHROME_TEST_UI_UI_TEST_SUITE_H_ #define CHROME_TEST_UI_UI_TEST_SUITE_H_ +#include "base/process.h" #include "chrome/test/ui/ui_test.h" #include "chrome/test/unit/chrome_test_suite.h" class UITestSuite : public ChromeTestSuite { public: - UITestSuite(int argc, char** argv) : ChromeTestSuite(argc, argv) { - } + UITestSuite(int argc, char** argv); protected: + virtual void Initialize(); - virtual void Initialize() { - ChromeTestSuite::Initialize(); + virtual void Shutdown(); - const CommandLine& parsed_command_line = *CommandLine::ForCurrentProcess(); - UITest::set_in_process_renderer( - parsed_command_line.HasSwitch(switches::kSingleProcess)); - UITest::set_no_sandbox( - parsed_command_line.HasSwitch(switches::kNoSandbox)); - UITest::set_full_memory_dump( - parsed_command_line.HasSwitch(switches::kFullMemoryCrashReport)); - UITest::set_safe_plugins( - parsed_command_line.HasSwitch(switches::kSafePlugins)); - UITest::set_use_existing_browser( - parsed_command_line.HasSwitch(UITestSuite::kUseExistingBrowser)); - UITest::set_dump_histograms_on_exit( - parsed_command_line.HasSwitch(switches::kDumpHistogramsOnExit)); - UITest::set_enable_dcheck( - parsed_command_line.HasSwitch(switches::kEnableDCHECK)); - UITest::set_silent_dump_on_dcheck( - parsed_command_line.HasSwitch(switches::kSilentDumpOnDCHECK)); - UITest::set_disable_breakpad( - parsed_command_line.HasSwitch(switches::kDisableBreakpad)); - std::wstring test_timeout = - parsed_command_line.GetSwitchValue(UITestSuite::kTestTimeout); - if (!test_timeout.empty()) { - UITest::set_test_timeout_ms(StringToInt(WideToUTF16Hack(test_timeout))); - } - std::wstring js_flags = - parsed_command_line.GetSwitchValue(switches::kJavaScriptFlags); - if (!js_flags.empty()) { - UITest::set_js_flags(js_flags); - } - std::wstring log_level = - parsed_command_line.GetSwitchValue(switches::kLoggingLevel); - if (!log_level.empty()) { - UITest::set_log_level(log_level); - } - } + virtual void SuppressErrorDialogs(); - virtual void SuppressErrorDialogs() { + private: #if defined(OS_WIN) - TestSuite::SuppressErrorDialogs(); + void LoadCrashService(); + + base::ProcessHandle crash_service_; #endif - UITest::set_show_error_dialogs(false); - } - private: static const wchar_t kUseExistingBrowser[]; static const wchar_t kTestTimeout[]; }; |