aboutsummaryrefslogtreecommitdiff
path: root/webrtc/test/call_test.cc
diff options
context:
space:
mode:
Diffstat (limited to 'webrtc/test/call_test.cc')
-rw-r--r--webrtc/test/call_test.cc394
1 files changed, 297 insertions, 97 deletions
diff --git a/webrtc/test/call_test.cc b/webrtc/test/call_test.cc
index 0a8b686974..e9651e33f5 100644
--- a/webrtc/test/call_test.cc
+++ b/webrtc/test/call_test.cc
@@ -7,8 +7,15 @@
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
+#include "webrtc/base/checks.h"
+#include "webrtc/common.h"
+#include "webrtc/config.h"
#include "webrtc/test/call_test.h"
#include "webrtc/test/encoder_settings.h"
+#include "webrtc/test/testsupport/fileutils.h"
+#include "webrtc/voice_engine/include/voe_base.h"
+#include "webrtc/voice_engine/include/voe_codec.h"
+#include "webrtc/voice_engine/include/voe_network.h"
namespace webrtc {
namespace test {
@@ -19,25 +26,43 @@ const int kVideoRotationRtpExtensionId = 4;
CallTest::CallTest()
: clock_(Clock::GetRealTimeClock()),
- send_config_(nullptr),
- send_stream_(NULL),
- fake_encoder_(clock_) {
-}
+ video_send_config_(nullptr),
+ video_send_stream_(nullptr),
+ audio_send_config_(nullptr),
+ audio_send_stream_(nullptr),
+ fake_encoder_(clock_),
+ num_video_streams_(1),
+ num_audio_streams_(0),
+ fake_send_audio_device_(nullptr),
+ fake_recv_audio_device_(nullptr) {}
CallTest::~CallTest() {
}
-void CallTest::RunBaseTest(BaseTest* test,
- const FakeNetworkPipe::Config& config) {
- CreateSenderCall(test->GetSenderCallConfig());
- if (test->ShouldCreateReceivers())
- CreateReceiverCall(test->GetReceiverCallConfig());
- send_transport_.reset(new PacketTransport(
- sender_call_.get(), test, test::PacketTransport::kSender, config));
- receive_transport_.reset(new PacketTransport(
- nullptr, test, test::PacketTransport::kReceiver, config));
- test->OnTransportsCreated(send_transport_.get(), receive_transport_.get());
+void CallTest::RunBaseTest(BaseTest* test) {
+ num_video_streams_ = test->GetNumVideoStreams();
+ num_audio_streams_ = test->GetNumAudioStreams();
+ RTC_DCHECK(num_video_streams_ > 0 || num_audio_streams_ > 0);
+ Call::Config send_config(test->GetSenderCallConfig());
+ if (num_audio_streams_ > 0) {
+ CreateVoiceEngines();
+ AudioState::Config audio_state_config;
+ audio_state_config.voice_engine = voe_send_.voice_engine;
+ send_config.audio_state = AudioState::Create(audio_state_config);
+ }
+ CreateSenderCall(send_config);
+ if (test->ShouldCreateReceivers()) {
+ Call::Config recv_config(test->GetReceiverCallConfig());
+ if (num_audio_streams_ > 0) {
+ AudioState::Config audio_state_config;
+ audio_state_config.voice_engine = voe_recv_.voice_engine;
+ recv_config.audio_state = AudioState::Create(audio_state_config);
+ }
+ CreateReceiverCall(recv_config);
+ }
test->OnCallsCreated(sender_call_.get(), receiver_call_.get());
+ send_transport_.reset(test->CreateSendTransport(sender_call_.get()));
+ receive_transport_.reset(test->CreateReceiveTransport());
if (test->ShouldCreateReceivers()) {
send_transport_->SetReceiver(receiver_call_->Receiver());
@@ -48,16 +73,34 @@ void CallTest::RunBaseTest(BaseTest* test,
receive_transport_->SetReceiver(nullptr);
}
- CreateSendConfig(test->GetNumStreams(), send_transport_.get());
+ CreateSendConfig(num_video_streams_, num_audio_streams_,
+ send_transport_.get());
if (test->ShouldCreateReceivers()) {
CreateMatchingReceiveConfigs(receive_transport_.get());
}
- test->ModifyConfigs(&send_config_, &receive_configs_, &encoder_config_);
- CreateStreams();
- test->OnStreamsCreated(send_stream_, receive_streams_);
+ if (num_audio_streams_ > 0)
+ SetupVoiceEngineTransports(send_transport_.get(), receive_transport_.get());
+
+ if (num_video_streams_ > 0) {
+ test->ModifyVideoConfigs(&video_send_config_, &video_receive_configs_,
+ &video_encoder_config_);
+ }
+ if (num_audio_streams_ > 0)
+ test->ModifyAudioConfigs(&audio_send_config_, &audio_receive_configs_);
- CreateFrameGeneratorCapturer();
- test->OnFrameGeneratorCapturerCreated(frame_generator_capturer_.get());
+ if (num_video_streams_ > 0) {
+ CreateVideoStreams();
+ test->OnVideoStreamsCreated(video_send_stream_, video_receive_streams_);
+ }
+ if (num_audio_streams_ > 0) {
+ CreateAudioStreams();
+ test->OnAudioStreamsCreated(audio_send_stream_, audio_receive_streams_);
+ }
+
+ if (num_video_streams_ > 0) {
+ CreateFrameGeneratorCapturer();
+ test->OnFrameGeneratorCapturerCreated(frame_generator_capturer_.get());
+ }
Start();
test->PerformTest();
@@ -66,12 +109,28 @@ void CallTest::RunBaseTest(BaseTest* test,
Stop();
DestroyStreams();
+ DestroyCalls();
+ if (num_audio_streams_ > 0)
+ DestroyVoiceEngines();
}
void CallTest::Start() {
- send_stream_->Start();
- for (size_t i = 0; i < receive_streams_.size(); ++i)
- receive_streams_[i]->Start();
+ if (video_send_stream_)
+ video_send_stream_->Start();
+ for (VideoReceiveStream* video_recv_stream : video_receive_streams_)
+ video_recv_stream->Start();
+ if (audio_send_stream_) {
+ fake_send_audio_device_->Start();
+ audio_send_stream_->Start();
+ EXPECT_EQ(0, voe_send_.base->StartSend(voe_send_.channel_id));
+ }
+ for (AudioReceiveStream* audio_recv_stream : audio_receive_streams_)
+ audio_recv_stream->Start();
+ if (!audio_receive_streams_.empty()) {
+ fake_recv_audio_device_->Start();
+ EXPECT_EQ(0, voe_recv_.base->StartPlayout(voe_recv_.channel_id));
+ EXPECT_EQ(0, voe_recv_.base->StartReceive(voe_recv_.channel_id));
+ }
if (frame_generator_capturer_.get() != NULL)
frame_generator_capturer_->Start();
}
@@ -79,9 +138,22 @@ void CallTest::Start() {
void CallTest::Stop() {
if (frame_generator_capturer_.get() != NULL)
frame_generator_capturer_->Stop();
- for (size_t i = 0; i < receive_streams_.size(); ++i)
- receive_streams_[i]->Stop();
- send_stream_->Stop();
+ if (!audio_receive_streams_.empty()) {
+ fake_recv_audio_device_->Stop();
+ EXPECT_EQ(0, voe_recv_.base->StopReceive(voe_recv_.channel_id));
+ EXPECT_EQ(0, voe_recv_.base->StopPlayout(voe_recv_.channel_id));
+ }
+ for (AudioReceiveStream* audio_recv_stream : audio_receive_streams_)
+ audio_recv_stream->Stop();
+ if (audio_send_stream_) {
+ fake_send_audio_device_->Stop();
+ EXPECT_EQ(0, voe_send_.base->StopSend(voe_send_.channel_id));
+ audio_send_stream_->Stop();
+ }
+ for (VideoReceiveStream* video_recv_stream : video_receive_streams_)
+ video_recv_stream->Stop();
+ if (video_send_stream_)
+ video_send_stream_->Stop();
}
void CallTest::CreateCalls(const Call::Config& sender_config,
@@ -99,92 +171,203 @@ void CallTest::CreateReceiverCall(const Call::Config& config) {
}
void CallTest::DestroyCalls() {
- sender_call_.reset(nullptr);
- receiver_call_.reset(nullptr);
+ sender_call_.reset();
+ receiver_call_.reset();
}
-void CallTest::CreateSendConfig(size_t num_streams,
+void CallTest::CreateSendConfig(size_t num_video_streams,
+ size_t num_audio_streams,
Transport* send_transport) {
- assert(num_streams <= kNumSsrcs);
- send_config_ = VideoSendStream::Config(send_transport);
- send_config_.encoder_settings.encoder = &fake_encoder_;
- send_config_.encoder_settings.payload_name = "FAKE";
- send_config_.encoder_settings.payload_type = kFakeSendPayloadType;
- send_config_.rtp.extensions.push_back(
- RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeExtensionId));
- encoder_config_.streams = test::CreateVideoStreams(num_streams);
- for (size_t i = 0; i < num_streams; ++i)
- send_config_.rtp.ssrcs.push_back(kSendSsrcs[i]);
- send_config_.rtp.extensions.push_back(
- RtpExtension(RtpExtension::kVideoRotation, kVideoRotationRtpExtensionId));
-}
-
-void CallTest::CreateMatchingReceiveConfigs(
- Transport* rtcp_send_transport) {
- assert(!send_config_.rtp.ssrcs.empty());
- assert(receive_configs_.empty());
- assert(allocated_decoders_.empty());
- VideoReceiveStream::Config config(rtcp_send_transport);
- config.rtp.remb = true;
- config.rtp.local_ssrc = kReceiverLocalSsrc;
- for (const RtpExtension& extension : send_config_.rtp.extensions)
- config.rtp.extensions.push_back(extension);
- for (size_t i = 0; i < send_config_.rtp.ssrcs.size(); ++i) {
- VideoReceiveStream::Decoder decoder =
- test::CreateMatchingDecoder(send_config_.encoder_settings);
- allocated_decoders_.push_back(decoder.decoder);
- config.decoders.clear();
- config.decoders.push_back(decoder);
- config.rtp.remote_ssrc = send_config_.rtp.ssrcs[i];
- receive_configs_.push_back(config);
+ RTC_DCHECK(num_video_streams <= kNumSsrcs);
+ RTC_DCHECK_LE(num_audio_streams, 1u);
+ RTC_DCHECK(num_audio_streams == 0 || voe_send_.channel_id >= 0);
+ if (num_video_streams > 0) {
+ video_send_config_ = VideoSendStream::Config(send_transport);
+ video_send_config_.encoder_settings.encoder = &fake_encoder_;
+ video_send_config_.encoder_settings.payload_name = "FAKE";
+ video_send_config_.encoder_settings.payload_type =
+ kFakeVideoSendPayloadType;
+ video_send_config_.rtp.extensions.push_back(
+ RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeExtensionId));
+ video_encoder_config_.streams = test::CreateVideoStreams(num_video_streams);
+ for (size_t i = 0; i < num_video_streams; ++i)
+ video_send_config_.rtp.ssrcs.push_back(kVideoSendSsrcs[i]);
+ video_send_config_.rtp.extensions.push_back(RtpExtension(
+ RtpExtension::kVideoRotation, kVideoRotationRtpExtensionId));
+ }
+
+ if (num_audio_streams > 0) {
+ audio_send_config_ = AudioSendStream::Config(send_transport);
+ audio_send_config_.voe_channel_id = voe_send_.channel_id;
+ audio_send_config_.rtp.ssrc = kAudioSendSsrc;
+ }
+}
+
+void CallTest::CreateMatchingReceiveConfigs(Transport* rtcp_send_transport) {
+ RTC_DCHECK(video_receive_configs_.empty());
+ RTC_DCHECK(allocated_decoders_.empty());
+ if (num_video_streams_ > 0) {
+ RTC_DCHECK(!video_send_config_.rtp.ssrcs.empty());
+ VideoReceiveStream::Config video_config(rtcp_send_transport);
+ video_config.rtp.remb = true;
+ video_config.rtp.local_ssrc = kReceiverLocalVideoSsrc;
+ for (const RtpExtension& extension : video_send_config_.rtp.extensions)
+ video_config.rtp.extensions.push_back(extension);
+ for (size_t i = 0; i < video_send_config_.rtp.ssrcs.size(); ++i) {
+ VideoReceiveStream::Decoder decoder =
+ test::CreateMatchingDecoder(video_send_config_.encoder_settings);
+ allocated_decoders_.push_back(decoder.decoder);
+ video_config.decoders.clear();
+ video_config.decoders.push_back(decoder);
+ video_config.rtp.remote_ssrc = video_send_config_.rtp.ssrcs[i];
+ video_receive_configs_.push_back(video_config);
+ }
+ }
+
+ RTC_DCHECK(num_audio_streams_ <= 1);
+ if (num_audio_streams_ == 1) {
+ RTC_DCHECK(voe_send_.channel_id >= 0);
+ AudioReceiveStream::Config audio_config;
+ audio_config.rtp.local_ssrc = kReceiverLocalAudioSsrc;
+ audio_config.rtcp_send_transport = rtcp_send_transport;
+ audio_config.voe_channel_id = voe_recv_.channel_id;
+ audio_config.rtp.remote_ssrc = audio_send_config_.rtp.ssrc;
+ audio_receive_configs_.push_back(audio_config);
}
}
void CallTest::CreateFrameGeneratorCapturer() {
- VideoStream stream = encoder_config_.streams.back();
- frame_generator_capturer_.reset(
- test::FrameGeneratorCapturer::Create(send_stream_->Input(),
- stream.width,
- stream.height,
- stream.max_framerate,
- clock_));
+ VideoStream stream = video_encoder_config_.streams.back();
+ frame_generator_capturer_.reset(test::FrameGeneratorCapturer::Create(
+ video_send_stream_->Input(), stream.width, stream.height,
+ stream.max_framerate, clock_));
}
-void CallTest::CreateStreams() {
- assert(send_stream_ == NULL);
- assert(receive_streams_.empty());
+void CallTest::CreateFakeAudioDevices() {
+ fake_send_audio_device_.reset(new FakeAudioDevice(
+ clock_, test::ResourcePath("voice_engine/audio_long16", "pcm")));
+ fake_recv_audio_device_.reset(new FakeAudioDevice(
+ clock_, test::ResourcePath("voice_engine/audio_long16", "pcm")));
+}
- send_stream_ =
- sender_call_->CreateVideoSendStream(send_config_, encoder_config_);
+void CallTest::CreateVideoStreams() {
+ RTC_DCHECK(video_send_stream_ == nullptr);
+ RTC_DCHECK(video_receive_streams_.empty());
+ RTC_DCHECK(audio_send_stream_ == nullptr);
+ RTC_DCHECK(audio_receive_streams_.empty());
+
+ video_send_stream_ = sender_call_->CreateVideoSendStream(
+ video_send_config_, video_encoder_config_);
+ for (size_t i = 0; i < video_receive_configs_.size(); ++i) {
+ video_receive_streams_.push_back(
+ receiver_call_->CreateVideoReceiveStream(video_receive_configs_[i]));
+ }
+}
- for (size_t i = 0; i < receive_configs_.size(); ++i) {
- receive_streams_.push_back(
- receiver_call_->CreateVideoReceiveStream(receive_configs_[i]));
+void CallTest::CreateAudioStreams() {
+ audio_send_stream_ = sender_call_->CreateAudioSendStream(audio_send_config_);
+ for (size_t i = 0; i < audio_receive_configs_.size(); ++i) {
+ audio_receive_streams_.push_back(
+ receiver_call_->CreateAudioReceiveStream(audio_receive_configs_[i]));
}
+ CodecInst isac = {kAudioSendPayloadType, "ISAC", 16000, 480, 1, 32000};
+ EXPECT_EQ(0, voe_send_.codec->SetSendCodec(voe_send_.channel_id, isac));
}
void CallTest::DestroyStreams() {
- if (send_stream_ != NULL)
- sender_call_->DestroyVideoSendStream(send_stream_);
- send_stream_ = NULL;
- for (size_t i = 0; i < receive_streams_.size(); ++i)
- receiver_call_->DestroyVideoReceiveStream(receive_streams_[i]);
- receive_streams_.clear();
+ if (video_send_stream_)
+ sender_call_->DestroyVideoSendStream(video_send_stream_);
+ video_send_stream_ = nullptr;
+ for (VideoReceiveStream* video_recv_stream : video_receive_streams_)
+ receiver_call_->DestroyVideoReceiveStream(video_recv_stream);
+
+ if (audio_send_stream_)
+ sender_call_->DestroyAudioSendStream(audio_send_stream_);
+ audio_send_stream_ = nullptr;
+ for (AudioReceiveStream* audio_recv_stream : audio_receive_streams_)
+ receiver_call_->DestroyAudioReceiveStream(audio_recv_stream);
+ video_receive_streams_.clear();
+
allocated_decoders_.clear();
}
-const unsigned int CallTest::kDefaultTimeoutMs = 30 * 1000;
-const unsigned int CallTest::kLongTimeoutMs = 120 * 1000;
-const uint8_t CallTest::kSendPayloadType = 100;
-const uint8_t CallTest::kFakeSendPayloadType = 125;
+void CallTest::CreateVoiceEngines() {
+ CreateFakeAudioDevices();
+ voe_send_.voice_engine = VoiceEngine::Create();
+ voe_send_.base = VoEBase::GetInterface(voe_send_.voice_engine);
+ voe_send_.network = VoENetwork::GetInterface(voe_send_.voice_engine);
+ voe_send_.codec = VoECodec::GetInterface(voe_send_.voice_engine);
+ EXPECT_EQ(0, voe_send_.base->Init(fake_send_audio_device_.get(), nullptr));
+ Config voe_config;
+ voe_config.Set<VoicePacing>(new VoicePacing(true));
+ voe_send_.channel_id = voe_send_.base->CreateChannel(voe_config);
+ EXPECT_GE(voe_send_.channel_id, 0);
+
+ voe_recv_.voice_engine = VoiceEngine::Create();
+ voe_recv_.base = VoEBase::GetInterface(voe_recv_.voice_engine);
+ voe_recv_.network = VoENetwork::GetInterface(voe_recv_.voice_engine);
+ voe_recv_.codec = VoECodec::GetInterface(voe_recv_.voice_engine);
+ EXPECT_EQ(0, voe_recv_.base->Init(fake_recv_audio_device_.get(), nullptr));
+ voe_recv_.channel_id = voe_recv_.base->CreateChannel();
+ EXPECT_GE(voe_recv_.channel_id, 0);
+}
+
+void CallTest::SetupVoiceEngineTransports(PacketTransport* send_transport,
+ PacketTransport* recv_transport) {
+ voe_send_.transport_adapter.reset(
+ new internal::TransportAdapter(send_transport));
+ voe_send_.transport_adapter->Enable();
+ EXPECT_EQ(0, voe_send_.network->RegisterExternalTransport(
+ voe_send_.channel_id, *voe_send_.transport_adapter.get()));
+
+ voe_recv_.transport_adapter.reset(
+ new internal::TransportAdapter(recv_transport));
+ voe_recv_.transport_adapter->Enable();
+ EXPECT_EQ(0, voe_recv_.network->RegisterExternalTransport(
+ voe_recv_.channel_id, *voe_recv_.transport_adapter.get()));
+}
+
+void CallTest::DestroyVoiceEngines() {
+ voe_recv_.base->DeleteChannel(voe_recv_.channel_id);
+ voe_recv_.channel_id = -1;
+ voe_recv_.base->Release();
+ voe_recv_.base = nullptr;
+ voe_recv_.network->Release();
+ voe_recv_.network = nullptr;
+ voe_recv_.codec->Release();
+ voe_recv_.codec = nullptr;
+
+ voe_send_.base->DeleteChannel(voe_send_.channel_id);
+ voe_send_.channel_id = -1;
+ voe_send_.base->Release();
+ voe_send_.base = nullptr;
+ voe_send_.network->Release();
+ voe_send_.network = nullptr;
+ voe_send_.codec->Release();
+ voe_send_.codec = nullptr;
+
+ VoiceEngine::Delete(voe_send_.voice_engine);
+ voe_send_.voice_engine = nullptr;
+ VoiceEngine::Delete(voe_recv_.voice_engine);
+ voe_recv_.voice_engine = nullptr;
+}
+
+const int CallTest::kDefaultTimeoutMs = 30 * 1000;
+const int CallTest::kLongTimeoutMs = 120 * 1000;
+const uint8_t CallTest::kVideoSendPayloadType = 100;
+const uint8_t CallTest::kFakeVideoSendPayloadType = 125;
const uint8_t CallTest::kSendRtxPayloadType = 98;
const uint8_t CallTest::kRedPayloadType = 118;
const uint8_t CallTest::kRtxRedPayloadType = 99;
const uint8_t CallTest::kUlpfecPayloadType = 119;
+const uint8_t CallTest::kAudioSendPayloadType = 103;
const uint32_t CallTest::kSendRtxSsrcs[kNumSsrcs] = {0xBADCAFD, 0xBADCAFE,
0xBADCAFF};
-const uint32_t CallTest::kSendSsrcs[kNumSsrcs] = {0xC0FFED, 0xC0FFEE, 0xC0FFEF};
-const uint32_t CallTest::kReceiverLocalSsrc = 0x123456;
+const uint32_t CallTest::kVideoSendSsrcs[kNumSsrcs] = {0xC0FFED, 0xC0FFEE,
+ 0xC0FFEF};
+const uint32_t CallTest::kAudioSendSsrc = 0xDEADBEEF;
+const uint32_t CallTest::kReceiverLocalVideoSsrc = 0x123456;
+const uint32_t CallTest::kReceiverLocalAudioSsrc = 0x1234567;
const int CallTest::kNackRtpHistoryMs = 1000;
BaseTest::BaseTest(unsigned int timeout_ms) : RtpRtcpObserver(timeout_ms) {
@@ -204,23 +387,40 @@ Call::Config BaseTest::GetReceiverCallConfig() {
void BaseTest::OnCallsCreated(Call* sender_call, Call* receiver_call) {
}
-void BaseTest::OnTransportsCreated(PacketTransport* send_transport,
- PacketTransport* receive_transport) {}
+test::PacketTransport* BaseTest::CreateSendTransport(Call* sender_call) {
+ return new PacketTransport(sender_call, this, test::PacketTransport::kSender,
+ FakeNetworkPipe::Config());
+}
-size_t BaseTest::GetNumStreams() const {
+test::PacketTransport* BaseTest::CreateReceiveTransport() {
+ return new PacketTransport(nullptr, this, test::PacketTransport::kReceiver,
+ FakeNetworkPipe::Config());
+}
+
+size_t BaseTest::GetNumVideoStreams() const {
return 1;
}
-void BaseTest::ModifyConfigs(
+size_t BaseTest::GetNumAudioStreams() const {
+ return 0;
+}
+
+void BaseTest::ModifyVideoConfigs(
VideoSendStream::Config* send_config,
std::vector<VideoReceiveStream::Config>* receive_configs,
- VideoEncoderConfig* encoder_config) {
-}
+ VideoEncoderConfig* encoder_config) {}
-void BaseTest::OnStreamsCreated(
+void BaseTest::OnVideoStreamsCreated(
VideoSendStream* send_stream,
- const std::vector<VideoReceiveStream*>& receive_streams) {
-}
+ const std::vector<VideoReceiveStream*>& receive_streams) {}
+
+void BaseTest::ModifyAudioConfigs(
+ AudioSendStream::Config* send_config,
+ std::vector<AudioReceiveStream::Config>* receive_configs) {}
+
+void BaseTest::OnAudioStreamsCreated(
+ AudioSendStream* send_stream,
+ const std::vector<AudioReceiveStream*>& receive_streams) {}
void BaseTest::OnFrameGeneratorCapturerCreated(
FrameGeneratorCapturer* frame_generator_capturer) {