Chromium Code Reviews| Index: chrome/browser/ui/views/accessibility/spoken_feedback_chromeos_browsertest.cc |
| diff --git a/chrome/browser/ui/views/accessibility/spoken_feedback_chromeos_browsertest.cc b/chrome/browser/ui/views/accessibility/spoken_feedback_chromeos_browsertest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..297f762ab951e735c275d0799f1ef23269ad8b7b |
| --- /dev/null |
| +++ b/chrome/browser/ui/views/accessibility/spoken_feedback_chromeos_browsertest.cc |
| @@ -0,0 +1,63 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
|
James Cook
2014/08/08 17:06:32
I steered you wrong. This should be spoken_feedbac
evy
2014/08/08 18:37:47
Done.
|
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "base/strings/string_util.h" |
| +#include "chrome/browser/chromeos/accessibility/accessibility_manager.h" |
| +#include "chrome/browser/chromeos/accessibility/accessibility_util.h" |
| +#include "chrome/browser/chromeos/accessibility/speech_monitor.h" |
| +#include "chrome/browser/ui/views/bookmarks/bookmark_bar_view.h" |
| +#include "chrome/browser/ui/views/frame/browser_view.h" |
| +#include "chrome/browser/ui/views/tabs/tab_strip.h" |
| +#include "chrome/test/base/in_process_browser_test.h" |
| + |
| +typedef InProcessBrowserTest SpokenFeedbackViewsTest; |
|
James Cook
2014/08/08 17:06:32
Add a brief comment about why this lives in c/b/ui
evy
2014/08/08 18:37:47
Done.
|
| + |
| +namespace chromeos { |
| + |
| +IN_PROC_BROWSER_TEST_F(SpokenFeedbackViewsTest, |
|
James Cook
2014/08/08 17:06:32
Add a brief comment explaining what you are testin
evy
2014/08/08 18:37:47
Done.
|
| + TouchExploreBookmarkBarInstructions) { |
| + EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); |
|
James Cook
2014/08/08 17:06:32
I would ASSERT_FALSE, as this is a precondition fo
evy
2014/08/08 18:37:47
Done.
|
| + SpeechMonitor monitor; |
| + AccessibilityManager::Get()->EnableSpokenFeedback( |
| + true, ash::A11Y_NOTIFICATION_NONE); |
| + EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); |
| + |
| + accessibility::SimulateTouchScreenInChromeVoxForTest(browser()->profile()); |
| + |
| + // Send an accessibility hover event on the empty bookmarks bar, which is |
| + // what we get when you tap it on a touch screen when ChromeVox is on. |
| + BrowserView* browser_view = |
| + static_cast<BrowserView*>(browser()->window()); |
| + BookmarkBarView* bookmarks_bar = browser_view->GetBookmarkBarView(); |
| + views::View* instructions = bookmarks_bar->GetBookmarkBarInstructionsView(); |
| + instructions->NotifyAccessibilityEvent(ui::AX_EVENT_HOVER, true); |
| + |
| + EXPECT_EQ("Bookmarks,", monitor.GetNextUtterance()); |
| + EXPECT_EQ("For quick access,", monitor.GetNextUtterance()); |
|
aboxhall
2014/08/08 17:16:01
Possibly consider expressing this in terms of inst
evy
2014/08/08 18:37:47
I thought a bit about that, and I'm glad you broug
aboxhall
2014/08/08 20:01:52
I think on balance it'd probably be over-engineeri
evy
2014/08/08 21:00:28
Acknowledged.
|
| + EXPECT_EQ("place your bookmarks here on the bookmarks bar.", |
| + monitor.GetNextUtterance()); |
| +} |
| + |
| +IN_PROC_BROWSER_TEST_F(SpokenFeedbackViewsTest, TouchExploreTabs) { |
| + EXPECT_FALSE(AccessibilityManager::Get()->IsSpokenFeedbackEnabled()); |
| + SpeechMonitor monitor; |
| + AccessibilityManager::Get()->EnableSpokenFeedback( |
| + true, ash::A11Y_NOTIFICATION_NONE); |
| + EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); |
| + |
| + accessibility::SimulateTouchScreenInChromeVoxForTest(browser()->profile()); |
| + |
| + // Send an accessibility hover event on a tab in the tap strip, which is |
| + // what we get when you tap it on a touch screen when ChromeVox is on. |
| + BrowserView* browser_view = |
| + static_cast<BrowserView*>(browser()->window()); |
| + TabStrip* tab_strip = browser_view->tabstrip(); |
| + ASSERT_EQ(tab_strip->tab_count(), 1); |
| + |
| + Tab* tab = tab_strip->tab_at(0); |
| + tab->NotifyAccessibilityEvent(ui::AX_EVENT_HOVER, true); |
| + EXPECT_TRUE(MatchPattern(monitor.GetNextUtterance(), "*, tab * of *")); |
| +} |
| + |
| +} // namespace chromeos |