This CL was generated by running git ls-files | grep -P "(\.h|\.cc)$" | grep -v 'sdk/' | grep -v 'rtc_base/ssl_' | \ grep -v 'fake_rtc_certificate_generator.h' | grep -v 'modules/audio_device/win/' | \ grep -v 'system_wrappers/source/clock.cc' | grep -v 'rtc_base/trace_event.h' | \ grep -v 'modules/audio_coding/codecs/ilbc/' | grep -v 'screen_capturer_mac.h' | \ grep -v 'spl_inl_mips.h' | grep -v 'data_size_unittest.cc' | grep -v 'timestamp_unittest.cc' \ | xargs clang-format -i ; git cl format Most of these changes are clang-format grouping and reordering includes differently. Bug: webrtc:9340 Change-Id: Ic83ddbc169bfacd21883e381b5181c3dd4fe8a63 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/144051 Commit-Queue: Jonas Olsson <jonasolsson@webrtc.org> Reviewed-by: Karl Wiberg <kwiberg@webrtc.org> Cr-Commit-Position: refs/heads/master@{#28505}
114 lines
3.7 KiB
C++
114 lines
3.7 KiB
C++
/*
|
|
* Copyright (c) 2017 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 "audio/test/audio_end_to_end_test.h"
|
|
|
|
#include <algorithm>
|
|
|
|
#include "absl/memory/memory.h"
|
|
#include "call/fake_network_pipe.h"
|
|
#include "call/simulated_network.h"
|
|
#include "system_wrappers/include/sleep.h"
|
|
#include "test/gtest.h"
|
|
|
|
namespace webrtc {
|
|
namespace test {
|
|
namespace {
|
|
// Wait half a second between stopping sending and stopping receiving audio.
|
|
constexpr int kExtraRecordTimeMs = 500;
|
|
|
|
constexpr int kSampleRate = 48000;
|
|
} // namespace
|
|
|
|
AudioEndToEndTest::AudioEndToEndTest()
|
|
: EndToEndTest(CallTest::kDefaultTimeoutMs) {}
|
|
|
|
BuiltInNetworkBehaviorConfig AudioEndToEndTest::GetNetworkPipeConfig() const {
|
|
return BuiltInNetworkBehaviorConfig();
|
|
}
|
|
|
|
size_t AudioEndToEndTest::GetNumVideoStreams() const {
|
|
return 0;
|
|
}
|
|
|
|
size_t AudioEndToEndTest::GetNumAudioStreams() const {
|
|
return 1;
|
|
}
|
|
|
|
size_t AudioEndToEndTest::GetNumFlexfecStreams() const {
|
|
return 0;
|
|
}
|
|
|
|
std::unique_ptr<TestAudioDeviceModule::Capturer>
|
|
AudioEndToEndTest::CreateCapturer() {
|
|
return TestAudioDeviceModule::CreatePulsedNoiseCapturer(32000, kSampleRate);
|
|
}
|
|
|
|
std::unique_ptr<TestAudioDeviceModule::Renderer>
|
|
AudioEndToEndTest::CreateRenderer() {
|
|
return TestAudioDeviceModule::CreateDiscardRenderer(kSampleRate);
|
|
}
|
|
|
|
void AudioEndToEndTest::OnFakeAudioDevicesCreated(
|
|
TestAudioDeviceModule* send_audio_device,
|
|
TestAudioDeviceModule* recv_audio_device) {
|
|
send_audio_device_ = send_audio_device;
|
|
}
|
|
|
|
test::PacketTransport* AudioEndToEndTest::CreateSendTransport(
|
|
SingleThreadedTaskQueueForTesting* task_queue,
|
|
Call* sender_call) {
|
|
return new test::PacketTransport(
|
|
task_queue, sender_call, this, test::PacketTransport::kSender,
|
|
test::CallTest::payload_type_map_,
|
|
absl::make_unique<FakeNetworkPipe>(
|
|
Clock::GetRealTimeClock(),
|
|
absl::make_unique<SimulatedNetwork>(GetNetworkPipeConfig())));
|
|
}
|
|
|
|
test::PacketTransport* AudioEndToEndTest::CreateReceiveTransport(
|
|
SingleThreadedTaskQueueForTesting* task_queue) {
|
|
return new test::PacketTransport(
|
|
task_queue, nullptr, this, test::PacketTransport::kReceiver,
|
|
test::CallTest::payload_type_map_,
|
|
absl::make_unique<FakeNetworkPipe>(
|
|
Clock::GetRealTimeClock(),
|
|
absl::make_unique<SimulatedNetwork>(GetNetworkPipeConfig())));
|
|
}
|
|
|
|
void AudioEndToEndTest::ModifyAudioConfigs(
|
|
AudioSendStream::Config* send_config,
|
|
std::vector<AudioReceiveStream::Config>* receive_configs) {
|
|
// Large bitrate by default.
|
|
const webrtc::SdpAudioFormat kDefaultFormat("opus", 48000, 2,
|
|
{{"stereo", "1"}});
|
|
send_config->send_codec_spec = AudioSendStream::Config::SendCodecSpec(
|
|
test::CallTest::kAudioSendPayloadType, kDefaultFormat);
|
|
}
|
|
|
|
void AudioEndToEndTest::OnAudioStreamsCreated(
|
|
AudioSendStream* send_stream,
|
|
const std::vector<AudioReceiveStream*>& receive_streams) {
|
|
ASSERT_NE(nullptr, send_stream);
|
|
ASSERT_EQ(1u, receive_streams.size());
|
|
ASSERT_NE(nullptr, receive_streams[0]);
|
|
send_stream_ = send_stream;
|
|
receive_stream_ = receive_streams[0];
|
|
}
|
|
|
|
void AudioEndToEndTest::PerformTest() {
|
|
// Wait until the input audio file is done...
|
|
send_audio_device_->WaitForRecordingEnd();
|
|
// and some extra time to account for network delay.
|
|
SleepMs(GetNetworkPipeConfig().queue_delay_ms + kExtraRecordTimeMs);
|
|
}
|
|
} // namespace test
|
|
} // namespace webrtc
|