1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CONTENT_TEST_WEBRTC_AUDIO_DEVICE_TEST_H_
6 #define CONTENT_TEST_WEBRTC_AUDIO_DEVICE_TEST_H_
10 #include "base/files/file_path.h"
11 #include "base/memory/ref_counted.h"
12 #include "base/memory/scoped_ptr.h"
13 #include "base/message_loop/message_loop.h"
14 #include "content/browser/renderer_host/media/mock_media_observer.h"
15 #include "content/public/renderer/content_renderer_client.h"
16 #include "ipc/ipc_listener.h"
17 #include "media/base/audio_hardware_config.h"
18 #include "media/base/channel_layout.h"
19 #include "testing/gtest/include/gtest/gtest.h"
20 #include "third_party/webrtc/common_types.h"
31 class URLRequestContext
;
41 class ScopedCOMInitializer
;
48 class AudioInputRendererHost
;
49 class AudioMirroringManager
;
50 class AudioRendererHost
;
51 class ContentRendererClient
;
52 class MediaStreamManager
;
53 class RenderThreadImpl
;
54 class ResourceContext
;
55 class TestBrowserThread
;
56 class WebRtcAudioRenderer
;
57 class WebRTCMockRenderProcess
;
59 // Scoped class for WebRTC interfaces. Fetches the wrapped interface
60 // in the constructor via WebRTC's GetInterface mechanism and then releases
61 // the reference in the destructor.
63 class ScopedWebRTCPtr
{
65 template<typename Engine
>
66 explicit ScopedWebRTCPtr(Engine
* e
)
67 : ptr_(T::GetInterface(e
)) {}
68 explicit ScopedWebRTCPtr(T
* p
) : ptr_(p
) {}
69 ~ScopedWebRTCPtr() { reset(); }
70 T
* operator->() const { return ptr_
; }
71 T
* get() const { return ptr_
; }
73 // Releases the current pointer.
81 bool valid() const { return ptr_
!= NULL
; }
87 // Wrapper to automatically calling T::Delete in the destructor.
88 // This is useful for some WebRTC objects that have their own Create/Delete
89 // methods and we can't use our our scoped_* classes.
91 class WebRTCAutoDelete
{
93 WebRTCAutoDelete() : ptr_(NULL
) {}
94 explicit WebRTCAutoDelete(T
* ptr
) : ptr_(ptr
) {}
95 ~WebRTCAutoDelete() { reset(); }
104 T
* operator->() { return ptr_
; }
105 T
* get() const { return ptr_
; }
107 bool valid() const { return ptr_
!= NULL
; }
113 // Implemented and defined in the cc file.
114 class ReplaceContentClientRenderer
;
116 // Temporarily disabled in LeakSanitizer builds due to memory leaks.
117 // http://crbug.com/148865
118 #if defined(LEAK_SANITIZER)
119 #define MAYBE_WebRTCAudioDeviceTest DISABLED_WebRTCAudioDeviceTest
121 #define MAYBE_WebRTCAudioDeviceTest WebRTCAudioDeviceTest
124 class MAYBE_WebRTCAudioDeviceTest
: public ::testing::Test
,
125 public IPC::Listener
{
127 MAYBE_WebRTCAudioDeviceTest();
128 virtual ~MAYBE_WebRTCAudioDeviceTest();
130 virtual void SetUp() OVERRIDE
;
131 virtual void TearDown() OVERRIDE
;
133 // Sends an IPC message to the IO thread channel.
134 bool Send(IPC::Message
* message
);
136 void SetAudioHardwareConfig(media::AudioHardwareConfig
* hardware_config
);
138 scoped_refptr
<WebRtcAudioRenderer
> CreateDefaultWebRtcAudioRenderer(
142 void InitializeIOThread(const char* thread_name
);
143 void UninitializeIOThread();
144 void CreateChannel(const char* name
);
145 void DestroyChannel();
147 void OnGetAudioHardwareConfig(media::AudioParameters
* input_params
,
148 media::AudioParameters
* output_params
);
150 // IPC::Listener implementation.
151 virtual bool OnMessageReceived(const IPC::Message
& message
) OVERRIDE
;
153 // Posts a final task to the IO message loop and waits for completion.
154 void WaitForIOThreadCompletion();
155 void WaitForAudioManagerCompletion();
156 void WaitForMessageLoopCompletion(base::MessageLoopProxy
* loop
);
158 // Convenience getter for gmock.
159 MockMediaInternals
& media_observer() const {
160 return *media_internals_
.get();
163 std::string
GetTestDataPath(const base::FilePath::StringType
& file_name
);
165 scoped_ptr
<ReplaceContentClientRenderer
> saved_content_renderer_
;
166 base::MessageLoopForUI message_loop_
;
167 ContentRendererClient content_renderer_client_
;
168 RenderThreadImpl
* render_thread_
; // Owned by mock_process_.
169 scoped_ptr
<WebRTCMockRenderProcess
> mock_process_
;
170 scoped_ptr
<MockMediaInternals
> media_internals_
;
171 scoped_ptr
<MediaStreamManager
> media_stream_manager_
;
172 scoped_ptr
<media::AudioManager
> audio_manager_
;
173 scoped_ptr
<AudioMirroringManager
> mirroring_manager_
;
174 scoped_ptr
<net::URLRequestContext
> test_request_context_
;
175 scoped_ptr
<ResourceContext
> resource_context_
;
176 scoped_ptr
<IPC::Channel
> channel_
;
177 scoped_refptr
<AudioRendererHost
> audio_render_host_
;
178 scoped_refptr
<AudioInputRendererHost
> audio_input_renderer_host_
;
180 media::AudioHardwareConfig
* audio_hardware_config_
; // Weak reference.
182 // Initialized on the main test thread that we mark as the UI thread.
183 scoped_ptr
<TestBrowserThread
> ui_thread_
;
184 // Initialized on our IO thread to satisfy BrowserThread::IO checks.
185 scoped_ptr
<TestBrowserThread
> io_thread_
;
188 // COM initialization on the IO thread.
189 scoped_ptr
<base::win::ScopedCOMInitializer
> initialize_com_
;
192 // These are initialized when we set up our IO thread.
193 bool has_input_devices_
;
194 bool has_output_devices_
;
196 // The previous state for whether sandbox support was enabled in
197 // RenderViewWebKitPlatformSupportImpl.
198 bool sandbox_was_enabled_
;
201 // A very basic implementation of webrtc::Transport that acts as a transport
202 // but just forwards all calls to a local webrtc::VoENetwork implementation.
203 // Ownership of the VoENetwork object lies outside the class.
204 class WebRTCTransportImpl
: public webrtc::Transport
{
206 explicit WebRTCTransportImpl(webrtc::VoENetwork
* network
);
207 virtual ~WebRTCTransportImpl();
209 virtual int SendPacket(int channel
, const void* data
, int len
) OVERRIDE
;
210 virtual int SendRTCPPacket(int channel
, const void* data
, int len
) OVERRIDE
;
213 webrtc::VoENetwork
* network_
;
216 } // namespace content
218 #endif // CONTENT_TEST_WEBRTC_AUDIO_DEVICE_TEST_H_