Index: webrtc/test/call_test.cc |
diff --git a/webrtc/test/call_test.cc b/webrtc/test/call_test.cc |
index bbc1224446469bbfbda044c477a445280b039c58..0b21455affa9f3db52a7f7d3dcd07feb3a7f6391 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 { |
@@ -20,17 +27,48 @@ const int kVideoRotationRtpExtensionId = 4; |
CallTest::CallTest() |
: clock_(Clock::GetRealTimeClock()), |
video_send_config_(nullptr), |
- video_send_stream_(NULL), |
- fake_encoder_(clock_) {} |
+ video_send_stream_(nullptr), |
+ audio_send_config_(nullptr), |
+ audio_send_stream_(nullptr), |
+ fake_encoder_(clock_), |
+ voe_send_channel_id_(-1), |
+ voe_recv_channel_id_(-1), |
+ send_voice_engine_(nullptr), |
+ recv_voice_engine_(nullptr), |
+ voe_send_base_(nullptr), |
+ voe_send_network_(nullptr), |
+ voe_send_codec_(nullptr), |
+ voe_recv_base_(nullptr), |
+ voe_recv_network_(nullptr), |
+ voe_recv_codec_(nullptr), |
+ voe_send_transport_adapter_(nullptr), |
+ voe_recv_transport_adapter_(nullptr), |
+ 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()); |
+ bool audio_enabled = test->GetNumAudioStreams() > 0; |
+ Call::Config send_config(test->GetSenderCallConfig()); |
+ if (audio_enabled) { |
+ CreateVoiceEngines(); |
+ AudioState::Config audio_state_config; |
+ audio_state_config.voice_engine = 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 (audio_enabled) { |
+ AudioState::Config audio_state_config; |
+ audio_state_config.voice_engine = recv_voice_engine_; |
+ recv_config.audio_state = AudioState::Create(audio_state_config); |
+ } |
+ CreateReceiverCall(recv_config); |
+ } |
send_transport_.reset(new PacketTransport( |
sender_call_.get(), test, test::PacketTransport::kSender, config)); |
receive_transport_.reset(new PacketTransport( |
@@ -47,14 +85,25 @@ void CallTest::RunBaseTest(BaseTest* test, |
receive_transport_->SetReceiver(nullptr); |
} |
- CreateSendConfig(test->GetNumStreams(), send_transport_.get()); |
+ CreateSendConfig(test->GetNumVideoStreams(), test->GetNumAudioStreams(), |
+ send_transport_.get()); |
if (test->ShouldCreateReceivers()) { |
- CreateMatchingReceiveConfigs(receive_transport_.get()); |
+ CreateMatchingReceiveConfigs(audio_enabled, receive_transport_.get()); |
} |
+ if (audio_enabled) |
+ SetupVoiceEngineTransports(send_transport_.get(), receive_transport_.get()); |
+ |
test->ModifyVideoConfigs(&video_send_config_, &video_receive_configs_, |
&video_encoder_config_); |
- CreateStreams(); |
+ test->ModifyAudioConfigs(&audio_send_config_, &audio_receive_configs_); |
+ |
+ RTC_DCHECK(test->GetNumVideoStreams() > 0 || audio_enabled); |
+ if (test->GetNumVideoStreams() > 0) |
+ CreateVideoStreams(); |
test->OnVideoStreamsCreated(video_send_stream_, video_receive_streams_); |
+ if (audio_enabled) |
+ CreateAudioStreams(); |
+ test->OnAudioStreamsCreated(audio_send_stream_, audio_receive_streams_); |
CreateFrameGeneratorCapturer(); |
test->OnFrameGeneratorCapturerCreated(frame_generator_capturer_.get()); |
@@ -66,12 +115,28 @@ void CallTest::RunBaseTest(BaseTest* test, |
Stop(); |
DestroyStreams(); |
+ DestroyCalls(); |
+ if (audio_enabled) |
+ DestroyVoiceEngines(); |
} |
void CallTest::Start() { |
- video_send_stream_->Start(); |
- for (size_t i = 0; i < video_receive_streams_.size(); ++i) |
- video_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 +144,22 @@ void CallTest::Start() { |
void CallTest::Stop() { |
if (frame_generator_capturer_.get() != NULL) |
frame_generator_capturer_->Stop(); |
- for (size_t i = 0; i < video_receive_streams_.size(); ++i) |
- video_receive_streams_[i]->Stop(); |
- video_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,44 +177,63 @@ 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); |
+ RTC_DCHECK(num_video_streams <= kNumSsrcs); |
+ RTC_DCHECK_LE(num_audio_streams, 1u); |
+ RTC_DCHECK(num_audio_streams == 0 || voe_send_channel_id_ >= 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 = kFakeSendPayloadType; |
+ 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_streams); |
- for (size_t i = 0; i < num_streams; ++i) |
- video_send_config_.rtp.ssrcs.push_back(kSendSsrcs[i]); |
+ 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) { |
- assert(!video_send_config_.rtp.ssrcs.empty()); |
- assert(video_receive_configs_.empty()); |
- assert(allocated_decoders_.empty()); |
- VideoReceiveStream::Config config(rtcp_send_transport); |
- config.rtp.remb = true; |
- config.rtp.local_ssrc = kReceiverLocalSsrc; |
+void CallTest::CreateMatchingReceiveConfigs(bool create_audio_recv_stream, |
+ Transport* rtcp_send_transport) { |
+ RTC_DCHECK(!video_send_config_.rtp.ssrcs.empty()); |
+ RTC_DCHECK(video_receive_configs_.empty()); |
+ RTC_DCHECK(allocated_decoders_.empty()); |
+ RTC_DCHECK(!create_audio_recv_stream || voe_send_channel_id_ >= 0); |
+ 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) |
- config.rtp.extensions.push_back(extension); |
+ 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); |
- config.decoders.clear(); |
- config.decoders.push_back(decoder); |
- config.rtp.remote_ssrc = video_send_config_.rtp.ssrcs[i]; |
- video_receive_configs_.push_back(config); |
+ 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); |
+ } |
+ |
+ if (create_audio_recv_stream) { |
+ 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); |
} |
} |
@@ -147,41 +244,131 @@ void CallTest::CreateFrameGeneratorCapturer() { |
stream.max_framerate, clock_)); |
} |
-void CallTest::CreateStreams() { |
- assert(video_send_stream_ == NULL); |
- assert(video_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"))); |
+} |
+ |
+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])); |
} |
} |
+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 (video_send_stream_ != NULL) |
+ if (video_send_stream_) |
sender_call_->DestroyVideoSendStream(video_send_stream_); |
- video_send_stream_ = NULL; |
- for (size_t i = 0; i < video_receive_streams_.size(); ++i) |
- receiver_call_->DestroyVideoReceiveStream(video_receive_streams_[i]); |
+ 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(); |
} |
+void CallTest::CreateVoiceEngines() { |
+ CreateFakeAudioDevices(); |
+ send_voice_engine_ = VoiceEngine::Create(); |
+ voe_send_base_ = VoEBase::GetInterface(send_voice_engine_); |
+ voe_send_network_ = VoENetwork::GetInterface(send_voice_engine_); |
+ voe_send_codec_ = VoECodec::GetInterface(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); |
+ |
+ recv_voice_engine_ = VoiceEngine::Create(); |
+ voe_recv_base_ = VoEBase::GetInterface(recv_voice_engine_); |
+ voe_recv_network_ = VoENetwork::GetInterface(recv_voice_engine_); |
+ voe_recv_codec_ = VoECodec::GetInterface(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(send_voice_engine_); |
+ send_voice_engine_ = nullptr; |
+ VoiceEngine::Delete(recv_voice_engine_); |
+ recv_voice_engine_ = nullptr; |
+} |
+ |
const int CallTest::kDefaultTimeoutMs = 30 * 1000; |
const int CallTest::kLongTimeoutMs = 120 * 1000; |
-const uint8_t CallTest::kSendPayloadType = 100; |
-const uint8_t CallTest::kFakeSendPayloadType = 125; |
+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,10 +391,14 @@ void BaseTest::OnCallsCreated(Call* sender_call, Call* receiver_call) { |
void BaseTest::OnTransportsCreated(PacketTransport* send_transport, |
PacketTransport* receive_transport) {} |
-size_t BaseTest::GetNumStreams() const { |
+size_t BaseTest::GetNumVideoStreams() const { |
return 1; |
} |
+size_t BaseTest::GetNumAudioStreams() const { |
+ return 0; |
+} |
+ |
void BaseTest::ModifyVideoConfigs( |
VideoSendStream::Config* send_config, |
std::vector<VideoReceiveStream::Config>* receive_configs, |
@@ -217,6 +408,14 @@ void BaseTest::OnVideoStreamsCreated( |
VideoSendStream* send_stream, |
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) { |
} |