OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 <queue> | 5 #include <queue> |
6 | 6 |
7 #include "ash/shell.h" | 7 #include "ash/shell.h" |
8 #include "ash/system/tray/system_tray.h" | 8 #include "ash/system/tray/system_tray.h" |
9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
10 #include "base/strings/string_util.h" | 10 #include "base/strings/string_util.h" |
11 #include "chrome/app/chrome_command_ids.h" | 11 #include "chrome/app/chrome_command_ids.h" |
12 #include "chrome/browser/chromeos/accessibility/accessibility_manager.h" | 12 #include "chrome/browser/chromeos/accessibility/accessibility_manager.h" |
13 #include "chrome/browser/chromeos/accessibility/speech_monitor.h" | 13 #include "chrome/browser/chromeos/accessibility/speech_monitor.h" |
14 #include "chrome/browser/chromeos/login/ui/login_display_host.h" | 14 #include "chrome/browser/chromeos/login/ui/login_display_host.h" |
15 #include "chrome/browser/chromeos/login/ui/login_display_host_impl.h" | 15 #include "chrome/browser/chromeos/login/ui/login_display_host_impl.h" |
16 #include "chrome/browser/chromeos/login/ui/webui_login_view.h" | 16 #include "chrome/browser/chromeos/login/ui/webui_login_view.h" |
17 #include "chrome/browser/chromeos/profiles/profile_helper.h" | 17 #include "chrome/browser/chromeos/profiles/profile_helper.h" |
18 #include "chrome/browser/extensions/api/braille_display_private/stub_braille_con troller.h" | 18 #include "chrome/browser/extensions/api/braille_display_private/stub_braille_con troller.h" |
19 #include "chrome/browser/speech/tts_controller.h" | 19 #include "chrome/browser/speech/tts_controller.h" |
20 #include "chrome/browser/speech/tts_platform.h" | 20 #include "chrome/browser/speech/tts_platform.h" |
21 #include "chrome/browser/ui/browser.h" | 21 #include "chrome/browser/ui/browser.h" |
22 #include "chrome/browser/ui/browser_commands.h" | 22 #include "chrome/browser/ui/browser_commands.h" |
23 #include "chrome/browser/ui/browser_window.h" | 23 #include "chrome/browser/ui/browser_window.h" |
24 #include "chrome/browser/ui/tabs/tab_strip_model.h" | |
24 #include "chrome/common/chrome_switches.h" | 25 #include "chrome/common/chrome_switches.h" |
25 #include "chrome/common/extensions/extension_constants.h" | 26 #include "chrome/common/extensions/extension_constants.h" |
26 #include "chrome/test/base/in_process_browser_test.h" | 27 #include "chrome/test/base/in_process_browser_test.h" |
27 #include "chrome/test/base/interactive_test_utils.h" | 28 #include "chrome/test/base/interactive_test_utils.h" |
28 #include "chrome/test/base/testing_profile.h" | 29 #include "chrome/test/base/testing_profile.h" |
29 #include "chrome/test/base/ui_test_utils.h" | 30 #include "chrome/test/base/ui_test_utils.h" |
30 #include "chromeos/chromeos_switches.h" | 31 #include "chromeos/chromeos_switches.h" |
31 #include "chromeos/login/user_names.h" | 32 #include "chromeos/login/user_names.h" |
32 #include "content/public/common/url_constants.h" | 33 #include "content/public/common/url_constants.h" |
33 #include "content/public/test/browser_test_utils.h" | 34 #include "content/public/test/browser_test_utils.h" |
(...skipping 19 matching lines...) Expand all Loading... | |
53 | 54 |
54 virtual void SetUpInProcessBrowserTestFixture() OVERRIDE { | 55 virtual void SetUpInProcessBrowserTestFixture() OVERRIDE { |
55 AccessibilityManager::SetBrailleControllerForTest(&braille_controller_); | 56 AccessibilityManager::SetBrailleControllerForTest(&braille_controller_); |
56 } | 57 } |
57 | 58 |
58 virtual void TearDownOnMainThread() OVERRIDE { | 59 virtual void TearDownOnMainThread() OVERRIDE { |
59 AccessibilityManager::SetBrailleControllerForTest(NULL); | 60 AccessibilityManager::SetBrailleControllerForTest(NULL); |
60 } | 61 } |
61 | 62 |
62 void SendKeyPress(ui::KeyboardCode key) { | 63 void SendKeyPress(ui::KeyboardCode key) { |
63 gfx::NativeWindow root_window = | 64 ASSERT_NO_FATAL_FAILURE( |
64 ash::Shell::GetInstance()->GetPrimaryRootWindow(); | 65 ASSERT_TRUE( |
65 ASSERT_TRUE( | 66 ui_test_utils::SendKeyPressToWindowSync( |
66 ui_test_utils::SendKeyPressToWindowSync( | 67 NULL, key, false, false, false, false))); |
67 root_window, key, false, false, false, false)); | 68 } |
69 | |
70 void SendKeyPressWithControl(ui::KeyboardCode key) { | |
71 ASSERT_NO_FATAL_FAILURE( | |
72 ASSERT_TRUE( | |
73 ui_test_utils::SendKeyPressToWindowSync( | |
74 NULL, key, true, false, false, false))); | |
75 } | |
76 | |
77 void SendKeyPressWithSearchAndShift(ui::KeyboardCode key) { | |
78 ASSERT_NO_FATAL_FAILURE( | |
79 ASSERT_TRUE( | |
80 ui_test_utils::SendKeyPressToWindowSync( | |
81 NULL, key, false, true, false, true))); | |
68 } | 82 } |
69 | 83 |
70 void RunJavaScriptInChromeVoxBackgroundPage(const std::string& script) { | 84 void RunJavaScriptInChromeVoxBackgroundPage(const std::string& script) { |
71 extensions::ExtensionHost* host = | 85 extensions::ExtensionHost* host = |
72 extensions::ExtensionSystem::Get(browser()->profile())-> | 86 extensions::ExtensionSystem::Get(browser()->profile())-> |
73 process_manager()->GetBackgroundHostForExtension( | 87 process_manager()->GetBackgroundHostForExtension( |
74 extension_misc::kChromeVoxExtensionId); | 88 extension_misc::kChromeVoxExtensionId); |
75 CHECK(content::ExecuteScript(host->host_contents(), script)); | 89 CHECK(content::ExecuteScript(host->host_contents(), script)); |
76 } | 90 } |
77 | 91 |
78 void SimulateTouchScreenInChromeVox() { | 92 void SimulateTouchScreenInChromeVox() { |
79 // ChromeVox looks at whether 'ontouchstart' exists to know whether | 93 // ChromeVox looks at whether 'ontouchstart' exists to know whether |
80 // or not it should respond to hover events. Fake it so that touch | 94 // or not it should respond to hover events. Fake it so that touch |
81 // exploration events get spoken. | 95 // exploration events get spoken. |
82 RunJavaScriptInChromeVoxBackgroundPage( | 96 RunJavaScriptInChromeVoxBackgroundPage( |
83 "window.ontouchstart = function() {};"); | 97 "window.ontouchstart = function() {};"); |
84 } | 98 } |
85 | 99 |
86 void DisableEarcons() { | 100 void DisableEarcons() { |
87 // Playing earcons from within a test is not only annoying if you're | 101 // Playing earcons from within a test is not only annoying if you're |
88 // running the test locally, but seems to cause crashes | 102 // running the test locally, but seems to cause crashes |
89 // (http://crbug.com/396507). Work around this by just telling | 103 // (http://crbug.com/396507). Work around this by just telling |
90 // ChromeVox to not ever play earcons (prerecorded sound effects). | 104 // ChromeVox to not ever play earcons (prerecorded sound effects). |
91 RunJavaScriptInChromeVoxBackgroundPage( | 105 RunJavaScriptInChromeVoxBackgroundPage( |
92 "cvox.ChromeVox.earcons.playEarcon = function() {};"); | 106 "cvox.ChromeVox.earcons.playEarcon = function() {};"); |
93 } | 107 } |
94 | 108 |
109 void LoadChromeVoxAndThenNavigateToURL(const GURL& url) { | |
110 // The goal of this helper function is to avoid race conditions between | |
111 // the page loading and the ChromeVox extension loading and fully | |
David Tseng
2014/09/22 21:52:21
Mention something about the content script being f
| |
112 // initializing. To do this, we first load a test url that repeatedly | |
113 // asks ChromeVox to speak 'ready', then we load ChromeVox and block | |
114 // until we get that 'ready' speech. | |
115 | |
116 ui_test_utils::NavigateToURL( | |
117 browser(), | |
118 GURL("data:text/html;charset=utf-8," | |
119 "<script>" | |
120 "window.setInterval(function() {" | |
121 " try {" | |
122 " cvox.Api.speak('ready');" | |
123 " } catch (e) {}" | |
124 "}, 100);" | |
125 "</script>")); | |
126 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); | |
127 AccessibilityManager::Get()->EnableSpokenFeedback( | |
128 true, ash::A11Y_NOTIFICATION_NONE); | |
129 | |
130 // Block until we get "ready". | |
131 while (speech_monitor_.GetNextUtterance() != "ready") { | |
David Tseng
2014/09/22 21:52:21
Should we sleep here inside the loop to avoid pote
| |
132 } | |
133 | |
134 // Now load the requested url. | |
135 ui_test_utils::NavigateToURL(browser(), url); | |
136 } | |
137 | |
138 SpeechMonitor speech_monitor_; | |
139 | |
95 private: | 140 private: |
96 StubBrailleController braille_controller_; | 141 StubBrailleController braille_controller_; |
97 DISALLOW_COPY_AND_ASSIGN(LoggedInSpokenFeedbackTest); | 142 DISALLOW_COPY_AND_ASSIGN(LoggedInSpokenFeedbackTest); |
98 }; | 143 }; |
99 | 144 |
100 IN_PROC_BROWSER_TEST_F(LoggedInSpokenFeedbackTest, AddBookmark) { | 145 IN_PROC_BROWSER_TEST_F(LoggedInSpokenFeedbackTest, AddBookmark) { |
101 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); | 146 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); |
102 | 147 |
103 SpeechMonitor monitor; | |
104 AccessibilityManager::Get()->EnableSpokenFeedback( | 148 AccessibilityManager::Get()->EnableSpokenFeedback( |
105 true, ash::A11Y_NOTIFICATION_NONE); | 149 true, ash::A11Y_NOTIFICATION_NONE); |
106 EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); | 150 EXPECT_TRUE(speech_monitor_.SkipChromeVoxEnabledMessage()); |
107 DisableEarcons(); | 151 DisableEarcons(); |
108 | 152 |
109 chrome::ExecuteCommand(browser(), IDC_SHOW_BOOKMARK_BAR); | 153 chrome::ExecuteCommand(browser(), IDC_SHOW_BOOKMARK_BAR); |
110 | 154 |
111 // Create a bookmark with title "foo". | 155 // Create a bookmark with title "foo". |
112 chrome::ExecuteCommand(browser(), IDC_BOOKMARK_PAGE); | 156 chrome::ExecuteCommand(browser(), IDC_BOOKMARK_PAGE); |
113 EXPECT_EQ("Bookmark added!,", monitor.GetNextUtterance()); | 157 EXPECT_EQ("Bookmark added!,", speech_monitor_.GetNextUtterance()); |
114 EXPECT_EQ("about blank,", monitor.GetNextUtterance()); | 158 EXPECT_EQ("about blank,", speech_monitor_.GetNextUtterance()); |
115 EXPECT_EQ("Bookmark name,", monitor.GetNextUtterance()); | 159 EXPECT_EQ("Bookmark name,", speech_monitor_.GetNextUtterance()); |
116 EXPECT_EQ("text box", monitor.GetNextUtterance()); | 160 EXPECT_EQ("text box", speech_monitor_.GetNextUtterance()); |
117 | 161 |
118 SendKeyPress(ui::VKEY_F); | 162 SendKeyPress(ui::VKEY_F); |
119 EXPECT_EQ("f", monitor.GetNextUtterance()); | 163 EXPECT_EQ("f", speech_monitor_.GetNextUtterance()); |
120 SendKeyPress(ui::VKEY_O); | 164 SendKeyPress(ui::VKEY_O); |
121 EXPECT_EQ("o", monitor.GetNextUtterance()); | 165 EXPECT_EQ("o", speech_monitor_.GetNextUtterance()); |
122 SendKeyPress(ui::VKEY_O); | 166 SendKeyPress(ui::VKEY_O); |
123 EXPECT_EQ("o", monitor.GetNextUtterance()); | 167 EXPECT_EQ("o", speech_monitor_.GetNextUtterance()); |
124 | 168 |
125 SendKeyPress(ui::VKEY_TAB); | 169 SendKeyPress(ui::VKEY_TAB); |
126 EXPECT_EQ("Bookmarks bar,", monitor.GetNextUtterance()); | 170 EXPECT_EQ("Bookmarks bar,", speech_monitor_.GetNextUtterance()); |
127 EXPECT_EQ("Bookmark folder,", monitor.GetNextUtterance()); | 171 EXPECT_EQ("Bookmark folder,", speech_monitor_.GetNextUtterance()); |
128 EXPECT_TRUE(MatchPattern(monitor.GetNextUtterance(), "combo box*")); | 172 EXPECT_TRUE(MatchPattern(speech_monitor_.GetNextUtterance(), "combo box*")); |
129 | 173 |
130 SendKeyPress(ui::VKEY_RETURN); | 174 SendKeyPress(ui::VKEY_RETURN); |
131 | 175 |
132 EXPECT_TRUE(MatchPattern(monitor.GetNextUtterance(), "*oolbar*")); | 176 EXPECT_TRUE(MatchPattern(speech_monitor_.GetNextUtterance(), "*oolbar*")); |
133 // Wait for active window change to be announced to avoid interference from | 177 // Wait for active window change to be announced to avoid interference from |
134 // that below. | 178 // that below. |
135 while (monitor.GetNextUtterance() != "window about blank tab") { | 179 while (speech_monitor_.GetNextUtterance() != "window about blank tab") { |
136 // Do nothing. | 180 // Do nothing. |
137 } | 181 } |
138 | 182 |
139 // Focus bookmarks bar and listen for "foo". | 183 // Focus bookmarks bar and listen for "foo". |
140 chrome::ExecuteCommand(browser(), IDC_FOCUS_BOOKMARKS); | 184 chrome::ExecuteCommand(browser(), IDC_FOCUS_BOOKMARKS); |
141 while (true) { | 185 while (true) { |
142 std::string utterance = monitor.GetNextUtterance(); | 186 std::string utterance = speech_monitor_.GetNextUtterance(); |
143 VLOG(0) << "Got utterance: " << utterance; | 187 VLOG(0) << "Got utterance: " << utterance; |
144 if (utterance == "Bookmarks,") | 188 if (utterance == "Bookmarks,") |
145 break; | 189 break; |
146 } | 190 } |
147 EXPECT_EQ("foo,", monitor.GetNextUtterance()); | 191 EXPECT_EQ("foo,", speech_monitor_.GetNextUtterance()); |
148 EXPECT_EQ("button", monitor.GetNextUtterance()); | 192 EXPECT_EQ("button", speech_monitor_.GetNextUtterance()); |
149 } | 193 } |
150 | 194 |
151 // | 195 // |
152 // Spoken feedback tests in both a logged in browser window and guest mode. | 196 // Spoken feedback tests in both a logged in browser window and guest mode. |
153 // | 197 // |
154 | 198 |
155 enum SpokenFeedbackTestVariant { | 199 enum SpokenFeedbackTestVariant { |
156 kTestAsNormalUser, | 200 kTestAsNormalUser, |
157 kTestAsGuestUser | 201 kTestAsGuestUser |
158 }; | 202 }; |
(...skipping 19 matching lines...) Expand all Loading... | |
178 | 222 |
179 INSTANTIATE_TEST_CASE_P( | 223 INSTANTIATE_TEST_CASE_P( |
180 TestAsNormalAndGuestUser, | 224 TestAsNormalAndGuestUser, |
181 SpokenFeedbackTest, | 225 SpokenFeedbackTest, |
182 ::testing::Values(kTestAsNormalUser, | 226 ::testing::Values(kTestAsNormalUser, |
183 kTestAsGuestUser)); | 227 kTestAsGuestUser)); |
184 | 228 |
185 IN_PROC_BROWSER_TEST_P(SpokenFeedbackTest, EnableSpokenFeedback) { | 229 IN_PROC_BROWSER_TEST_P(SpokenFeedbackTest, EnableSpokenFeedback) { |
186 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); | 230 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); |
187 | 231 |
188 SpeechMonitor monitor; | |
189 AccessibilityManager::Get()->EnableSpokenFeedback( | 232 AccessibilityManager::Get()->EnableSpokenFeedback( |
190 true, ash::A11Y_NOTIFICATION_NONE); | 233 true, ash::A11Y_NOTIFICATION_NONE); |
191 EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); | 234 EXPECT_TRUE(speech_monitor_.SkipChromeVoxEnabledMessage()); |
192 } | 235 } |
193 | 236 |
194 IN_PROC_BROWSER_TEST_P(SpokenFeedbackTest, FocusToolbar) { | 237 IN_PROC_BROWSER_TEST_P(SpokenFeedbackTest, FocusToolbar) { |
195 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); | 238 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); |
196 | 239 |
197 SpeechMonitor monitor; | |
198 AccessibilityManager::Get()->EnableSpokenFeedback( | 240 AccessibilityManager::Get()->EnableSpokenFeedback( |
199 true, ash::A11Y_NOTIFICATION_NONE); | 241 true, ash::A11Y_NOTIFICATION_NONE); |
200 EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); | 242 EXPECT_TRUE(speech_monitor_.SkipChromeVoxEnabledMessage()); |
201 DisableEarcons(); | 243 DisableEarcons(); |
202 | 244 |
203 chrome::ExecuteCommand(browser(), IDC_FOCUS_TOOLBAR); | 245 chrome::ExecuteCommand(browser(), IDC_FOCUS_TOOLBAR); |
204 // Might be "Google Chrome Toolbar" or "Chromium Toolbar". | 246 // Might be "Google Chrome Toolbar" or "Chromium Toolbar". |
205 EXPECT_TRUE(MatchPattern(monitor.GetNextUtterance(), "*oolbar*")); | 247 EXPECT_TRUE(MatchPattern(speech_monitor_.GetNextUtterance(), "*oolbar*")); |
206 EXPECT_EQ("Reload,", monitor.GetNextUtterance()); | 248 EXPECT_EQ("Reload,", speech_monitor_.GetNextUtterance()); |
207 EXPECT_EQ("button", monitor.GetNextUtterance()); | 249 EXPECT_EQ("button", speech_monitor_.GetNextUtterance()); |
208 } | 250 } |
209 | 251 |
210 IN_PROC_BROWSER_TEST_P(SpokenFeedbackTest, TypeInOmnibox) { | 252 IN_PROC_BROWSER_TEST_P(SpokenFeedbackTest, TypeInOmnibox) { |
211 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); | 253 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); |
212 | 254 |
213 SpeechMonitor monitor; | |
214 AccessibilityManager::Get()->EnableSpokenFeedback( | 255 AccessibilityManager::Get()->EnableSpokenFeedback( |
215 true, ash::A11Y_NOTIFICATION_NONE); | 256 true, ash::A11Y_NOTIFICATION_NONE); |
216 EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); | 257 EXPECT_TRUE(speech_monitor_.SkipChromeVoxEnabledMessage()); |
217 DisableEarcons(); | 258 DisableEarcons(); |
218 | 259 |
219 // Wait for ChromeVox to finish speaking. | 260 // Wait for ChromeVox to finish speaking. |
220 chrome::ExecuteCommand(browser(), IDC_FOCUS_LOCATION); | 261 chrome::ExecuteCommand(browser(), IDC_FOCUS_LOCATION); |
221 while (true) { | 262 while (true) { |
222 std::string utterance = monitor.GetNextUtterance(); | 263 std::string utterance = speech_monitor_.GetNextUtterance(); |
223 VLOG(0) << "Got utterance: " << utterance; | 264 VLOG(0) << "Got utterance: " << utterance; |
224 if (utterance == "text box") | 265 if (utterance == "text box") |
225 break; | 266 break; |
226 } | 267 } |
227 | 268 |
228 SendKeyPress(ui::VKEY_X); | 269 SendKeyPress(ui::VKEY_X); |
229 EXPECT_EQ("x", monitor.GetNextUtterance()); | 270 EXPECT_EQ("x", speech_monitor_.GetNextUtterance()); |
230 | 271 |
231 SendKeyPress(ui::VKEY_Y); | 272 SendKeyPress(ui::VKEY_Y); |
232 EXPECT_EQ("y", monitor.GetNextUtterance()); | 273 EXPECT_EQ("y", speech_monitor_.GetNextUtterance()); |
233 | 274 |
234 SendKeyPress(ui::VKEY_Z); | 275 SendKeyPress(ui::VKEY_Z); |
235 EXPECT_EQ("z", monitor.GetNextUtterance()); | 276 EXPECT_EQ("z", speech_monitor_.GetNextUtterance()); |
236 | 277 |
237 SendKeyPress(ui::VKEY_BACK); | 278 SendKeyPress(ui::VKEY_BACK); |
238 EXPECT_EQ("z", monitor.GetNextUtterance()); | 279 EXPECT_EQ("z", speech_monitor_.GetNextUtterance()); |
280 } | |
281 | |
282 IN_PROC_BROWSER_TEST_P(SpokenFeedbackTest, ChromeVoxShiftSearch) { | |
283 LoadChromeVoxAndThenNavigateToURL( | |
284 GURL("data:text/html;charset=utf-8,<button autofocus>Click me</button>")); | |
285 while (true) { | |
286 std::string utterance = speech_monitor_.GetNextUtterance(); | |
287 if (utterance == "Click me") | |
David Tseng
2014/09/22 21:52:21
Would be helpful to state why we're expecting this
| |
288 break; | |
289 } | |
David Tseng
2014/09/22 21:52:21
Ditto.
| |
290 EXPECT_EQ("Button", speech_monitor_.GetNextUtterance()); | |
291 | |
292 // Press Search+Shift+/ to enter ChromeVox's "find in page". | |
293 SendKeyPressWithSearchAndShift(ui::VKEY_OEM_2); | |
294 EXPECT_EQ("Find in page.", speech_monitor_.GetNextUtterance()); | |
295 EXPECT_EQ("Enter a search query.", speech_monitor_.GetNextUtterance()); | |
296 } | |
297 | |
298 IN_PROC_BROWSER_TEST_P(SpokenFeedbackTest, ChromeVoxPrefixKey) { | |
299 LoadChromeVoxAndThenNavigateToURL( | |
300 GURL("data:text/html;charset=utf-8,<button autofocus>Click me</button>")); | |
301 while (true) { | |
302 std::string utterance = speech_monitor_.GetNextUtterance(); | |
303 if (utterance == "Click me") | |
304 break; | |
305 } | |
306 EXPECT_EQ("Button", speech_monitor_.GetNextUtterance()); | |
307 | |
308 // Press the prefix key Ctrl+';' followed by '/' | |
309 // to enter ChromeVox's "find in page". | |
310 SendKeyPressWithControl(ui::VKEY_OEM_1); | |
311 SendKeyPress(ui::VKEY_OEM_2); | |
312 EXPECT_EQ("Find in page.", speech_monitor_.GetNextUtterance()); | |
313 EXPECT_EQ("Enter a search query.", speech_monitor_.GetNextUtterance()); | |
239 } | 314 } |
240 | 315 |
241 IN_PROC_BROWSER_TEST_P(SpokenFeedbackTest, TouchExploreStatusTray) { | 316 IN_PROC_BROWSER_TEST_P(SpokenFeedbackTest, TouchExploreStatusTray) { |
242 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); | 317 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); |
243 | 318 |
244 SpeechMonitor monitor; | |
245 AccessibilityManager::Get()->EnableSpokenFeedback( | 319 AccessibilityManager::Get()->EnableSpokenFeedback( |
246 true, ash::A11Y_NOTIFICATION_NONE); | 320 true, ash::A11Y_NOTIFICATION_NONE); |
247 EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); | 321 EXPECT_TRUE(speech_monitor_.SkipChromeVoxEnabledMessage()); |
248 DisableEarcons(); | 322 DisableEarcons(); |
249 | 323 |
250 SimulateTouchScreenInChromeVox(); | 324 SimulateTouchScreenInChromeVox(); |
251 | 325 |
252 // Send an accessibility hover event on the system tray, which is | 326 // Send an accessibility hover event on the system tray, which is |
253 // what we get when you tap it on a touch screen when ChromeVox is on. | 327 // what we get when you tap it on a touch screen when ChromeVox is on. |
254 ash::SystemTray* tray = ash::Shell::GetInstance()->GetPrimarySystemTray(); | 328 ash::SystemTray* tray = ash::Shell::GetInstance()->GetPrimarySystemTray(); |
255 tray->NotifyAccessibilityEvent(ui::AX_EVENT_HOVER, true); | 329 tray->NotifyAccessibilityEvent(ui::AX_EVENT_HOVER, true); |
256 | 330 |
257 EXPECT_EQ("Status tray,", monitor.GetNextUtterance()); | 331 EXPECT_EQ("Status tray,", speech_monitor_.GetNextUtterance()); |
258 EXPECT_TRUE(MatchPattern(monitor.GetNextUtterance(), "time*,")); | 332 EXPECT_TRUE(MatchPattern(speech_monitor_.GetNextUtterance(), "time*,")); |
259 EXPECT_TRUE(MatchPattern(monitor.GetNextUtterance(), "Battery*,")); | 333 EXPECT_TRUE(MatchPattern(speech_monitor_.GetNextUtterance(), "Battery*,")); |
260 EXPECT_EQ("button", monitor.GetNextUtterance()); | 334 EXPECT_EQ("button", speech_monitor_.GetNextUtterance()); |
261 } | 335 } |
262 | 336 |
263 // | 337 // |
264 // Spoken feedback tests that run only in guest mode. | 338 // Spoken feedback tests that run only in guest mode. |
265 // | 339 // |
266 | 340 |
267 class GuestSpokenFeedbackTest : public LoggedInSpokenFeedbackTest { | 341 class GuestSpokenFeedbackTest : public LoggedInSpokenFeedbackTest { |
268 protected: | 342 protected: |
269 GuestSpokenFeedbackTest() {} | 343 GuestSpokenFeedbackTest() {} |
270 virtual ~GuestSpokenFeedbackTest() {} | 344 virtual ~GuestSpokenFeedbackTest() {} |
271 | 345 |
272 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { | 346 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { |
273 command_line->AppendSwitch(chromeos::switches::kGuestSession); | 347 command_line->AppendSwitch(chromeos::switches::kGuestSession); |
274 command_line->AppendSwitch(::switches::kIncognito); | 348 command_line->AppendSwitch(::switches::kIncognito); |
275 command_line->AppendSwitchASCII(chromeos::switches::kLoginProfile, "user"); | 349 command_line->AppendSwitchASCII(chromeos::switches::kLoginProfile, "user"); |
276 command_line->AppendSwitchASCII(chromeos::switches::kLoginUser, | 350 command_line->AppendSwitchASCII(chromeos::switches::kLoginUser, |
277 chromeos::login::kGuestUserName); | 351 chromeos::login::kGuestUserName); |
278 } | 352 } |
279 | 353 |
280 private: | 354 private: |
281 DISALLOW_COPY_AND_ASSIGN(GuestSpokenFeedbackTest); | 355 DISALLOW_COPY_AND_ASSIGN(GuestSpokenFeedbackTest); |
282 }; | 356 }; |
283 | 357 |
284 IN_PROC_BROWSER_TEST_F(GuestSpokenFeedbackTest, FocusToolbar) { | 358 IN_PROC_BROWSER_TEST_F(GuestSpokenFeedbackTest, FocusToolbar) { |
285 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); | 359 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); |
286 | 360 |
287 SpeechMonitor monitor; | |
288 AccessibilityManager::Get()->EnableSpokenFeedback( | 361 AccessibilityManager::Get()->EnableSpokenFeedback( |
289 true, ash::A11Y_NOTIFICATION_NONE); | 362 true, ash::A11Y_NOTIFICATION_NONE); |
290 EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); | 363 EXPECT_TRUE(speech_monitor_.SkipChromeVoxEnabledMessage()); |
291 DisableEarcons(); | 364 DisableEarcons(); |
292 | 365 |
293 chrome::ExecuteCommand(browser(), IDC_FOCUS_TOOLBAR); | 366 chrome::ExecuteCommand(browser(), IDC_FOCUS_TOOLBAR); |
294 // Might be "Google Chrome Toolbar" or "Chromium Toolbar". | 367 // Might be "Google Chrome Toolbar" or "Chromium Toolbar". |
295 EXPECT_TRUE(MatchPattern(monitor.GetNextUtterance(), "*oolbar*")); | 368 EXPECT_TRUE(MatchPattern(speech_monitor_.GetNextUtterance(), "*oolbar*")); |
296 EXPECT_EQ("Reload,", monitor.GetNextUtterance()); | 369 EXPECT_EQ("Reload,", speech_monitor_.GetNextUtterance()); |
297 EXPECT_EQ("button", monitor.GetNextUtterance()); | 370 EXPECT_EQ("button", speech_monitor_.GetNextUtterance()); |
298 } | 371 } |
299 | 372 |
300 // | 373 // |
301 // Spoken feedback tests of the out-of-box experience. | 374 // Spoken feedback tests of the out-of-box experience. |
302 // | 375 // |
303 | 376 |
304 class OobeSpokenFeedbackTest : public InProcessBrowserTest { | 377 class OobeSpokenFeedbackTest : public InProcessBrowserTest { |
305 protected: | 378 protected: |
306 OobeSpokenFeedbackTest() {} | 379 OobeSpokenFeedbackTest() {} |
307 virtual ~OobeSpokenFeedbackTest() {} | 380 virtual ~OobeSpokenFeedbackTest() {} |
308 | 381 |
309 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { | 382 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { |
310 command_line->AppendSwitch(chromeos::switches::kLoginManager); | 383 command_line->AppendSwitch(chromeos::switches::kLoginManager); |
311 command_line->AppendSwitch(chromeos::switches::kForceLoginManagerInTests); | 384 command_line->AppendSwitch(chromeos::switches::kForceLoginManagerInTests); |
312 command_line->AppendSwitchASCII(chromeos::switches::kLoginProfile, "user"); | 385 command_line->AppendSwitchASCII(chromeos::switches::kLoginProfile, "user"); |
313 } | 386 } |
314 | 387 |
315 virtual void SetUpOnMainThread() OVERRIDE { | 388 virtual void SetUpOnMainThread() OVERRIDE { |
316 AccessibilityManager::Get()-> | 389 AccessibilityManager::Get()-> |
317 SetProfileForTest(ProfileHelper::GetSigninProfile()); | 390 SetProfileForTest(ProfileHelper::GetSigninProfile()); |
318 } | 391 } |
319 | 392 |
393 SpeechMonitor speech_monitor_; | |
394 | |
320 private: | 395 private: |
321 DISALLOW_COPY_AND_ASSIGN(OobeSpokenFeedbackTest); | 396 DISALLOW_COPY_AND_ASSIGN(OobeSpokenFeedbackTest); |
322 }; | 397 }; |
323 | 398 |
324 // Test is flaky: http://crbug.com/346797 | 399 // Test is flaky: http://crbug.com/346797 |
325 IN_PROC_BROWSER_TEST_F(OobeSpokenFeedbackTest, DISABLED_SpokenFeedbackInOobe) { | 400 IN_PROC_BROWSER_TEST_F(OobeSpokenFeedbackTest, DISABLED_SpokenFeedbackInOobe) { |
326 ui_controls::EnableUIControls(); | 401 ui_controls::EnableUIControls(); |
327 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); | 402 EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); |
328 | 403 |
329 LoginDisplayHost* login_display_host = LoginDisplayHostImpl::default_host(); | 404 LoginDisplayHost* login_display_host = LoginDisplayHostImpl::default_host(); |
330 WebUILoginView* web_ui_login_view = login_display_host->GetWebUILoginView(); | 405 WebUILoginView* web_ui_login_view = login_display_host->GetWebUILoginView(); |
331 views::Widget* widget = web_ui_login_view->GetWidget(); | 406 views::Widget* widget = web_ui_login_view->GetWidget(); |
332 gfx::NativeWindow window = widget->GetNativeWindow(); | 407 gfx::NativeWindow window = widget->GetNativeWindow(); |
333 | 408 |
334 SpeechMonitor monitor; | |
335 AccessibilityManager::Get()->EnableSpokenFeedback( | 409 AccessibilityManager::Get()->EnableSpokenFeedback( |
336 true, ash::A11Y_NOTIFICATION_NONE); | 410 true, ash::A11Y_NOTIFICATION_NONE); |
337 EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); | 411 EXPECT_TRUE(speech_monitor_.SkipChromeVoxEnabledMessage()); |
338 | 412 |
339 EXPECT_EQ("Select your language:", monitor.GetNextUtterance()); | 413 EXPECT_EQ("Select your language:", speech_monitor_.GetNextUtterance()); |
340 EXPECT_EQ("English ( United States)", monitor.GetNextUtterance()); | 414 EXPECT_EQ("English ( United States)", speech_monitor_.GetNextUtterance()); |
341 EXPECT_TRUE(MatchPattern(monitor.GetNextUtterance(), "Combo box * of *")); | 415 EXPECT_TRUE(MatchPattern(speech_monitor_.GetNextUtterance(), |
416 "Combo box * of *")); | |
342 ASSERT_TRUE( | 417 ASSERT_TRUE( |
343 ui_test_utils::SendKeyPressToWindowSync( | 418 ui_test_utils::SendKeyPressToWindowSync( |
344 window, ui::VKEY_TAB, false, false, false, false)); | 419 window, ui::VKEY_TAB, false, false, false, false)); |
345 EXPECT_EQ("Select your keyboard:", monitor.GetNextUtterance()); | 420 EXPECT_EQ("Select your keyboard:", speech_monitor_.GetNextUtterance()); |
346 } | 421 } |
347 | 422 |
348 } // namespace chromeos | 423 } // namespace chromeos |
OLD | NEW |