OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "content/test/webrtc_audio_device_test.h" | 5 #include "content/test/webrtc_audio_device_test.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/file_util.h" | 8 #include "base/file_util.h" |
9 #include "base/message_loop.h" | 9 #include "base/message_loop.h" |
10 #include "base/synchronization/waitable_event.h" | 10 #include "base/synchronization/waitable_event.h" |
11 #include "base/test/signaling_task.h" | 11 #include "base/test/signaling_task.h" |
12 #include "base/test/test_timeouts.h" | 12 #include "base/test/test_timeouts.h" |
13 #include "base/win/scoped_com_initializer.h" | 13 #include "base/win/scoped_com_initializer.h" |
14 #include "content/browser/renderer_host/media/audio_input_renderer_host.h" | 14 #include "content/browser/renderer_host/media/audio_input_renderer_host.h" |
15 #include "content/browser/renderer_host/media/audio_renderer_host.h" | 15 #include "content/browser/renderer_host/media/audio_renderer_host.h" |
16 #include "content/browser/renderer_host/media/media_stream_manager.h" | 16 #include "content/browser/renderer_host/media/media_stream_manager.h" |
17 #include "content/browser/renderer_host/media/mock_media_observer.h" | 17 #include "content/browser/renderer_host/media/mock_media_observer.h" |
18 #include "content/browser/resource_context.h" | 18 #include "content/browser/resource_context.h" |
19 #include "content/common/view_messages.h" | 19 #include "content/common/view_messages.h" |
20 #include "content/public/browser/browser_thread.h" | 20 #include "content/public/browser/browser_thread.h" |
21 #include "content/public/common/content_paths.h" | 21 #include "content/public/common/content_paths.h" |
| 22 #include "content/renderer/media/audio_hardware.h" |
22 #include "content/renderer/media/webrtc_audio_device_impl.h" | 23 #include "content/renderer/media/webrtc_audio_device_impl.h" |
23 #include "content/renderer/render_process.h" | 24 #include "content/renderer/render_process.h" |
24 #include "content/renderer/render_thread_impl.h" | 25 #include "content/renderer/render_thread_impl.h" |
25 #include "content/test/test_browser_thread.h" | 26 #include "content/test/test_browser_thread.h" |
26 #include "net/url_request/url_request_test_util.h" | 27 #include "net/url_request/url_request_test_util.h" |
27 #include "testing/gmock/include/gmock/gmock.h" | 28 #include "testing/gmock/include/gmock/gmock.h" |
28 #include "testing/gtest/include/gtest/gtest.h" | 29 #include "testing/gtest/include/gtest/gtest.h" |
29 #include "third_party/webrtc/voice_engine/main/interface/voe_audio_processing.h" | 30 #include "third_party/webrtc/voice_engine/main/interface/voe_audio_processing.h" |
30 #include "third_party/webrtc/voice_engine/main/interface/voe_base.h" | 31 #include "third_party/webrtc/voice_engine/main/interface/voe_base.h" |
31 #include "third_party/webrtc/voice_engine/main/interface/voe_file.h" | 32 #include "third_party/webrtc/voice_engine/main/interface/voe_file.h" |
(...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
118 FROM_HERE, | 119 FROM_HERE, |
119 base::Bind(&SetupTask::InitializeIOThread, new SetupTask(this), | 120 base::Bind(&SetupTask::InitializeIOThread, new SetupTask(this), |
120 kThreadName)); | 121 kThreadName)); |
121 WaitForIOThreadCompletion(); | 122 WaitForIOThreadCompletion(); |
122 | 123 |
123 render_thread_ = new RenderThreadImpl(kThreadName); | 124 render_thread_ = new RenderThreadImpl(kThreadName); |
124 mock_process_->set_main_thread(render_thread_); | 125 mock_process_->set_main_thread(render_thread_); |
125 } | 126 } |
126 | 127 |
127 void WebRTCAudioDeviceTest::TearDown() { | 128 void WebRTCAudioDeviceTest::TearDown() { |
| 129 SetAudioUtilCallback(NULL); |
| 130 |
128 ChildProcess::current()->io_message_loop()->PostTask( | 131 ChildProcess::current()->io_message_loop()->PostTask( |
129 FROM_HERE, | 132 FROM_HERE, |
130 base::Bind(&SetupTask::UninitializeIOThread, new SetupTask(this))); | 133 base::Bind(&SetupTask::UninitializeIOThread, new SetupTask(this))); |
131 WaitForIOThreadCompletion(); | 134 EXPECT_TRUE(event_.TimedWait( |
| 135 base::TimeDelta::FromMilliseconds(TestTimeouts::action_timeout_ms()))); |
132 mock_process_.reset(); | 136 mock_process_.reset(); |
133 } | 137 } |
134 | 138 |
135 bool WebRTCAudioDeviceTest::Send(IPC::Message* message) { | 139 bool WebRTCAudioDeviceTest::Send(IPC::Message* message) { |
136 return channel_->Send(message); | 140 return channel_->Send(message); |
137 } | 141 } |
138 | 142 |
| 143 void WebRTCAudioDeviceTest::SetAudioUtilCallback(AudioUtilInterface* callback) { |
| 144 // Invalidate any potentially cached values since the new callback should |
| 145 // be used for those queries. |
| 146 audio_hardware::ResetCache(); |
| 147 audio_util_callback_ = callback; |
| 148 } |
| 149 |
139 void WebRTCAudioDeviceTest::InitializeIOThread(const char* thread_name) { | 150 void WebRTCAudioDeviceTest::InitializeIOThread(const char* thread_name) { |
140 // We initialize COM (STA) on our IO thread as is done in Chrome. | 151 // We initialize COM (STA) on our IO thread as is done in Chrome. |
141 // See BrowserProcessSubThread::Init. | 152 // See BrowserProcessSubThread::Init. |
142 initialize_com_.reset(new ScopedCOMInitializer()); | 153 initialize_com_.reset(new ScopedCOMInitializer()); |
143 | 154 |
144 // Set the current thread as the IO thread. | 155 // Set the current thread as the IO thread. |
145 io_thread_.reset(new content::TestBrowserThread(content::BrowserThread::IO, | 156 io_thread_.reset(new content::TestBrowserThread(content::BrowserThread::IO, |
146 MessageLoop::current())); | 157 MessageLoop::current())); |
147 test_request_context_ = new TestURLRequestContext(); | 158 test_request_context_ = new TestURLRequestContext(); |
148 resource_context_->set_request_context(test_request_context_.get()); | 159 resource_context_->set_request_context(test_request_context_.get()); |
149 media_observer_.reset(new MockMediaObserver()); | 160 media_observer_.reset(new MockMediaObserver()); |
150 resource_context_->set_media_observer(media_observer_.get()); | 161 resource_context_->set_media_observer(media_observer_.get()); |
151 media_stream_manager_.reset(new media_stream::MediaStreamManager()); | 162 media_stream_manager_.reset(new media_stream::MediaStreamManager()); |
152 resource_context_->set_media_stream_manager(media_stream_manager_.get()); | 163 resource_context_->set_media_stream_manager(media_stream_manager_.get()); |
153 | 164 |
154 CreateChannel(thread_name, resource_context_.get()); | 165 CreateChannel(thread_name, resource_context_.get()); |
155 } | 166 } |
156 | 167 |
157 void WebRTCAudioDeviceTest::UninitializeIOThread() { | 168 void WebRTCAudioDeviceTest::UninitializeIOThread() { |
158 DestroyChannel(); | 169 DestroyChannel(); |
159 resource_context_.reset(); | 170 resource_context_.reset(); |
160 media_stream_manager_.reset(); | 171 media_stream_manager_.reset(); |
161 test_request_context_ = NULL; | 172 test_request_context_ = NULL; |
162 initialize_com_.reset(); | 173 initialize_com_.reset(); |
| 174 event_.Signal(); |
163 } | 175 } |
164 | 176 |
165 void WebRTCAudioDeviceTest::CreateChannel( | 177 void WebRTCAudioDeviceTest::CreateChannel( |
166 const char* name, | 178 const char* name, |
167 content::ResourceContext* resource_context) { | 179 content::ResourceContext* resource_context) { |
168 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO)); | 180 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO)); |
169 audio_render_host_ = new AudioRendererHost(resource_context); | 181 audio_render_host_ = new AudioRendererHost(resource_context); |
170 audio_render_host_->OnChannelConnected(base::GetCurrentProcId()); | 182 audio_render_host_->OnChannelConnected(base::GetCurrentProcId()); |
171 | 183 |
172 audio_input_renderer_host_ = new AudioInputRendererHost(resource_context); | 184 audio_input_renderer_host_ = new AudioInputRendererHost(resource_context); |
173 audio_input_renderer_host_->OnChannelConnected(base::GetCurrentProcId()); | 185 audio_input_renderer_host_->OnChannelConnected(base::GetCurrentProcId()); |
174 | 186 |
175 channel_.reset(new IPC::Channel(name, IPC::Channel::MODE_SERVER, this)); | 187 channel_.reset(new IPC::Channel(name, IPC::Channel::MODE_SERVER, this)); |
176 ASSERT_TRUE(channel_->Connect()); | 188 ASSERT_TRUE(channel_->Connect()); |
177 | 189 |
178 audio_render_host_->OnFilterAdded(channel_.get()); | 190 audio_render_host_->OnFilterAdded(channel_.get()); |
179 audio_input_renderer_host_->OnFilterAdded(channel_.get()); | 191 audio_input_renderer_host_->OnFilterAdded(channel_.get()); |
180 } | 192 } |
181 | 193 |
182 void WebRTCAudioDeviceTest::DestroyChannel() { | 194 void WebRTCAudioDeviceTest::DestroyChannel() { |
183 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO)); | 195 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO)); |
184 audio_render_host_->OnChannelClosing(); | 196 audio_render_host_->OnChannelClosing(); |
| 197 audio_render_host_->OnFilterRemoved(); |
185 audio_input_renderer_host_->OnChannelClosing(); | 198 audio_input_renderer_host_->OnChannelClosing(); |
| 199 audio_input_renderer_host_->OnFilterRemoved(); |
186 channel_.reset(); | 200 channel_.reset(); |
187 audio_render_host_ = NULL; | 201 audio_render_host_ = NULL; |
188 audio_input_renderer_host_ = NULL; | 202 audio_input_renderer_host_ = NULL; |
189 } | 203 } |
190 | 204 |
191 void WebRTCAudioDeviceTest::OnGetHardwareSampleRate(double* sample_rate) { | 205 void WebRTCAudioDeviceTest::OnGetHardwareSampleRate(double* sample_rate) { |
192 EXPECT_TRUE(audio_util_callback_); | 206 EXPECT_TRUE(audio_util_callback_); |
193 *sample_rate = audio_util_callback_ ? | 207 *sample_rate = audio_util_callback_ ? |
194 audio_util_callback_->GetAudioHardwareSampleRate() : 0.0; | 208 audio_util_callback_->GetAudioHardwareSampleRate() : 0.0; |
195 } | 209 } |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
230 IPC_BEGIN_MESSAGE_MAP_EX(WebRTCAudioDeviceTest, message, message_is_ok) | 244 IPC_BEGIN_MESSAGE_MAP_EX(WebRTCAudioDeviceTest, message, message_is_ok) |
231 IPC_MESSAGE_HANDLER(ViewHostMsg_GetHardwareSampleRate, | 245 IPC_MESSAGE_HANDLER(ViewHostMsg_GetHardwareSampleRate, |
232 OnGetHardwareSampleRate) | 246 OnGetHardwareSampleRate) |
233 IPC_MESSAGE_HANDLER(ViewHostMsg_GetHardwareInputSampleRate, | 247 IPC_MESSAGE_HANDLER(ViewHostMsg_GetHardwareInputSampleRate, |
234 OnGetHardwareInputSampleRate) | 248 OnGetHardwareInputSampleRate) |
235 IPC_MESSAGE_UNHANDLED(handled = false) | 249 IPC_MESSAGE_UNHANDLED(handled = false) |
236 IPC_END_MESSAGE_MAP_EX() | 250 IPC_END_MESSAGE_MAP_EX() |
237 | 251 |
238 EXPECT_TRUE(message_is_ok); | 252 EXPECT_TRUE(message_is_ok); |
239 | 253 |
240 // We leave a DLOG as a hint to the developer in case important IPC messages | |
241 // are being dropped. | |
242 DLOG_IF(WARNING, !handled) << "Unhandled IPC message"; | |
243 | |
244 return true; | 254 return true; |
245 } | 255 } |
246 | 256 |
247 // Posts a final task to the IO message loop and waits for completion. | 257 // Posts a final task to the IO message loop and waits for completion. |
248 void WebRTCAudioDeviceTest::WaitForIOThreadCompletion() { | 258 void WebRTCAudioDeviceTest::WaitForIOThreadCompletion() { |
249 ChildProcess::current()->io_message_loop()->PostTask( | 259 ChildProcess::current()->io_message_loop()->PostTask( |
250 FROM_HERE, new base::SignalingTask(&event_)); | 260 FROM_HERE, new base::SignalingTask(&event_)); |
251 EXPECT_TRUE(event_.TimedWait( | 261 EXPECT_TRUE(event_.TimedWait( |
252 base::TimeDelta::FromMilliseconds(TestTimeouts::action_timeout_ms()))); | 262 base::TimeDelta::FromMilliseconds(TestTimeouts::action_timeout_ms()))); |
253 } | 263 } |
(...skipping 18 matching lines...) Expand all Loading... |
272 WebRTCTransportImpl::~WebRTCTransportImpl() {} | 282 WebRTCTransportImpl::~WebRTCTransportImpl() {} |
273 | 283 |
274 int WebRTCTransportImpl::SendPacket(int channel, const void* data, int len) { | 284 int WebRTCTransportImpl::SendPacket(int channel, const void* data, int len) { |
275 return network_->ReceivedRTPPacket(channel, data, len); | 285 return network_->ReceivedRTPPacket(channel, data, len); |
276 } | 286 } |
277 | 287 |
278 int WebRTCTransportImpl::SendRTCPPacket(int channel, const void* data, | 288 int WebRTCTransportImpl::SendRTCPPacket(int channel, const void* data, |
279 int len) { | 289 int len) { |
280 return network_->ReceivedRTCPPacket(channel, data, len); | 290 return network_->ReceivedRTCPPacket(channel, data, len); |
281 } | 291 } |
OLD | NEW |