OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 <vector> | 5 #include <vector> |
6 | 6 |
7 #include "content/browser/browser_thread_impl.h" | 7 #include "content/browser/browser_thread_impl.h" |
8 #include "content/browser/speech/google_one_shot_remote_engine.h" | 8 #include "content/browser/speech/google_one_shot_remote_engine.h" |
9 #include "content/browser/speech/speech_recognizer_impl.h" | 9 #include "content/browser/speech/speech_recognizer_impl.h" |
10 #include "content/public/browser/speech_recognition_event_listener.h" | 10 #include "content/public/browser/speech_recognition_event_listener.h" |
11 #include "media/audio/audio_manager_base.h" | 11 #include "media/audio/audio_manager_base.h" |
12 #include "media/audio/fake_audio_input_stream.h" | 12 #include "media/audio/fake_audio_input_stream.h" |
13 #include "media/audio/fake_audio_output_stream.h" | 13 #include "media/audio/fake_audio_output_stream.h" |
14 #include "media/audio/mock_audio_manager.h" | 14 #include "media/audio/mock_audio_manager.h" |
15 #include "media/audio/test_audio_input_controller_factory.h" | 15 #include "media/audio/test_audio_input_controller_factory.h" |
16 #include "media/base/audio_bus.h" | 16 #include "media/base/audio_bus.h" |
17 #include "net/base/net_errors.h" | 17 #include "net/base/net_errors.h" |
18 #include "net/url_request/test_url_fetcher_factory.h" | 18 #include "net/url_request/test_url_fetcher_factory.h" |
19 #include "net/url_request/url_request_status.h" | 19 #include "net/url_request/url_request_status.h" |
20 #include "testing/gtest/include/gtest/gtest.h" | 20 #include "testing/gtest/include/gtest/gtest.h" |
21 | 21 |
| 22 using base::MessageLoopProxy; |
22 using media::AudioInputController; | 23 using media::AudioInputController; |
23 using media::AudioInputStream; | 24 using media::AudioInputStream; |
24 using media::AudioManager; | 25 using media::AudioManager; |
25 using media::AudioOutputStream; | 26 using media::AudioOutputStream; |
26 using media::AudioParameters; | 27 using media::AudioParameters; |
27 using media::TestAudioInputController; | 28 using media::TestAudioInputController; |
28 using media::TestAudioInputControllerFactory; | 29 using media::TestAudioInputControllerFactory; |
29 | 30 |
30 namespace content { | 31 namespace content { |
31 | 32 |
(...skipping 18 matching lines...) Expand all Loading... |
50 config.audio_num_bits_per_sample = | 51 config.audio_num_bits_per_sample = |
51 SpeechRecognizerImpl::kNumBitsPerAudioSample; | 52 SpeechRecognizerImpl::kNumBitsPerAudioSample; |
52 config.audio_sample_rate = SpeechRecognizerImpl::kAudioSampleRate; | 53 config.audio_sample_rate = SpeechRecognizerImpl::kAudioSampleRate; |
53 config.filter_profanities = false; | 54 config.filter_profanities = false; |
54 sr_engine->SetConfig(config); | 55 sr_engine->SetConfig(config); |
55 | 56 |
56 const int kTestingSessionId = 1; | 57 const int kTestingSessionId = 1; |
57 recognizer_ = new SpeechRecognizerImpl( | 58 recognizer_ = new SpeechRecognizerImpl( |
58 this, kTestingSessionId, false, false, sr_engine); | 59 this, kTestingSessionId, false, false, sr_engine); |
59 audio_manager_.reset(new media::MockAudioManager( | 60 audio_manager_.reset(new media::MockAudioManager( |
60 base::MessageLoop::current()->task_runner().get())); | 61 base::MessageLoop::current()->message_loop_proxy().get())); |
61 recognizer_->SetAudioManagerForTesting(audio_manager_.get()); | 62 recognizer_->SetAudioManagerForTesting(audio_manager_.get()); |
62 | 63 |
63 int audio_packet_length_bytes = | 64 int audio_packet_length_bytes = |
64 (SpeechRecognizerImpl::kAudioSampleRate * | 65 (SpeechRecognizerImpl::kAudioSampleRate * |
65 GoogleOneShotRemoteEngine::kAudioPacketIntervalMs * | 66 GoogleOneShotRemoteEngine::kAudioPacketIntervalMs * |
66 ChannelLayoutToChannelCount(SpeechRecognizerImpl::kChannelLayout) * | 67 ChannelLayoutToChannelCount(SpeechRecognizerImpl::kChannelLayout) * |
67 SpeechRecognizerImpl::kNumBitsPerAudioSample) / (8 * 1000); | 68 SpeechRecognizerImpl::kNumBitsPerAudioSample) / (8 * 1000); |
68 audio_packet_.resize(audio_packet_length_bytes); | 69 audio_packet_.resize(audio_packet_length_bytes); |
69 | 70 |
70 const int channels = | 71 const int channels = |
(...skipping 421 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
492 | 493 |
493 EXPECT_EQ(SPEECH_RECOGNITION_ERROR_NONE, error_); | 494 EXPECT_EQ(SPEECH_RECOGNITION_ERROR_NONE, error_); |
494 EXPECT_FALSE(audio_ended_); | 495 EXPECT_FALSE(audio_ended_); |
495 EXPECT_FALSE(recognition_ended_); | 496 EXPECT_FALSE(recognition_ended_); |
496 recognizer_->AbortRecognition(); | 497 recognizer_->AbortRecognition(); |
497 base::MessageLoop::current()->RunUntilIdle(); | 498 base::MessageLoop::current()->RunUntilIdle(); |
498 CheckFinalEventsConsistency(); | 499 CheckFinalEventsConsistency(); |
499 } | 500 } |
500 | 501 |
501 } // namespace content | 502 } // namespace content |
OLD | NEW |