| 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 |