| /* | 
 |  *  Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. | 
 |  * | 
 |  *  Use of this source code is governed by a BSD-style license | 
 |  *  that can be found in the LICENSE file in the root of the source | 
 |  *  tree. An additional intellectual property rights grant can be found | 
 |  *  in the file PATENTS.  All contributing project authors may | 
 |  *  be found in the AUTHORS file in the root of the source tree. | 
 |  */ | 
 |  | 
 | #include "webrtc/modules/media_file/media_file.h" | 
 | #include "webrtc/system_wrappers/include/sleep.h" | 
 | #include "webrtc/test/gtest.h" | 
 | #include "webrtc/test/testsupport/fileutils.h" | 
 |  | 
 | class MediaFileTest : public testing::Test { | 
 |  protected: | 
 |   void SetUp() { | 
 |     // Use number 0 as the the identifier and pass to CreateMediaFile. | 
 |     media_file_ = webrtc::MediaFile::CreateMediaFile(0); | 
 |     ASSERT_TRUE(media_file_ != NULL); | 
 |   } | 
 |   void TearDown() { | 
 |     webrtc::MediaFile::DestroyMediaFile(media_file_); | 
 |     media_file_ = NULL; | 
 |   } | 
 |   webrtc::MediaFile* media_file_; | 
 | }; | 
 |  | 
 | #if defined(WEBRTC_ANDROID) || defined(WEBRTC_IOS) | 
 | #define MAYBE_StartPlayingAudioFileWithoutError \ | 
 |   DISABLED_StartPlayingAudioFileWithoutError | 
 | #else | 
 | #define MAYBE_StartPlayingAudioFileWithoutError \ | 
 |   StartPlayingAudioFileWithoutError | 
 | #endif | 
 | TEST_F(MediaFileTest, MAYBE_StartPlayingAudioFileWithoutError) { | 
 |   // TODO(leozwang): Use hard coded filename here, we want to | 
 |   // loop through all audio files in future | 
 |   const std::string audio_file = | 
 |       webrtc::test::ResourcePath("voice_engine/audio_tiny48", "wav"); | 
 |   ASSERT_EQ(0, media_file_->StartPlayingAudioFile( | 
 |       audio_file.c_str(), | 
 |       0, | 
 |       false, | 
 |       webrtc::kFileFormatWavFile)); | 
 |  | 
 |   ASSERT_EQ(true, media_file_->IsPlaying()); | 
 |  | 
 |   webrtc::SleepMs(1); | 
 |  | 
 |   ASSERT_EQ(0, media_file_->StopPlaying()); | 
 | } | 
 |  | 
 | #if defined(WEBRTC_IOS) | 
 | #define MAYBE_WriteWavFile DISABLED_WriteWavFile | 
 | #else | 
 | #define MAYBE_WriteWavFile WriteWavFile | 
 | #endif | 
 | TEST_F(MediaFileTest, MAYBE_WriteWavFile) { | 
 |   // Write file. | 
 |   static const size_t kHeaderSize = 44; | 
 |   static const size_t kPayloadSize = 320; | 
 |   webrtc::CodecInst codec = { | 
 |     0, "L16", 16000, static_cast<int>(kPayloadSize), 1 | 
 |   }; | 
 |   std::string outfile = webrtc::test::OutputPath() + "wavtest.wav"; | 
 |   ASSERT_EQ(0, | 
 |             media_file_->StartRecordingAudioFile( | 
 |                 outfile.c_str(), webrtc::kFileFormatWavFile, codec)); | 
 |   static const int8_t kFakeData[kPayloadSize] = {0}; | 
 |   ASSERT_EQ(0, media_file_->IncomingAudioData(kFakeData, kPayloadSize)); | 
 |   ASSERT_EQ(0, media_file_->StopRecording()); | 
 |  | 
 |   // Check the file we just wrote. | 
 |   static const uint8_t kExpectedHeader[] = { | 
 |     'R', 'I', 'F', 'F', | 
 |     0x64, 0x1, 0, 0,  // size of whole file - 8: 320 + 44 - 8 | 
 |     'W', 'A', 'V', 'E', | 
 |     'f', 'm', 't', ' ', | 
 |     0x10, 0, 0, 0,  // size of fmt block - 8: 24 - 8 | 
 |     0x1, 0,  // format: PCM (1) | 
 |     0x1, 0,  // channels: 1 | 
 |     0x80, 0x3e, 0, 0,  // sample rate: 16000 | 
 |     0, 0x7d, 0, 0,  // byte rate: 2 * 16000 | 
 |     0x2, 0,  // block align: NumChannels * BytesPerSample | 
 |     0x10, 0,  // bits per sample: 2 * 8 | 
 |     'd', 'a', 't', 'a', | 
 |     0x40, 0x1, 0, 0,  // size of payload: 320 | 
 |   }; | 
 |   static_assert(sizeof(kExpectedHeader) == kHeaderSize, "header size"); | 
 |  | 
 |   EXPECT_EQ(kHeaderSize + kPayloadSize, webrtc::test::GetFileSize(outfile)); | 
 |   FILE* f = fopen(outfile.c_str(), "rb"); | 
 |   ASSERT_TRUE(f); | 
 |  | 
 |   uint8_t header[kHeaderSize]; | 
 |   ASSERT_EQ(1u, fread(header, kHeaderSize, 1, f)); | 
 |   EXPECT_EQ(0, memcmp(kExpectedHeader, header, kHeaderSize)); | 
 |  | 
 |   uint8_t payload[kPayloadSize]; | 
 |   ASSERT_EQ(1u, fread(payload, kPayloadSize, 1, f)); | 
 |   EXPECT_EQ(0, memcmp(kFakeData, payload, kPayloadSize)); | 
 |  | 
 |   EXPECT_EQ(0, fclose(f)); | 
 | } |