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

Side by Side Diff: chrome/test/ui/ui_test.cc

Issue 195106: Implement per-test timeout for UI tests. (Closed)
Patch Set: sync with trunk Created 11 years, 2 months 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 unified diff | Download patch
« no previous file with comments | « chrome/test/ui/ui_test.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2006-2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2006-2009 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 "chrome/test/ui/ui_test.h" 5 #include "chrome/test/ui/ui_test.h"
6 6
7 #include <set> 7 #include <set>
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/base_switches.h" 10 #include "base/base_switches.h"
(...skipping 26 matching lines...) Expand all
37 37
38 using base::TimeTicks; 38 using base::TimeTicks;
39 39
40 // Delay to let browser complete a requested action. 40 // Delay to let browser complete a requested action.
41 static const int kWaitForActionMsec = 2000; 41 static const int kWaitForActionMsec = 2000;
42 static const int kWaitForActionMaxMsec = 10000; 42 static const int kWaitForActionMaxMsec = 10000;
43 // Delay to let the browser complete the test. 43 // Delay to let the browser complete the test.
44 static const int kMaxTestExecutionTime = 30000; 44 static const int kMaxTestExecutionTime = 30000;
45 // Delay to let the browser shut down before trying more brutal methods. 45 // Delay to let the browser shut down before trying more brutal methods.
46 static const int kWaitForTerminateMsec = 30000; 46 static const int kWaitForTerminateMsec = 30000;
47 // Timeout after which the test will be aborted.
48 static const int kPerTestTimeoutMsec = 360000;
47 49
48 const wchar_t UITest::kFailedNoCrashService[] = 50 const wchar_t UITest::kFailedNoCrashService[] =
49 #if defined(OS_WIN) 51 #if defined(OS_WIN)
50 L"NOTE: This test is expected to fail if crash_service.exe is not " 52 L"NOTE: This test is expected to fail if crash_service.exe is not "
51 L"running. Start it manually before running this test (see the build " 53 L"running. Start it manually before running this test (see the build "
52 L"output directory)."; 54 L"output directory).";
53 #elif defined(OS_LINUX) 55 #elif defined(OS_LINUX)
54 L"NOTE: This test is expected to fail if breakpad is not built in " 56 L"NOTE: This test is expected to fail if breakpad is not built in "
55 L"or if chromium is not running headless (try CHROME_HEADLESS=1)."; 57 L"or if chromium is not running headless (try CHROME_HEADLESS=1).";
56 #else 58 #else
57 L"NOTE: Crash service not ported to this platform!"; 59 L"NOTE: Crash service not ported to this platform!";
58 #endif 60 #endif
59 bool UITest::in_process_renderer_ = false; 61 bool UITest::in_process_renderer_ = false;
60 bool UITest::no_sandbox_ = false; 62 bool UITest::no_sandbox_ = false;
61 bool UITest::full_memory_dump_ = false; 63 bool UITest::full_memory_dump_ = false;
62 bool UITest::safe_plugins_ = false; 64 bool UITest::safe_plugins_ = false;
63 bool UITest::show_error_dialogs_ = true; 65 bool UITest::show_error_dialogs_ = true;
64 bool UITest::default_use_existing_browser_ = false; 66 bool UITest::default_use_existing_browser_ = false;
65 bool UITest::dump_histograms_on_exit_ = false; 67 bool UITest::dump_histograms_on_exit_ = false;
66 bool UITest::enable_dcheck_ = false; 68 bool UITest::enable_dcheck_ = false;
67 bool UITest::silent_dump_on_dcheck_ = false; 69 bool UITest::silent_dump_on_dcheck_ = false;
68 bool UITest::disable_breakpad_ = false; 70 bool UITest::disable_breakpad_ = false;
69 int UITest::timeout_ms_ = 20 * 60 * 1000; 71 int UITest::timeout_ms_ = 20 * 60 * 1000;
70 std::wstring UITest::js_flags_ = L""; 72 std::wstring UITest::js_flags_ = L"";
71 std::wstring UITest::log_level_ = L""; 73 std::wstring UITest::log_level_ = L"";
72 74
73 // Specify the time (in milliseconds) that the ui_tests should wait before 75 // Specify the time (in milliseconds) that the ui_tests should wait before
74 // timing out. This is used to specify longer timeouts when running under Purify 76 // timing out. This is used to specify longer timeouts when running under Purify
75 // which requires much more time. 77 // which requires much more time.
78 // TODO(phajdan.jr): ui-test-timeout is misleading name, rename it.
76 const wchar_t kUiTestTimeout[] = L"ui-test-timeout"; 79 const wchar_t kUiTestTimeout[] = L"ui-test-timeout";
77 const wchar_t kUiTestActionTimeout[] = L"ui-test-action-timeout"; 80 const wchar_t kUiTestActionTimeout[] = L"ui-test-action-timeout";
78 const wchar_t kUiTestActionMaxTimeout[] = L"ui-test-action-max-timeout"; 81 const wchar_t kUiTestActionMaxTimeout[] = L"ui-test-action-max-timeout";
79 const wchar_t kUiTestSleepTimeout[] = L"ui-test-sleep-timeout"; 82 const wchar_t kUiTestSleepTimeout[] = L"ui-test-sleep-timeout";
80 const wchar_t kUiTestTerminateTimeout[] = L"ui-test-terminate-timeout"; 83 const wchar_t kUiTestTerminateTimeout[] = L"ui-test-terminate-timeout";
84 const wchar_t kUiTestPerTestTimeout[] = L"ui-test-per-test-timeout";
81 85
82 const wchar_t kExtraChromeFlagsSwitch[] = L"extra-chrome-flags"; 86 const wchar_t kExtraChromeFlagsSwitch[] = L"extra-chrome-flags";
83 87
84 // By default error dialogs are hidden, which makes debugging failures in the 88 // By default error dialogs are hidden, which makes debugging failures in the
85 // slave process frustrating. By passing this in error dialogs are enabled. 89 // slave process frustrating. By passing this in error dialogs are enabled.
86 const wchar_t kEnableErrorDialogs[] = L"enable-errdialogs"; 90 const wchar_t kEnableErrorDialogs[] = L"enable-errdialogs";
87 91
88 // Uncomment this line to have the spawned process wait for the debugger to 92 // Uncomment this line to have the spawned process wait for the debugger to
89 // attach. This only works on Windows. On posix systems, you can set the 93 // attach. This only works on Windows. On posix systems, you can set the
90 // BROWSER_WRAPPER env variable to wrap the browser process. 94 // BROWSER_WRAPPER env variable to wrap the browser process.
(...skipping 13 matching lines...) Expand all
104 clear_profile_(true), 108 clear_profile_(true),
105 include_testing_id_(true), 109 include_testing_id_(true),
106 use_existing_browser_(default_use_existing_browser_), 110 use_existing_browser_(default_use_existing_browser_),
107 enable_file_cookies_(true), 111 enable_file_cookies_(true),
108 profile_type_(UITest::DEFAULT_THEME), 112 profile_type_(UITest::DEFAULT_THEME),
109 test_start_time_(base::Time::NowFromSystemTime()), 113 test_start_time_(base::Time::NowFromSystemTime()),
110 command_execution_timeout_ms_(kMaxTestExecutionTime), 114 command_execution_timeout_ms_(kMaxTestExecutionTime),
111 action_timeout_ms_(kWaitForActionMsec), 115 action_timeout_ms_(kWaitForActionMsec),
112 action_max_timeout_ms_(kWaitForActionMaxMsec), 116 action_max_timeout_ms_(kWaitForActionMaxMsec),
113 sleep_timeout_ms_(kWaitForActionMsec), 117 sleep_timeout_ms_(kWaitForActionMsec),
114 terminate_timeout_ms_(kWaitForTerminateMsec) { 118 terminate_timeout_ms_(kWaitForTerminateMsec),
119 per_test_timeout_ms_(kPerTestTimeoutMsec) {
115 PathService::Get(chrome::DIR_APP, &browser_directory_); 120 PathService::Get(chrome::DIR_APP, &browser_directory_);
116 PathService::Get(chrome::DIR_TEST_DATA, &test_data_directory_); 121 PathService::Get(chrome::DIR_TEST_DATA, &test_data_directory_);
117 } 122 }
118 123
119 void UITest::SetUp() { 124 void UITest::SetUp() {
120 if (!use_existing_browser_) { 125 if (!use_existing_browser_) {
121 AssertAppNotRunning(L"Please close any other instances " 126 AssertAppNotRunning(L"Please close any other instances "
122 L"of the app before testing."); 127 L"of the app before testing.");
123 } 128 }
124 129
125 // Pass the test case name to chrome.exe on the command line to help with 130 // Pass the test case name to chrome.exe on the command line to help with
126 // parsing Purify output. 131 // parsing Purify output.
127 const testing::TestInfo* const test_info = 132 const testing::TestInfo* const test_info =
128 testing::UnitTest::GetInstance()->current_test_info(); 133 testing::UnitTest::GetInstance()->current_test_info();
129 if (test_info) { 134 if (test_info) {
130 std::string test_name = test_info->test_case_name(); 135 std::string test_name = test_info->test_case_name();
131 test_name += "."; 136 test_name += ".";
132 test_name += test_info->name(); 137 test_name += test_info->name();
133 ui_test_name_ = ASCIIToWide(test_name); 138 ui_test_name_ = ASCIIToWide(test_name);
134 } 139 }
135 140
136 InitializeTimeouts(); 141 InitializeTimeouts();
137 LaunchBrowserAndServer(); 142 LaunchBrowserAndServer();
143
144 automation()->QuitAfterTimeout(per_test_timeout_ms_);
138 } 145 }
139 146
140 void UITest::TearDown() { 147 void UITest::TearDown() {
141 CloseBrowserAndServer(); 148 CloseBrowserAndServer();
142 149
143 // Make sure that we didn't encounter any assertion failures 150 // Make sure that we didn't encounter any assertion failures
144 logging::AssertionList assertions; 151 logging::AssertionList assertions;
145 logging::GetFatalAssertions(&assertions); 152 logging::GetFatalAssertions(&assertions);
146 153
147 // If there were errors, get all the error strings for display. 154 // If there were errors, get all the error strings for display.
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after
200 sleep_timeout_ms_ = std::max(kWaitForActionMsec, sleep_timeout); 207 sleep_timeout_ms_ = std::max(kWaitForActionMsec, sleep_timeout);
201 } 208 }
202 209
203 if (CommandLine::ForCurrentProcess()->HasSwitch(kUiTestTerminateTimeout)) { 210 if (CommandLine::ForCurrentProcess()->HasSwitch(kUiTestTerminateTimeout)) {
204 std::wstring terminate_timeout_str = 211 std::wstring terminate_timeout_str =
205 CommandLine::ForCurrentProcess()->GetSwitchValue( 212 CommandLine::ForCurrentProcess()->GetSwitchValue(
206 kUiTestTerminateTimeout); 213 kUiTestTerminateTimeout);
207 int terminate_timeout = StringToInt(WideToUTF16Hack(terminate_timeout_str)); 214 int terminate_timeout = StringToInt(WideToUTF16Hack(terminate_timeout_str));
208 terminate_timeout_ms_ = std::max(kWaitForActionMsec, terminate_timeout); 215 terminate_timeout_ms_ = std::max(kWaitForActionMsec, terminate_timeout);
209 } 216 }
217
218 if (CommandLine::ForCurrentProcess()->HasSwitch(kUiTestPerTestTimeout)) {
219 std::wstring per_test_timeout_str =
220 CommandLine::ForCurrentProcess()->GetSwitchValue(
221 kUiTestPerTestTimeout);
222 int per_test_timeout = StringToInt(WideToUTF16Hack(per_test_timeout_str));
223 per_test_timeout_ms_ = std::max(kPerTestTimeoutMsec, per_test_timeout);
224 }
210 } 225 }
211 226
212 AutomationProxy* UITest::CreateAutomationProxy(int execution_timeout) { 227 AutomationProxy* UITest::CreateAutomationProxy(int execution_timeout) {
213 // By default we create a plain vanilla AutomationProxy. 228 // By default we create a plain vanilla AutomationProxy.
214 return new AutomationProxy(execution_timeout); 229 return new AutomationProxy(execution_timeout);
215 } 230 }
216 231
217 void UITest::LaunchBrowserAndServer() { 232 void UITest::LaunchBrowserAndServer() {
218 // Set up IPC testing interface server. 233 // Set up IPC testing interface server.
219 server_.reset(CreateAutomationProxy(command_execution_timeout_ms_)); 234 server_.reset(CreateAutomationProxy(command_execution_timeout_ms_));
(...skipping 903 matching lines...) Expand 10 before | Expand all | Expand 10 after
1123 #else 1138 #else
1124 // TODO(port): above code is very Windows-specific; we need to 1139 // TODO(port): above code is very Windows-specific; we need to
1125 // figure out and abstract out how we'll handle finding any existing 1140 // figure out and abstract out how we'll handle finding any existing
1126 // running process, etc. on other platforms. 1141 // running process, etc. on other platforms.
1127 NOTIMPLEMENTED(); 1142 NOTIMPLEMENTED();
1128 #endif 1143 #endif
1129 } 1144 }
1130 1145
1131 return true; 1146 return true;
1132 } 1147 }
OLDNEW
« no previous file with comments | « chrome/test/ui/ui_test.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698