OLD | NEW |
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 // MSVC++ requires this to be set before any other includes to get M_PI. | 5 // MSVC++ requires this to be set before any other includes to get M_PI. |
6 #define _USE_MATH_DEFINES | 6 #define _USE_MATH_DEFINES |
7 | 7 |
8 #include "media/base/audio_renderer_mixer.h" | 8 #include "media/base/audio_renderer_mixer.h" |
9 | 9 |
10 #include <stddef.h> | 10 #include <stddef.h> |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
81 expected_audio_bus_ = AudioBus::Create(output_parameters_); | 81 expected_audio_bus_ = AudioBus::Create(output_parameters_); |
82 | 82 |
83 // Allocate one callback for generating expected results. | 83 // Allocate one callback for generating expected results. |
84 double step = kSineCycles / static_cast<double>( | 84 double step = kSineCycles / static_cast<double>( |
85 output_parameters_.frames_per_buffer()); | 85 output_parameters_.frames_per_buffer()); |
86 expected_callback_.reset(new FakeAudioRenderCallback(step)); | 86 expected_callback_.reset(new FakeAudioRenderCallback(step)); |
87 } | 87 } |
88 | 88 |
89 AudioRendererMixer* GetMixer(int owner_id, | 89 AudioRendererMixer* GetMixer(int owner_id, |
90 const AudioParameters& params, | 90 const AudioParameters& params, |
| 91 AudioLatency::LatencyType latency, |
91 const std::string& device_id, | 92 const std::string& device_id, |
92 const url::Origin& security_origin, | 93 const url::Origin& security_origin, |
93 OutputDeviceStatus* device_status) final { | 94 OutputDeviceStatus* device_status) final { |
94 return mixer_.get(); | 95 return mixer_.get(); |
95 }; | 96 }; |
96 | 97 |
97 MOCK_METHOD4(ReturnMixer, | 98 MOCK_METHOD1(ReturnMixer, void(const AudioRendererMixer*)); |
98 void(int, | |
99 const AudioParameters&, | |
100 const std::string&, | |
101 const url::Origin&)); | |
102 | 99 |
103 MOCK_METHOD4( | 100 MOCK_METHOD4( |
104 GetOutputDeviceInfo, | 101 GetOutputDeviceInfo, |
105 OutputDeviceInfo(int, int, const std::string&, const url::Origin&)); | 102 OutputDeviceInfo(int, int, const std::string&, const url::Origin&)); |
106 | 103 |
107 void InitializeInputs(int inputs_per_sample_rate) { | 104 void InitializeInputs(int inputs_per_sample_rate) { |
108 mixer_inputs_.reserve(inputs_per_sample_rate * input_parameters_.size()); | 105 mixer_inputs_.reserve(inputs_per_sample_rate * input_parameters_.size()); |
109 fake_callbacks_.reserve(inputs_per_sample_rate * input_parameters_.size()); | 106 fake_callbacks_.reserve(inputs_per_sample_rate * input_parameters_.size()); |
110 | 107 |
111 for (size_t i = 0, input = 0; i < input_parameters_.size(); ++i) { | 108 for (size_t i = 0, input = 0; i < input_parameters_.size(); ++i) { |
(...skipping 214 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
326 std::max(1.f, static_cast<float>(floor(mixer_inputs_.size() / 2.f))))); | 323 std::max(1.f, static_cast<float>(floor(mixer_inputs_.size() / 2.f))))); |
327 | 324 |
328 for (size_t i = 1; i < mixer_inputs_.size(); i += 2) | 325 for (size_t i = 1; i < mixer_inputs_.size(); i += 2) |
329 mixer_inputs_[i]->Stop(); | 326 mixer_inputs_[i]->Stop(); |
330 } | 327 } |
331 | 328 |
332 scoped_refptr<AudioRendererMixerInput> CreateMixerInput() { | 329 scoped_refptr<AudioRendererMixerInput> CreateMixerInput() { |
333 return new AudioRendererMixerInput( | 330 return new AudioRendererMixerInput( |
334 this, | 331 this, |
335 // Zero frame id, default device ID and security origin. | 332 // Zero frame id, default device ID and security origin. |
336 0, std::string(), url::Origin()); | 333 0, std::string(), url::Origin(), AudioLatency::LATENCY_PLAYBACK); |
337 } | 334 } |
338 | 335 |
339 protected: | 336 protected: |
340 virtual ~AudioRendererMixerTest() {} | 337 virtual ~AudioRendererMixerTest() {} |
341 | 338 |
342 scoped_refptr<MockAudioRendererSink> sink_; | 339 scoped_refptr<MockAudioRendererSink> sink_; |
343 std::unique_ptr<AudioRendererMixer> mixer_; | 340 std::unique_ptr<AudioRendererMixer> mixer_; |
344 AudioRendererSink::RenderCallback* mixer_callback_; | 341 AudioRendererSink::RenderCallback* mixer_callback_; |
345 std::vector<AudioParameters> input_parameters_; | 342 std::vector<AudioParameters> input_parameters_; |
346 AudioParameters output_parameters_; | 343 AudioParameters output_parameters_; |
(...skipping 200 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
547 INSTANTIATE_TEST_CASE_P( | 544 INSTANTIATE_TEST_CASE_P( |
548 AudioRendererMixerBehavioralTest, | 545 AudioRendererMixerBehavioralTest, |
549 AudioRendererMixerBehavioralTest, | 546 AudioRendererMixerBehavioralTest, |
550 testing::ValuesIn(std::vector<AudioRendererMixerTestData>( | 547 testing::ValuesIn(std::vector<AudioRendererMixerTestData>( |
551 1, | 548 1, |
552 std::tr1::make_tuple(&kTestInputLower, | 549 std::tr1::make_tuple(&kTestInputLower, |
553 1, | 550 1, |
554 kTestInputLower, | 551 kTestInputLower, |
555 0.00000048)))); | 552 0.00000048)))); |
556 } // namespace media | 553 } // namespace media |
OLD | NEW |