diff options
Diffstat (limited to 'media')
-rw-r--r-- | media/audio/audio_output.h | 4 | ||||
-rw-r--r-- | media/audio/win/audio_manager_win.h | 1 | ||||
-rw-r--r-- | media/audio/win/audio_output_win.cc | 5 | ||||
-rw-r--r-- | media/audio/win/audio_output_win_unittest.cc | 18 |
4 files changed, 24 insertions, 4 deletions
diff --git a/media/audio/audio_output.h b/media/audio/audio_output.h index 37235a2..b21d653 100644 --- a/media/audio/audio_output.h +++ b/media/audio/audio_output.h @@ -114,6 +114,10 @@ class AudioManager { // Digital Audio Tape sample rate. static const int kAudioDATSampleRate = 48000; + // Returns true if the OS reports existence of audio devices. This does not + // guarantee that the existing devices support all formats and sample rates. + virtual bool HasAudioDevices() = 0; + // Factory for all the supported stream formats. At this moment |channels| // can be 1 (mono) or 2 (stereo). The |sample_rate| is in hertz and can be // any value supported by the underlying platform. For some future formats diff --git a/media/audio/win/audio_manager_win.h b/media/audio/win/audio_manager_win.h index df9e076..05040ce 100644 --- a/media/audio/win/audio_manager_win.h +++ b/media/audio/win/audio_manager_win.h @@ -20,6 +20,7 @@ class AudioManagerWin : public AudioManager { public: AudioManagerWin() {} // Implementation of AudioManager. + virtual bool HasAudioDevices(); virtual AudioOutputStream* MakeAudioStream(Format format, int channels, int sample_rate, char bits_per_sample); diff --git a/media/audio/win/audio_output_win.cc b/media/audio/win/audio_output_win.cc index 5685ee7..6003fcd 100644 --- a/media/audio/win/audio_output_win.cc +++ b/media/audio/win/audio_output_win.cc @@ -89,6 +89,11 @@ void ReplaceLastMockStream(AudioOutputStreamMockWin* newer) { } // namespace. + +bool AudioManagerWin::HasAudioDevices() { + return (::waveOutGetNumDevs() != 0); +} + // Factory for the implementations of AudioOutputStream. Two implementations // should suffice most windows user's needs. // - PCMWaveOutAudioOutputStream: Based on the waveOutWrite API (in progress) diff --git a/media/audio/win/audio_output_win_unittest.cc b/media/audio/win/audio_output_win_unittest.cc index 1780630..7635420 100644 --- a/media/audio/win/audio_output_win_unittest.cc +++ b/media/audio/win/audio_output_win_unittest.cc @@ -170,6 +170,8 @@ TEST(WinAudioTest, SineWaveAudio16MonoTest) { TEST(WinAudioTest, PCMWaveStreamGetAndClose) { AudioManager* audio_man = AudioManager::GetAudioManager(); ASSERT_TRUE(NULL != audio_man); + if (!audio_man->HasAudioDevices()) + return; AudioOutputStream* oas = audio_man->MakeAudioStream(AudioManager::AUDIO_PCM_LINEAR, 2, 8000, 16); ASSERT_TRUE(NULL != oas); @@ -177,9 +179,11 @@ TEST(WinAudioTest, PCMWaveStreamGetAndClose) { } // Test that it can be opened and closed. -TEST(WinAudioTest, DISABLED_PCMWaveStreamOpenAndClose) { +TEST(WinAudioTest, PCMWaveStreamOpenAndClose) { AudioManager* audio_man = AudioManager::GetAudioManager(); ASSERT_TRUE(NULL != audio_man); + if (!audio_man->HasAudioDevices()) + return; AudioOutputStream* oas = audio_man->MakeAudioStream(AudioManager::AUDIO_PCM_LINEAR, 2, 8000, 16); ASSERT_TRUE(NULL != oas); @@ -189,9 +193,11 @@ TEST(WinAudioTest, DISABLED_PCMWaveStreamOpenAndClose) { // Test that it uses the double buffers correctly. Because it uses the actual // audio device, you might hear a short pop noise for a short time. -TEST(WinAudioTest, DISABLED_PCMWaveStreamDoubleBuffer) { +TEST(WinAudioTest, PCMWaveStreamDoubleBuffer) { AudioManager* audio_man = AudioManager::GetAudioManager(); ASSERT_TRUE(NULL != audio_man); + if (!audio_man->HasAudioDevices()) + return; AudioOutputStream* oas = audio_man->MakeAudioStream(AudioManager::AUDIO_PCM_LINEAR, 1, 16000, 16); ASSERT_TRUE(NULL != oas); @@ -209,9 +215,11 @@ TEST(WinAudioTest, DISABLED_PCMWaveStreamDoubleBuffer) { // This test produces actual audio for 1.5 seconds on the default wave // device at 44.1K s/sec. Parameters have been chosen carefully so you should // not hear pops or noises while the sound is playing. -TEST(WinAudioTest, DISABLED_PCMWaveStreamPlay200HzTone44Kss) { +TEST(WinAudioTest, PCMWaveStreamPlay200HzTone44Kss) { AudioManager* audio_man = AudioManager::GetAudioManager(); ASSERT_TRUE(NULL != audio_man); + if (!audio_man->HasAudioDevices()) + return; AudioOutputStream* oas = audio_man->MakeAudioStream(AudioManager::AUDIO_PCM_LINEAR, 1, AudioManager::kAudioCDSampleRate, 16); @@ -231,9 +239,11 @@ TEST(WinAudioTest, DISABLED_PCMWaveStreamPlay200HzTone44Kss) { // This test produces actual audio for for 1.5 seconds on the default wave // device at 22K s/sec. Parameters have been chosen carefully so you should // not hear pops or noises while the sound is playing. -TEST(WinAudioTest, DISABLED_PCMWaveStreamPlay200HzTone22Kss) { +TEST(WinAudioTest, PCMWaveStreamPlay200HzTone22Kss) { AudioManager* audio_man = AudioManager::GetAudioManager(); ASSERT_TRUE(NULL != audio_man); + if (!audio_man->HasAudioDevices()) + return; AudioOutputStream* oas = audio_man->MakeAudioStream(AudioManager::AUDIO_PCM_LINEAR, 1, AudioManager::kAudioCDSampleRate/2, 16); |