blob: af6af9efa0914c3867369abd57c90703047864b7 [file] [log] [blame]
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ash/shell.h"
#include "base/strings/pattern.h"
#include "chrome/browser/chromeos/accessibility/accessibility_manager.h"
#include "chrome/browser/chromeos/accessibility/speech_monitor.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_window.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "chrome/test/base/ui_test_utils.h"
#include "content/public/browser/browser_accessibility_state.h"
#include "content/public/browser/notification_details.h"
#include "content/public/browser/notification_service.h"
#include "content/public/test/browser_test_utils.h"
#include "extensions/browser/notification_types.h"
#include "net/dns/mock_host_resolver.h"
#include "ui/events/test/event_generator.h"
#include "url/url_constants.h"
namespace chromeos {
class SelectToSpeakLiveSiteTest : public InProcessBrowserTest {
protected:
void SetUpOnMainThread() override {
ASSERT_FALSE(AccessibilityManager::Get()->IsSelectToSpeakEnabled());
content::WindowedNotificationObserver extension_load_waiter(
extensions::NOTIFICATION_EXTENSION_HOST_DID_STOP_FIRST_LOAD,
content::NotificationService::AllSources());
AccessibilityManager::Get()->SetSelectToSpeakEnabled(true);
extension_load_waiter.Wait();
aura::Window* root_window = ash::Shell::Get()->GetPrimaryRootWindow();
generator_.reset(new ui::test::EventGenerator(root_window));
ui_test_utils::NavigateToURL(browser(), GURL(url::kAboutBlankURL));
}
void SetUpInProcessBrowserTestFixture() override {
// To avoid depending on external resources, browser tests don't allow
// non-local DNS queries by default. Override this for this specific
// manual test suite.
scoped_refptr<net::RuleBasedHostResolverProc> resolver =
new net::RuleBasedHostResolverProc(host_resolver());
resolver->AllowDirectLookup("*.google.com");
resolver->AllowDirectLookup("*.gstatic.com");
mock_host_resolver_override_.reset(
new net::ScopedDefaultHostResolverProc(resolver.get()));
}
void TearDownInProcessBrowserTestFixture() override {
mock_host_resolver_override_.reset();
}
SpeechMonitor speech_monitor_;
std::unique_ptr<ui::test::EventGenerator> generator_;
std::unique_ptr<net::ScopedDefaultHostResolverProc>
mock_host_resolver_override_;
};
// This is a sanity check / integration test that Select-to-speak works
// with Google Docs, since we have a small amount of code that works
// around a compatibility issue.
//
// It's only run on an FYI bot because we don't want Docs outages to affect the
// Chrome waterfall.
//
// To visually see what's happening while the test is running,
// add this option:
// --enable-pixel-output-in-tests
IN_PROC_BROWSER_TEST_F(SelectToSpeakLiveSiteTest, GoogleDocsSupport) {
const char* kGoogleDocsUrl =
"https://docs.google.com/document/d/"
"1qpu3koSIHpBzQbxeEE-dofSKXCIgdc4yJLI-o1LpCPs/view";
const char* kTextFoundInGoogleDoc = "Long-string-to-test-select-to-speak";
content::BrowserAccessibilityState::GetInstance()->EnableAccessibility();
ui_test_utils::NavigateToURL(browser(), GURL(kGoogleDocsUrl));
content::WebContents* web_contents =
browser()->tab_strip_model()->GetActiveWebContents();
content::EnableAccessibilityForWebContents(web_contents);
content::WaitForAccessibilityTreeToContainNodeWithName(
web_contents, "Long-string-to-test-select-to-speak");
gfx::Rect bounds = browser()->window()->GetBounds();
generator_->PressKey(ui::VKEY_LWIN, 0 /* flags */);
generator_->MoveMouseTo(bounds.x() + 8, bounds.y() + 200);
generator_->PressLeftButton();
generator_->MoveMouseTo(bounds.x() + bounds.width() - 8,
bounds.y() + bounds.height() - 8);
generator_->ReleaseLeftButton();
generator_->ReleaseKey(ui::VKEY_LWIN, 0 /* flags */);
for (;;) {
std::string utterance = speech_monitor_.GetNextUtterance();
if (utterance == kTextFoundInGoogleDoc)
break;
}
}
} // namespace chromeos