1b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org/* 2b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 3b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org * 4b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org * Use of this source code is governed by a BSD-style license 5b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org * that can be found in the LICENSE file in the root of the source 6b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org * tree. An additional intellectual property rights grant can be found 7b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org * in the file PATENTS. All contributing project authors may 8b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org * be found in the AUTHORS file in the root of the source tree. 9b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org */ 10b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 11471ae72f18e7b23a96b245dbd508386fe139449cpbos@webrtc.org#include "webrtc/test/testsupport/fileutils.h" 12471ae72f18e7b23a96b245dbd508386fe139449cpbos@webrtc.org#include "webrtc/voice_engine/test/auto_test/fixtures/after_streaming_fixture.h" 13471ae72f18e7b23a96b245dbd508386fe139449cpbos@webrtc.org#include "webrtc/voice_engine/test/auto_test/voe_standard_test.h" 14b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 15b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 16b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.orgclass FileTest : public AfterStreamingFixture { 17b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org protected: 18b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org // Creates the string åäö.pcm. 19b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org std::string CreateTrickyFilenameInUtf8() { 20b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org char filename[16] = { (char)0xc3, (char)0xa5, 21b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org (char)0xc3, (char)0xa4, 22b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org (char)0xc3, (char)0xb6, 23b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org static_cast<char>(0) }; 24b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org return std::string(filename) + ".pcm"; 25b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org } 26b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org}; 27b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 28b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.orgTEST_F(FileTest, ManualRecordToFileForThreeSecondsAndPlayback) { 29b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org if (!FLAGS_include_timing_dependent_tests) { 30d1660913e5506f9613f8bbaa39fd1ed0ee97ee6bphoglund@webrtc.org TEST_LOG("Skipping test - running in slow execution environment...\n"); 31b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org return; 32b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org } 33b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 34b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org SwitchToManualMicrophone(); 35b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 36b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org std::string recording_filename = 37b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org webrtc::test::OutputPath() + CreateTrickyFilenameInUtf8(); 38b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 39b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org TEST_LOG("Recording to %s for 3 seconds.\n", recording_filename.c_str()); 40b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org EXPECT_EQ(0, voe_file_->StartRecordingMicrophone(recording_filename.c_str())); 41b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org Sleep(3000); 42b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org EXPECT_EQ(0, voe_file_->StopRecordingMicrophone()); 43b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 44b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org TEST_LOG("Playing back %s.\n", recording_filename.c_str()); 45b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org EXPECT_EQ(0, voe_file_->StartPlayingFileLocally( 46b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org channel_, recording_filename.c_str())); 47b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 487f5e2973967c6ef5859334eb4ccac2c7c0020565henrika@webrtc.org // Play the file to the user and ensure the is-playing-locally. 497f5e2973967c6ef5859334eb4ccac2c7c0020565henrika@webrtc.org // The clip is 3 seconds long. 50b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org Sleep(250); 51b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org EXPECT_EQ(1, voe_file_->IsPlayingFileLocally(channel_)); 52b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org Sleep(1500); 53b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org} 54b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 55b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.orgTEST_F(FileTest, ManualRecordPlayoutToWavFileForThreeSecondsAndPlayback) { 56b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org webrtc::CodecInst send_codec; 57b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org voe_codec_->GetSendCodec(channel_, send_codec); 58b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 59b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org std::string recording_filename = 60b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org webrtc::test::OutputPath() + "playout.wav"; 61b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 62b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org TEST_LOG("Recording playout to %s.\n", recording_filename.c_str()); 63b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org EXPECT_EQ(0, voe_file_->StartRecordingPlayout( 64b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org channel_, recording_filename.c_str(), &send_codec)); 65b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org Sleep(3000); 66b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org EXPECT_EQ(0, voe_file_->StopRecordingPlayout(channel_)); 67b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 68b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org TEST_LOG("Playing back the recording in looping mode.\n"); 69b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org EXPECT_EQ(0, voe_file_->StartPlayingFileAsMicrophone( 70b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org channel_, recording_filename.c_str(), true, false, 71b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org webrtc::kFileFormatWavFile)); 72b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org 73b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org Sleep(2000); 74b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org EXPECT_EQ(1, voe_file_->IsPlayingFileAsMicrophone(channel_)); 75b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org Sleep(2000); 76b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org // We should still be playing since we're looping. 77b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org EXPECT_EQ(1, voe_file_->IsPlayingFileAsMicrophone(channel_)); 78b015cbede88899f67a53fbbe581b02ce8e32794andrew@webrtc.org} 79