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

Side by Side Diff: media/audio/audio_manager_unittest.cc

Issue 1806313003: Pass task runners to AudioManager constructor. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Pass task runners into AudioManager::Create Created 4 years, 9 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
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 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 "base/bind.h" 5 #include "base/bind.h"
6 #include "base/environment.h" 6 #include "base/environment.h"
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/memory/scoped_ptr.h" 8 #include "base/memory/scoped_ptr.h"
9 #include "base/synchronization/waitable_event.h" 9 #include "base/synchronization/waitable_event.h"
10 #include "build/build_config.h" 10 #include "build/build_config.h"
11 #include "media/audio/audio_manager.h" 11 #include "media/audio/audio_manager.h"
12 #include "media/audio/audio_manager_base.h" 12 #include "media/audio/audio_manager_base.h"
13 #include "media/audio/audio_output_proxy.h" 13 #include "media/audio/audio_output_proxy.h"
14 #include "media/audio/audio_thread.h"
14 #include "media/audio/audio_unittest_util.h" 15 #include "media/audio/audio_unittest_util.h"
15 #include "media/audio/fake_audio_log_factory.h" 16 #include "media/audio/fake_audio_log_factory.h"
16 #include "media/audio/fake_audio_manager.h" 17 #include "media/audio/fake_audio_manager.h"
17 #include "testing/gtest/include/gtest/gtest.h" 18 #include "testing/gtest/include/gtest/gtest.h"
18 19
19 #if defined(USE_ALSA) 20 #if defined(USE_ALSA)
20 #include "media/audio/alsa/audio_manager_alsa.h" 21 #include "media/audio/alsa/audio_manager_alsa.h"
21 #endif // defined(USE_ALSA) 22 #endif // defined(USE_ALSA)
22 23
23 #if defined(OS_WIN) 24 #if defined(OS_WIN)
24 #include "base/win/scoped_com_initializer.h" 25 #include "base/win/scoped_com_initializer.h"
25 #include "media/audio/win/audio_manager_win.h" 26 #include "media/audio/win/audio_manager_win.h"
26 #include "media/audio/win/wavein_input_win.h" 27 #include "media/audio/win/wavein_input_win.h"
27 #endif 28 #endif
28 29
29 #if defined(USE_PULSEAUDIO) 30 #if defined(USE_PULSEAUDIO)
30 #include "media/audio/pulse/audio_manager_pulse.h" 31 #include "media/audio/pulse/audio_manager_pulse.h"
31 #endif // defined(USE_PULSEAUDIO) 32 #endif // defined(USE_PULSEAUDIO)
32 33
33 namespace media { 34 namespace media {
34 35
36 namespace {
37 template <typename T>
38 struct AudioManagerFactory {
39 static AudioManager* Create(AudioLogFactory* audio_log_factory) {
40 base::Thread* audio_thread = AudioThread::Get();
41 return new T(audio_thread->task_runner(), audio_thread->task_runner(),
42 audio_log_factory);
43 };
44 };
45
46 #if defined(USE_PULSEAUDIO)
47 template <>
48 struct AudioManagerFactory<AudioManagerPulse> {
49 static AudioManager* Create(AudioLogFactory* audio_log_factory) {
50 base::Thread* audio_thread = AudioThread::Get();
51 AudioManagerPulse* manager =
52 new AudioManagerPulse(audio_thread->task_runner(),
53 audio_thread->task_runner(), audio_log_factory);
54 if (!manager->Init()) {
55 AudioManager::Destroy(manager);
56 manager = nullptr;
57 }
58 return manager;
59 };
60 };
61 #endif // defined(USE_PULSEAUDIO)
62
63 template <>
64 struct AudioManagerFactory<std::nullptr_t> {
65 static AudioManager* Create(AudioLogFactory* audio_log_factory) {
66 return AudioManager::Create(nullptr, nullptr, nullptr, audio_log_factory);
67 };
68 };
69 } // namespace
70
35 // Test fixture which allows us to override the default enumeration API on 71 // Test fixture which allows us to override the default enumeration API on
36 // Windows. 72 // Windows.
37 class AudioManagerTest : public ::testing::Test { 73 class AudioManagerTest : public ::testing::Test {
38 public: 74 public:
39 void HandleDefaultDeviceIDsTest() { 75 void HandleDefaultDeviceIDsTest() {
40 AudioParameters params(AudioParameters::AUDIO_PCM_LOW_LATENCY, 76 AudioParameters params(AudioParameters::AUDIO_PCM_LOW_LATENCY,
41 CHANNEL_LAYOUT_STEREO, 48000, 16, 2048); 77 CHANNEL_LAYOUT_STEREO, 48000, 16, 2048);
42 78
43 // Create a stream with the default device id "". 79 // Create a stream with the default device id "".
44 AudioOutputStream* stream = 80 AudioOutputStream* stream =
(...skipping 25 matching lines...) Expand all
70 *params = audio_manager_->GetDefaultOutputStreamParameters(); 106 *params = audio_manager_->GetDefaultOutputStreamParameters();
71 } 107 }
72 108
73 void GetAssociatedOutputDeviceID(const std::string& input_device_id, 109 void GetAssociatedOutputDeviceID(const std::string& input_device_id,
74 std::string* output_device_id) { 110 std::string* output_device_id) {
75 *output_device_id = 111 *output_device_id =
76 audio_manager_->GetAssociatedOutputDeviceID(input_device_id); 112 audio_manager_->GetAssociatedOutputDeviceID(input_device_id);
77 } 113 }
78 114
79 protected: 115 protected:
80 AudioManagerTest() : audio_manager_(AudioManager::CreateForTesting()) { 116 AudioManagerTest() { CreateAudioManagerForTesting(); }
81 // Wait for audio thread initialization to complete. Otherwise the 117 ~AudioManagerTest() override {
82 // enumeration type may not have been set yet. 118 if (audio_manager_)
83 base::WaitableEvent event(false, false); 119 AudioManager::Destroy(audio_manager_.release());
84 audio_manager_->GetTaskRunner()->PostTask(FROM_HERE, base::Bind(
85 &base::WaitableEvent::Signal, base::Unretained(&event)));
86 event.Wait();
87 } 120 }
88 121
89 #if defined(OS_WIN) 122 #if defined(OS_WIN)
90 bool SetMMDeviceEnumeration() { 123 bool SetMMDeviceEnumeration() {
91 AudioManagerWin* amw = static_cast<AudioManagerWin*>(audio_manager_.get()); 124 AudioManagerWin* amw = static_cast<AudioManagerWin*>(audio_manager_.get());
92 // Windows Wave is used as default if Windows XP was detected => 125 // Windows Wave is used as default if Windows XP was detected =>
93 // return false since MMDevice is not supported on XP. 126 // return false since MMDevice is not supported on XP.
94 if (amw->enumeration_type() == AudioManagerWin::kWaveEnumeration) 127 if (amw->enumeration_type() == AudioManagerWin::kWaveEnumeration)
95 return false; 128 return false;
96 129
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after
164 return has_devices; 197 return has_devices;
165 } 198 }
166 199
167 bool OutputDevicesAvailable() { 200 bool OutputDevicesAvailable() {
168 bool has_devices = false; 201 bool has_devices = false;
169 RunOnAudioThread(base::Bind(&AudioManagerTest::HasOutputDevicesAvailable, 202 RunOnAudioThread(base::Bind(&AudioManagerTest::HasOutputDevicesAvailable,
170 base::Unretained(this), &has_devices)); 203 base::Unretained(this), &has_devices));
171 return has_devices; 204 return has_devices;
172 } 205 }
173 206
174 #if defined(USE_ALSA) || defined(USE_PULSEAUDIO) 207 template <typename T = std::nullptr_t>
175 template <class T>
176 void CreateAudioManagerForTesting() { 208 void CreateAudioManagerForTesting() {
177 // Only one AudioManager may exist at a time, so destroy the one we're 209 // Only one AudioManager may exist at a time, so destroy the one we're
178 // currently holding before creating a new one. 210 // currently holding before creating a new one.
179 audio_manager_.reset(); 211 if (audio_manager_)
180 audio_manager_.reset(T::Create(&fake_audio_log_factory_)); 212 AudioManager::Destroy(audio_manager_.release());
213 audio_manager_.reset(
214 AudioManagerFactory<T>::Create(&fake_audio_log_factory_));
181 } 215 }
182 #endif
183 216
184 // Synchronously runs the provided callback/closure on the audio thread. 217 // Synchronously runs the provided callback/closure on the audio thread.
185 void RunOnAudioThread(const base::Closure& closure) { 218 void RunOnAudioThread(const base::Closure& closure) {
186 if (!audio_manager_->GetTaskRunner()->BelongsToCurrentThread()) { 219 if (!audio_manager_->GetTaskRunner()->BelongsToCurrentThread()) {
187 base::WaitableEvent event(false, false); 220 base::WaitableEvent event(false, false);
188 audio_manager_->GetTaskRunner()->PostTask( 221 audio_manager_->GetTaskRunner()->PostTask(
189 FROM_HERE, 222 FROM_HERE,
190 base::Bind(&AudioManagerTest::RunOnAudioThreadImpl, 223 base::Bind(&AudioManagerTest::RunOnAudioThreadImpl,
191 base::Unretained(this), 224 base::Unretained(this),
192 closure, 225 closure,
(...skipping 11 matching lines...) Expand all
204 event->Signal(); 237 event->Signal();
205 } 238 }
206 239
207 FakeAudioLogFactory fake_audio_log_factory_; 240 FakeAudioLogFactory fake_audio_log_factory_;
208 scoped_ptr<AudioManager> audio_manager_; 241 scoped_ptr<AudioManager> audio_manager_;
209 }; 242 };
210 243
211 TEST_F(AudioManagerTest, HandleDefaultDeviceIDs) { 244 TEST_F(AudioManagerTest, HandleDefaultDeviceIDs) {
212 // Use a fake manager so we can makeup device ids, this will still use the 245 // Use a fake manager so we can makeup device ids, this will still use the
213 // AudioManagerBase code. 246 // AudioManagerBase code.
214 audio_manager_.reset(new FakeAudioManager(&fake_audio_log_factory_)); 247 CreateAudioManagerForTesting<FakeAudioManager>();
215 RunOnAudioThread(base::Bind(&AudioManagerTest::HandleDefaultDeviceIDsTest, 248 RunOnAudioThread(base::Bind(&AudioManagerTest::HandleDefaultDeviceIDsTest,
216 base::Unretained(this))); 249 base::Unretained(this)));
217 } 250 }
218 251
219 // Test that devices can be enumerated. 252 // Test that devices can be enumerated.
220 TEST_F(AudioManagerTest, EnumerateInputDevices) { 253 TEST_F(AudioManagerTest, EnumerateInputDevices) {
221 ABORT_AUDIO_TEST_IF_NOT(InputDevicesAvailable()); 254 ABORT_AUDIO_TEST_IF_NOT(InputDevicesAvailable());
222 255
223 AudioDeviceNames device_names; 256 AudioDeviceNames device_names;
224 RunOnAudioThread( 257 RunOnAudioThread(
(...skipping 207 matching lines...) Expand 10 before | Expand all | Expand 10 after
432 DVLOG(2) << it->unique_id << " matches with " << output_device_id; 465 DVLOG(2) << it->unique_id << " matches with " << output_device_id;
433 found_an_associated_device = true; 466 found_an_associated_device = true;
434 } 467 }
435 } 468 }
436 469
437 EXPECT_TRUE(found_an_associated_device); 470 EXPECT_TRUE(found_an_associated_device);
438 #endif // defined(OS_WIN) || defined(OS_MACOSX) 471 #endif // defined(OS_WIN) || defined(OS_MACOSX)
439 } 472 }
440 473
441 } // namespace media 474 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698