| OLD | NEW |
| 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/android/build_info.h" | 5 #include "base/android/build_info.h" |
| 6 #include "base/basictypes.h" | 6 #include "base/basictypes.h" |
| 7 #include "base/file_util.h" | 7 #include "base/file_util.h" |
| 8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
| 9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
| 10 #include "base/path_service.h" | 10 #include "base/path_service.h" |
| (...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 78 return std::string("CHANNEL_LAYOUT_UNSUPPORTED"); | 78 return std::string("CHANNEL_LAYOUT_UNSUPPORTED"); |
| 79 } | 79 } |
| 80 } | 80 } |
| 81 | 81 |
| 82 static double ExpectedTimeBetweenCallbacks(AudioParameters params) { | 82 static double ExpectedTimeBetweenCallbacks(AudioParameters params) { |
| 83 return (base::TimeDelta::FromMicroseconds( | 83 return (base::TimeDelta::FromMicroseconds( |
| 84 params.frames_per_buffer() * base::Time::kMicrosecondsPerSecond / | 84 params.frames_per_buffer() * base::Time::kMicrosecondsPerSecond / |
| 85 static_cast<double>(params.sample_rate()))).InMillisecondsF(); | 85 static_cast<double>(params.sample_rate()))).InMillisecondsF(); |
| 86 } | 86 } |
| 87 | 87 |
| 88 // Helper method which verifies that the device list starts with a valid | |
| 89 // default device name followed by non-default device names. | |
| 90 static void CheckDeviceNames(const AudioDeviceNames& device_names) { | |
| 91 VLOG(2) << "Got " << device_names.size() << " audio devices."; | |
| 92 if (device_names.empty()) { | |
| 93 // Log a warning so we can see the status on the build bots. No need to | |
| 94 // break the test though since this does successfully test the code and | |
| 95 // some failure cases. | |
| 96 LOG(WARNING) << "No input devices detected"; | |
| 97 return; | |
| 98 } | |
| 99 | |
| 100 AudioDeviceNames::const_iterator it = device_names.begin(); | |
| 101 | |
| 102 // The first device in the list should always be the default device. | |
| 103 EXPECT_EQ(std::string(AudioManagerBase::kDefaultDeviceName), | |
| 104 it->device_name); | |
| 105 EXPECT_EQ(std::string(AudioManagerBase::kDefaultDeviceId), it->unique_id); | |
| 106 ++it; | |
| 107 | |
| 108 // Other devices should have non-empty name and id and should not contain | |
| 109 // default name or id. | |
| 110 while (it != device_names.end()) { | |
| 111 EXPECT_FALSE(it->device_name.empty()); | |
| 112 EXPECT_FALSE(it->unique_id.empty()); | |
| 113 VLOG(2) << "Device ID(" << it->unique_id | |
| 114 << "), label: " << it->device_name; | |
| 115 EXPECT_NE(std::string(AudioManagerBase::kDefaultDeviceName), | |
| 116 it->device_name); | |
| 117 EXPECT_NE(std::string(AudioManagerBase::kDefaultDeviceId), | |
| 118 it->unique_id); | |
| 119 ++it; | |
| 120 } | |
| 121 } | |
| 122 | |
| 123 std::ostream& operator<<(std::ostream& os, const AudioParameters& params) { | 88 std::ostream& operator<<(std::ostream& os, const AudioParameters& params) { |
| 124 using namespace std; | 89 using namespace std; |
| 125 os << endl << "format: " << FormatToString(params.format()) << endl | 90 os << endl << "format: " << FormatToString(params.format()) << endl |
| 126 << "channel layout: " << LayoutToString(params.channel_layout()) << endl | 91 << "channel layout: " << LayoutToString(params.channel_layout()) << endl |
| 127 << "sample rate: " << params.sample_rate() << endl | 92 << "sample rate: " << params.sample_rate() << endl |
| 128 << "bits per sample: " << params.bits_per_sample() << endl | 93 << "bits per sample: " << params.bits_per_sample() << endl |
| 129 << "frames per buffer: " << params.frames_per_buffer() << endl | 94 << "frames per buffer: " << params.frames_per_buffer() << endl |
| 130 << "channels: " << params.channels() << endl | 95 << "channels: " << params.channels() << endl |
| 131 << "bytes per buffer: " << params.GetBytesPerBuffer() << endl | 96 << "bytes per buffer: " << params.GetBytesPerBuffer() << endl |
| 132 << "bytes per second: " << params.GetBytesPerSecond() << endl | 97 << "bytes per second: " << params.GetBytesPerSecond() << endl |
| (...skipping 462 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 595 | 560 |
| 596 // Check if low-latency output is supported and log the result as output. | 561 // Check if low-latency output is supported and log the result as output. |
| 597 TEST_F(AudioAndroidOutputTest, IsAudioLowLatencySupported) { | 562 TEST_F(AudioAndroidOutputTest, IsAudioLowLatencySupported) { |
| 598 AudioManagerAndroid* manager = | 563 AudioManagerAndroid* manager = |
| 599 static_cast<AudioManagerAndroid*>(audio_manager()); | 564 static_cast<AudioManagerAndroid*>(audio_manager()); |
| 600 bool low_latency = manager->IsAudioLowLatencySupported(); | 565 bool low_latency = manager->IsAudioLowLatencySupported(); |
| 601 low_latency ? VLOG(0) << "Low latency output is supported" | 566 low_latency ? VLOG(0) << "Low latency output is supported" |
| 602 : VLOG(0) << "Low latency output is *not* supported"; | 567 : VLOG(0) << "Low latency output is *not* supported"; |
| 603 } | 568 } |
| 604 | 569 |
| 605 // Verify input device enumeration. | |
| 606 TEST_F(AudioAndroidInputTest, GetAudioInputDeviceNames) { | |
| 607 if (!audio_manager()->HasAudioInputDevices()) | |
| 608 return; | |
| 609 AudioDeviceNames devices; | |
| 610 audio_manager()->GetAudioInputDeviceNames(&devices); | |
| 611 CheckDeviceNames(devices); | |
| 612 } | |
| 613 | |
| 614 // Verify output device enumeration. | |
| 615 TEST_F(AudioAndroidOutputTest, GetAudioOutputDeviceNames) { | |
| 616 if (!audio_manager()->HasAudioOutputDevices()) | |
| 617 return; | |
| 618 AudioDeviceNames devices; | |
| 619 audio_manager()->GetAudioOutputDeviceNames(&devices); | |
| 620 CheckDeviceNames(devices); | |
| 621 } | |
| 622 | |
| 623 // Ensure that a default input stream can be created and closed. | 570 // Ensure that a default input stream can be created and closed. |
| 624 TEST_P(AudioAndroidInputTest, CreateAndCloseInputStream) { | 571 TEST_P(AudioAndroidInputTest, CreateAndCloseInputStream) { |
| 625 AudioParameters params = GetInputStreamParameters(); | 572 AudioParameters params = GetInputStreamParameters(); |
| 626 AudioInputStream* ais = audio_manager()->MakeAudioInputStream( | 573 AudioInputStream* ais = audio_manager()->MakeAudioInputStream( |
| 627 params, AudioManagerBase::kDefaultDeviceId); | 574 params, AudioManagerBase::kDefaultDeviceId); |
| 628 EXPECT_TRUE(ais); | 575 EXPECT_TRUE(ais); |
| 629 ais->Close(); | 576 ais->Close(); |
| 630 } | 577 } |
| 631 | 578 |
| 632 // Ensure that a default output stream can be created and closed. | 579 // Ensure that a default output stream can be created and closed. |
| (...skipping 228 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 861 aos->Stop(); | 808 aos->Stop(); |
| 862 ais->Stop(); | 809 ais->Stop(); |
| 863 aos->Close(); | 810 aos->Close(); |
| 864 ais->Close(); | 811 ais->Close(); |
| 865 } | 812 } |
| 866 | 813 |
| 867 INSTANTIATE_TEST_CASE_P(AudioAndroidInputTest, AudioAndroidInputTest, | 814 INSTANTIATE_TEST_CASE_P(AudioAndroidInputTest, AudioAndroidInputTest, |
| 868 testing::ValuesIn(RunAudioRecordInputPathTests())); | 815 testing::ValuesIn(RunAudioRecordInputPathTests())); |
| 869 | 816 |
| 870 } // namespace media | 817 } // namespace media |
| OLD | NEW |