Index: chrome/browser/chromeos/accessibility/spoken_feedback_browsertest.cc |
diff --git a/chrome/browser/chromeos/accessibility/spoken_feedback_browsertest.cc b/chrome/browser/chromeos/accessibility/spoken_feedback_browsertest.cc |
index 97ab6c4e05b78deb09e27e1273cb13a541fd5114..b529c9b3b9ca5d130e6abeaac4f4752e16135f3e 100644 |
--- a/chrome/browser/chromeos/accessibility/spoken_feedback_browsertest.cc |
+++ b/chrome/browser/chromeos/accessibility/spoken_feedback_browsertest.cc |
@@ -8,6 +8,7 @@ |
#include "base/strings/string_util.h" |
#include "chrome/app/chrome_command_ids.h" |
#include "chrome/browser/chromeos/accessibility/accessibility_manager.h" |
+#include "chrome/browser/chromeos/accessibility/speech_monitor.h" |
#include "chrome/browser/chromeos/login/login_display_host.h" |
#include "chrome/browser/chromeos/login/login_display_host_impl.h" |
#include "chrome/browser/chromeos/login/user_manager.h" |
@@ -33,86 +34,6 @@ using extensions::api::braille_display_private::StubBrailleController; |
namespace chromeos { |
-namespace { |
-const char kChromeVoxEnabledMessage[] = "chrome vox spoken feedback is ready"; |
-} // anonymous namespace |
- |
-// Installs itself as the platform speech synthesis engine, allowing it to |
-// intercept all speech calls, and then provides a method to block until the |
-// next utterance is spoken. |
-class SpeechMonitor : public TtsPlatformImpl { |
- public: |
- SpeechMonitor(); |
- virtual ~SpeechMonitor(); |
- |
- // Blocks until the next utterance is spoken, and returns its text. |
- std::string GetNextUtterance(); |
- |
- // TtsPlatformImpl implementation. |
- virtual bool PlatformImplAvailable() OVERRIDE { return true; } |
- virtual bool Speak( |
- int utterance_id, |
- const std::string& utterance, |
- const std::string& lang, |
- const VoiceData& voice, |
- const UtteranceContinuousParameters& params) OVERRIDE { |
- TtsController::GetInstance()->OnTtsEvent( |
- utterance_id, |
- TTS_EVENT_END, |
- static_cast<int>(utterance.size()), |
- std::string()); |
- return true; |
- } |
- virtual bool StopSpeaking() OVERRIDE { return true; } |
- virtual bool IsSpeaking() OVERRIDE { return false; } |
- virtual void GetVoices(std::vector<VoiceData>* out_voices) OVERRIDE { |
- out_voices->push_back(VoiceData()); |
- VoiceData& voice = out_voices->back(); |
- voice.native = true; |
- voice.name = "SpeechMonitor"; |
- voice.events.insert(TTS_EVENT_END); |
- } |
- virtual void Pause() OVERRIDE {} |
- virtual void Resume() OVERRIDE {} |
- virtual std::string error() OVERRIDE { return ""; } |
- virtual void clear_error() OVERRIDE {} |
- virtual void set_error(const std::string& error) OVERRIDE {} |
- virtual void WillSpeakUtteranceWithVoice( |
- const Utterance* utterance, const VoiceData& voice_data) OVERRIDE; |
- |
- private: |
- scoped_refptr<content::MessageLoopRunner> loop_runner_; |
- std::deque<std::string> utterance_queue_; |
- |
- DISALLOW_COPY_AND_ASSIGN(SpeechMonitor); |
-}; |
- |
-SpeechMonitor::SpeechMonitor() { |
- TtsController::GetInstance()->SetPlatformImpl(this); |
-} |
- |
-SpeechMonitor::~SpeechMonitor() { |
- TtsController::GetInstance()->SetPlatformImpl(TtsPlatformImpl::GetInstance()); |
-} |
- |
-void SpeechMonitor::WillSpeakUtteranceWithVoice(const Utterance* utterance, |
- const VoiceData& voice_data) { |
- utterance_queue_.push_back(utterance->text()); |
- if (loop_runner_.get()) |
- loop_runner_->Quit(); |
-} |
- |
-std::string SpeechMonitor::GetNextUtterance() { |
- if (utterance_queue_.empty()) { |
- loop_runner_ = new content::MessageLoopRunner(); |
- loop_runner_->Run(); |
- loop_runner_ = NULL; |
- } |
- std::string result = utterance_queue_.front(); |
- utterance_queue_.pop_front(); |
- return result; |
-} |
- |
// |
// Spoken feedback tests in a normal browser window. |
// |
@@ -141,7 +62,7 @@ IN_PROC_BROWSER_TEST_F(SpokenFeedbackTest, EnableSpokenFeedback) { |
SpeechMonitor monitor; |
AccessibilityManager::Get()->EnableSpokenFeedback( |
true, ash::A11Y_NOTIFICATION_NONE); |
- EXPECT_EQ(kChromeVoxEnabledMessage, monitor.GetNextUtterance()); |
+ EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); |
} |
IN_PROC_BROWSER_TEST_F(SpokenFeedbackTest, FocusToolbar) { |
@@ -150,7 +71,7 @@ IN_PROC_BROWSER_TEST_F(SpokenFeedbackTest, FocusToolbar) { |
SpeechMonitor monitor; |
AccessibilityManager::Get()->EnableSpokenFeedback( |
true, ash::A11Y_NOTIFICATION_NONE); |
- EXPECT_EQ(kChromeVoxEnabledMessage, monitor.GetNextUtterance()); |
+ EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); |
chrome::ExecuteCommand(browser(), IDC_FOCUS_TOOLBAR); |
// Might be "Google Chrome Toolbar" or "Chromium Toolbar". |
@@ -195,7 +116,7 @@ IN_PROC_BROWSER_TEST_F(OobeSpokenFeedbackTest, SpokenFeedbackInOobe) { |
SpeechMonitor monitor; |
AccessibilityManager::Get()->EnableSpokenFeedback( |
true, ash::A11Y_NOTIFICATION_NONE); |
- EXPECT_EQ(kChromeVoxEnabledMessage, monitor.GetNextUtterance()); |
+ EXPECT_TRUE(monitor.SkipChromeVoxEnabledMessage()); |
EXPECT_EQ("Select your language:", monitor.GetNextUtterance()); |
EXPECT_EQ("English ( United States)", monitor.GetNextUtterance()); |