diff options
Diffstat (limited to 'webrtc/test/call_test.cc')
-rw-r--r-- | webrtc/test/call_test.cc | 394 |
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) { |