Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(57)

Side by Side Diff: content/test/webrtc_audio_device_test.cc

Issue 10299002: Stop refcounting URLRequestContext. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Initialize to NULL Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 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/bind_helpers.h" 8 #include "base/bind_helpers.h"
9 #include "base/compiler_specific.h" 9 #include "base/compiler_specific.h"
10 #include "base/file_util.h" 10 #include "base/file_util.h"
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
74 // Restore the original renderer. 74 // Restore the original renderer.
75 content::GetContentClient()->set_renderer(saved_renderer_); 75 content::GetContentClient()->set_renderer(saved_renderer_);
76 } 76 }
77 private: 77 private:
78 content::ContentRendererClient* saved_renderer_; 78 content::ContentRendererClient* saved_renderer_;
79 DISALLOW_COPY_AND_ASSIGN(ReplaceContentClientRenderer); 79 DISALLOW_COPY_AND_ASSIGN(ReplaceContentClientRenderer);
80 }; 80 };
81 81
82 namespace { 82 namespace {
83 83
84 class MockResourceContext : public content::ResourceContext {
85 public:
86 MockResourceContext() : test_request_context_(NULL) {}
87 virtual ~MockResourceContext() {}
88
89 void set_request_context(net::URLRequestContext* request_context) {
90 test_request_context_ = request_context;
91 }
92
93 // ResourceContext implementation:
94 virtual net::HostResolver* GetHostResolver() OVERRIDE {
95 return NULL;
96 }
97 virtual net::URLRequestContext* GetRequestContext() OVERRIDE {
98 return test_request_context_;
99 }
100
101 private:
102 net::URLRequestContext* test_request_context_;
103
104 DISALLOW_COPY_AND_ASSIGN(MockResourceContext);
105 };
106
84 ACTION_P(QuitMessageLoop, loop_or_proxy) { 107 ACTION_P(QuitMessageLoop, loop_or_proxy) {
85 loop_or_proxy->PostTask(FROM_HERE, MessageLoop::QuitClosure()); 108 loop_or_proxy->PostTask(FROM_HERE, MessageLoop::QuitClosure());
86 } 109 }
87 110
88 } // end namespace 111 } // namespace
89 112
90 WebRTCAudioDeviceTest::WebRTCAudioDeviceTest() 113 WebRTCAudioDeviceTest::WebRTCAudioDeviceTest()
91 : render_thread_(NULL), audio_util_callback_(NULL), 114 : render_thread_(NULL), audio_util_callback_(NULL),
92 has_input_devices_(false), has_output_devices_(false) { 115 has_input_devices_(false), has_output_devices_(false) {
93 } 116 }
94 117
95 WebRTCAudioDeviceTest::~WebRTCAudioDeviceTest() {} 118 WebRTCAudioDeviceTest::~WebRTCAudioDeviceTest() {}
96 119
97 void WebRTCAudioDeviceTest::SetUp() { 120 void WebRTCAudioDeviceTest::SetUp() {
98 // This part sets up a RenderThread environment to ensure that 121 // This part sets up a RenderThread environment to ensure that
99 // RenderThread::current() (<=> TLS pointer) is valid. 122 // RenderThread::current() (<=> TLS pointer) is valid.
100 // Main parts are inspired by the RenderViewFakeResourcesTest. 123 // Main parts are inspired by the RenderViewFakeResourcesTest.
101 // Note that, the IPC part is not utilized in this test. 124 // Note that, the IPC part is not utilized in this test.
102 saved_content_renderer_.reset( 125 saved_content_renderer_.reset(
103 new ReplaceContentClientRenderer(&mock_content_renderer_client_)); 126 new ReplaceContentClientRenderer(&mock_content_renderer_client_));
104 mock_process_.reset(new WebRTCMockRenderProcess()); 127 mock_process_.reset(new WebRTCMockRenderProcess());
105 ui_thread_.reset(new content::TestBrowserThread(content::BrowserThread::UI, 128 ui_thread_.reset(new content::TestBrowserThread(content::BrowserThread::UI,
106 MessageLoop::current())); 129 MessageLoop::current()));
107 130
108 // Construct the resource context on the UI thread. 131 // Construct the resource context on the UI thread.
109 resource_context_.reset(new content::MockResourceContext(NULL)); 132 resource_context_.reset(new MockResourceContext);
110 133
111 static const char kThreadName[] = "RenderThread"; 134 static const char kThreadName[] = "RenderThread";
112 ChildProcess::current()->io_message_loop()->PostTask(FROM_HERE, 135 ChildProcess::current()->io_message_loop()->PostTask(FROM_HERE,
113 base::Bind(&WebRTCAudioDeviceTest::InitializeIOThread, 136 base::Bind(&WebRTCAudioDeviceTest::InitializeIOThread,
114 base::Unretained(this), kThreadName)); 137 base::Unretained(this), kThreadName));
115 WaitForIOThreadCompletion(); 138 WaitForIOThreadCompletion();
116 139
117 render_thread_ = new RenderThreadImpl(kThreadName); 140 render_thread_ = new RenderThreadImpl(kThreadName);
118 } 141 }
119 142
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
161 // See BrowserProcessSubThread::Init. 184 // See BrowserProcessSubThread::Init.
162 initialize_com_.reset(new ScopedCOMInitializer()); 185 initialize_com_.reset(new ScopedCOMInitializer());
163 186
164 // Set the current thread as the IO thread. 187 // Set the current thread as the IO thread.
165 io_thread_.reset(new content::TestBrowserThread(content::BrowserThread::IO, 188 io_thread_.reset(new content::TestBrowserThread(content::BrowserThread::IO,
166 MessageLoop::current())); 189 MessageLoop::current()));
167 190
168 audio_manager_.reset(media::AudioManager::Create()); 191 audio_manager_.reset(media::AudioManager::Create());
169 192
170 // Populate our resource context. 193 // Populate our resource context.
171 test_request_context_ = new TestURLRequestContext(); 194 test_request_context_.reset(new TestURLRequestContext());
172 resource_context_->set_request_context(test_request_context_.get()); 195 MockResourceContext* resource_context =
196 static_cast<MockResourceContext*>(resource_context_.get());
197 resource_context->set_request_context(test_request_context_.get());
173 media_observer_.reset(new MockMediaObserver()); 198 media_observer_.reset(new MockMediaObserver());
174 199
175 has_input_devices_ = audio_manager_->HasAudioInputDevices(); 200 has_input_devices_ = audio_manager_->HasAudioInputDevices();
176 has_output_devices_ = audio_manager_->HasAudioOutputDevices(); 201 has_output_devices_ = audio_manager_->HasAudioOutputDevices();
177 202
178 // Create an IPC channel that handles incoming messages on the IO thread. 203 // Create an IPC channel that handles incoming messages on the IO thread.
179 CreateChannel(thread_name); 204 CreateChannel(thread_name);
180 } 205 }
181 206
182 void WebRTCAudioDeviceTest::UninitializeIOThread() { 207 void WebRTCAudioDeviceTest::UninitializeIOThread() {
183 resource_context_.reset(); 208 resource_context_.reset();
184 209
185 audio_manager_.reset(); 210 audio_manager_.reset();
186 test_request_context_ = NULL; 211 test_request_context_.reset();
187 initialize_com_.reset(); 212 initialize_com_.reset();
188 } 213 }
189 214
190 void WebRTCAudioDeviceTest::CreateChannel(const char* name) { 215 void WebRTCAudioDeviceTest::CreateChannel(const char* name) {
191 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO)); 216 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO));
192 audio_render_host_ = new AudioRendererHost( 217 audio_render_host_ = new AudioRendererHost(
193 audio_manager_.get(), media_observer_.get()); 218 audio_manager_.get(), media_observer_.get());
194 audio_render_host_->OnChannelConnected(base::GetCurrentProcId()); 219 audio_render_host_->OnChannelConnected(base::GetCurrentProcId());
195 220
196 audio_input_renderer_host_ = new AudioInputRendererHost( 221 audio_input_renderer_host_ = new AudioInputRendererHost(
(...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after
324 WebRTCTransportImpl::~WebRTCTransportImpl() {} 349 WebRTCTransportImpl::~WebRTCTransportImpl() {}
325 350
326 int WebRTCTransportImpl::SendPacket(int channel, const void* data, int len) { 351 int WebRTCTransportImpl::SendPacket(int channel, const void* data, int len) {
327 return network_->ReceivedRTPPacket(channel, data, len); 352 return network_->ReceivedRTPPacket(channel, data, len);
328 } 353 }
329 354
330 int WebRTCTransportImpl::SendRTCPPacket(int channel, const void* data, 355 int WebRTCTransportImpl::SendRTCPPacket(int channel, const void* data,
331 int len) { 356 int len) {
332 return network_->ReceivedRTCPPacket(channel, data, len); 357 return network_->ReceivedRTCPPacket(channel, data, len);
333 } 358 }
OLDNEW
« no previous file with comments | « content/test/webrtc_audio_device_test.h ('k') | net/proxy/dhcp_proxy_script_adapter_fetcher_win_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698