| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/browser/renderer_host/media/media_devices_manager.h" | 5 #include "content/browser/renderer_host/media/media_devices_manager.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| 11 #include "base/macros.h" | 11 #include "base/macros.h" |
| 12 #include "base/memory/ref_counted.h" | 12 #include "base/memory/ref_counted.h" |
| 13 #include "base/run_loop.h" | 13 #include "base/run_loop.h" |
| 14 #include "base/strings/string_number_conversions.h" | 14 #include "base/strings/string_number_conversions.h" |
| 15 #include "base/threading/thread_task_runner_handle.h" | 15 #include "base/threading/thread_task_runner_handle.h" |
| 16 #include "content/browser/renderer_host/media/video_capture_manager.h" | 16 #include "content/browser/renderer_host/media/video_capture_manager.h" |
| 17 #include "content/public/test/test_browser_thread_bundle.h" | 17 #include "content/public/test/test_browser_thread_bundle.h" |
| 18 #include "media/audio/audio_device_name.h" | 18 #include "media/audio/audio_device_name.h" |
| 19 #include "media/audio/audio_system_impl.h" |
| 19 #include "media/audio/fake_audio_log_factory.h" | 20 #include "media/audio/fake_audio_log_factory.h" |
| 20 #include "media/audio/fake_audio_manager.h" | 21 #include "media/audio/fake_audio_manager.h" |
| 21 #include "media/capture/video/fake_video_capture_device_factory.h" | 22 #include "media/capture/video/fake_video_capture_device_factory.h" |
| 22 #include "testing/gmock/include/gmock/gmock.h" | 23 #include "testing/gmock/include/gmock/gmock.h" |
| 23 #include "testing/gtest/include/gtest/gtest.h" | 24 #include "testing/gtest/include/gtest/gtest.h" |
| 24 | 25 |
| 25 using testing::_; | 26 using testing::_; |
| 26 using testing::SaveArg; | 27 using testing::SaveArg; |
| 27 | 28 |
| 28 namespace content { | 29 namespace content { |
| (...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 133 | 134 |
| 134 void EnumerateCallback(base::RunLoop* run_loop, | 135 void EnumerateCallback(base::RunLoop* run_loop, |
| 135 const MediaDeviceEnumeration& result) { | 136 const MediaDeviceEnumeration& result) { |
| 136 MockCallback(result); | 137 MockCallback(result); |
| 137 run_loop->Quit(); | 138 run_loop->Quit(); |
| 138 } | 139 } |
| 139 | 140 |
| 140 protected: | 141 protected: |
| 141 void SetUp() override { | 142 void SetUp() override { |
| 142 audio_manager_.reset(new MockAudioManager()); | 143 audio_manager_.reset(new MockAudioManager()); |
| 144 audio_system_ = media::AudioSystemImpl::Create(audio_manager_.get()); |
| 143 video_capture_manager_ = new VideoCaptureManager( | 145 video_capture_manager_ = new VideoCaptureManager( |
| 144 std::unique_ptr<media::VideoCaptureDeviceFactory>( | 146 std::unique_ptr<media::VideoCaptureDeviceFactory>( |
| 145 new MockVideoCaptureDeviceFactory()), | 147 new MockVideoCaptureDeviceFactory()), |
| 146 base::ThreadTaskRunnerHandle::Get()); | 148 base::ThreadTaskRunnerHandle::Get()); |
| 147 video_capture_device_factory_ = static_cast<MockVideoCaptureDeviceFactory*>( | 149 video_capture_device_factory_ = static_cast<MockVideoCaptureDeviceFactory*>( |
| 148 video_capture_manager_->video_capture_device_factory()); | 150 video_capture_manager_->video_capture_device_factory()); |
| 149 media_devices_manager_.reset(new MediaDevicesManager( | 151 media_devices_manager_.reset(new MediaDevicesManager( |
| 150 audio_manager_.get(), video_capture_manager_, nullptr)); | 152 audio_system_.get(), video_capture_manager_, nullptr)); |
| 151 } | 153 } |
| 152 | 154 |
| 153 void EnableCache(MediaDeviceType type) { | 155 void EnableCache(MediaDeviceType type) { |
| 154 media_devices_manager_->SetCachePolicy( | 156 media_devices_manager_->SetCachePolicy( |
| 155 type, MediaDevicesManager::CachePolicy::SYSTEM_MONITOR); | 157 type, MediaDevicesManager::CachePolicy::SYSTEM_MONITOR); |
| 156 } | 158 } |
| 157 | 159 |
| 158 // Must outlive MediaDevicesManager as ~MediaDevicesManager() verifies it's | 160 // Must outlive MediaDevicesManager as ~MediaDevicesManager() verifies it's |
| 159 // running on the IO thread. | 161 // running on the IO thread. |
| 160 TestBrowserThreadBundle thread_bundle_; | 162 TestBrowserThreadBundle thread_bundle_; |
| 161 | 163 |
| 162 std::unique_ptr<MediaDevicesManager> media_devices_manager_; | 164 std::unique_ptr<MediaDevicesManager> media_devices_manager_; |
| 163 scoped_refptr<VideoCaptureManager> video_capture_manager_; | 165 scoped_refptr<VideoCaptureManager> video_capture_manager_; |
| 164 MockVideoCaptureDeviceFactory* video_capture_device_factory_; | 166 MockVideoCaptureDeviceFactory* video_capture_device_factory_; |
| 165 std::unique_ptr<MockAudioManager, media::AudioManagerDeleter> audio_manager_; | 167 std::unique_ptr<MockAudioManager, media::AudioManagerDeleter> audio_manager_; |
| 168 std::unique_ptr<media::AudioSystem> audio_system_; |
| 166 | 169 |
| 167 private: | 170 private: |
| 168 DISALLOW_COPY_AND_ASSIGN(MediaDevicesManagerTest); | 171 DISALLOW_COPY_AND_ASSIGN(MediaDevicesManagerTest); |
| 169 }; | 172 }; |
| 170 | 173 |
| 171 TEST_F(MediaDevicesManagerTest, EnumerateNoCacheAudioInput) { | 174 TEST_F(MediaDevicesManagerTest, EnumerateNoCacheAudioInput) { |
| 172 EXPECT_CALL(*audio_manager_, MockGetAudioInputDeviceNames(_)) | 175 EXPECT_CALL(*audio_manager_, MockGetAudioInputDeviceNames(_)) |
| 173 .Times(kNumCalls); | 176 .Times(kNumCalls); |
| 174 EXPECT_CALL(*video_capture_device_factory_, MockGetDeviceDescriptors()) | 177 EXPECT_CALL(*video_capture_device_factory_, MockGetDeviceDescriptors()) |
| 175 .Times(0); | 178 .Times(0); |
| (...skipping 390 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 566 media_devices_manager_->OnDevicesChanged(base::SystemMonitor::DEVTYPE_AUDIO); | 569 media_devices_manager_->OnDevicesChanged(base::SystemMonitor::DEVTYPE_AUDIO); |
| 567 media_devices_manager_->OnDevicesChanged( | 570 media_devices_manager_->OnDevicesChanged( |
| 568 base::SystemMonitor::DEVTYPE_VIDEO_CAPTURE); | 571 base::SystemMonitor::DEVTYPE_VIDEO_CAPTURE); |
| 569 base::RunLoop().RunUntilIdle(); | 572 base::RunLoop().RunUntilIdle(); |
| 570 EXPECT_EQ(num_audio_input_devices, notification_all_audio_input.size()); | 573 EXPECT_EQ(num_audio_input_devices, notification_all_audio_input.size()); |
| 571 EXPECT_EQ(num_video_input_devices, notification_all_video_input.size()); | 574 EXPECT_EQ(num_video_input_devices, notification_all_video_input.size()); |
| 572 EXPECT_EQ(num_audio_output_devices, notification_all_audio_output.size()); | 575 EXPECT_EQ(num_audio_output_devices, notification_all_audio_output.size()); |
| 573 } | 576 } |
| 574 | 577 |
| 575 } // namespace content | 578 } // namespace content |
| OLD | NEW |