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