Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
| 5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
| 6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| 11 #include "webrtc/test/call_test.h" | 11 #include "webrtc/test/call_test.h" |
| 12 | 12 |
| 13 #include <algorithm> | 13 #include <algorithm> |
| 14 | 14 |
| 15 #include "webrtc/api/audio_codecs/builtin_audio_decoder_factory.h" | 15 #include "webrtc/api/audio_codecs/builtin_audio_decoder_factory.h" |
| 16 #include "webrtc/api/audio_codecs/builtin_audio_encoder_factory.h" | 16 #include "webrtc/api/audio_codecs/builtin_audio_encoder_factory.h" |
| 17 #include "webrtc/call/rtp_transport_controller_send.h" | 17 #include "webrtc/call/rtp_transport_controller_send.h" |
| 18 #include "webrtc/config.h" | 18 #include "webrtc/config.h" |
| 19 #include "webrtc/modules/audio_mixer/audio_mixer_impl.h" | 19 #include "webrtc/modules/audio_mixer/audio_mixer_impl.h" |
| 20 #include "webrtc/rtc_base/checks.h" | 20 #include "webrtc/rtc_base/checks.h" |
| 21 #include "webrtc/rtc_base/event.h" | |
| 22 #include "webrtc/rtc_base/ptr_util.h" | |
| 21 #include "webrtc/test/testsupport/fileutils.h" | 23 #include "webrtc/test/testsupport/fileutils.h" |
| 22 #include "webrtc/voice_engine/include/voe_base.h" | 24 #include "webrtc/voice_engine/include/voe_base.h" |
| 25 | |
| 23 namespace webrtc { | 26 namespace webrtc { |
| 24 namespace test { | 27 namespace test { |
| 25 | 28 |
| 26 namespace { | 29 namespace { |
| 27 const int kVideoRotationRtpExtensionId = 4; | 30 const int kVideoRotationRtpExtensionId = 4; |
| 28 } | 31 } |
| 29 | 32 |
| 30 CallTest::CallTest() | 33 CallTest::CallTest() |
| 31 : clock_(Clock::GetRealTimeClock()), | 34 : clock_(Clock::GetRealTimeClock()), |
| 32 event_log_(RtcEventLog::CreateNull()), | 35 event_log_(RtcEventLog::CreateNull()), |
| 33 sender_call_transport_controller_(nullptr), | 36 sender_call_transport_controller_(nullptr), |
| 34 video_send_config_(nullptr), | 37 video_send_config_(nullptr), |
| 35 video_send_stream_(nullptr), | 38 video_send_stream_(nullptr), |
| 36 audio_send_config_(nullptr), | 39 audio_send_config_(nullptr), |
| 37 audio_send_stream_(nullptr), | 40 audio_send_stream_(nullptr), |
| 38 fake_encoder_(clock_), | 41 fake_encoder_(clock_), |
| 39 num_video_streams_(1), | 42 num_video_streams_(1), |
| 40 num_audio_streams_(0), | 43 num_audio_streams_(0), |
| 41 num_flexfec_streams_(0), | 44 num_flexfec_streams_(0), |
| 42 decoder_factory_(CreateBuiltinAudioDecoderFactory()), | 45 decoder_factory_(CreateBuiltinAudioDecoderFactory()), |
| 43 encoder_factory_(CreateBuiltinAudioEncoderFactory()), | 46 encoder_factory_(CreateBuiltinAudioEncoderFactory()), |
| 44 fake_send_audio_device_(nullptr), | 47 fake_send_audio_device_(nullptr), |
| 45 fake_recv_audio_device_(nullptr) {} | 48 fake_recv_audio_device_(nullptr), |
| 49 task_queue_("CallTestTaskQueue") {} | |
| 46 | 50 |
| 47 CallTest::~CallTest() { | 51 CallTest::~CallTest() { |
| 52 task_queue_.SendTask([this]() { | |
| 53 fake_send_audio_device_.reset(); | |
| 54 fake_recv_audio_device_.reset(); | |
| 55 frame_generator_capturer_.reset(); | |
| 56 }); | |
| 48 } | 57 } |
| 49 | 58 |
| 50 void CallTest::RunBaseTest(BaseTest* test) { | 59 void CallTest::RunBaseTest(BaseTest* test) { |
| 51 num_video_streams_ = test->GetNumVideoStreams(); | 60 task_queue_.SendTask([this, test]() { |
|
nisse-webrtc
2017/08/18 11:08:29
There's a lot of code moving around here, not clea
eladalon
2017/08/18 12:12:37
* The diff-tool used by the code-review system is
| |
| 52 num_audio_streams_ = test->GetNumAudioStreams(); | 61 num_video_streams_ = test->GetNumVideoStreams(); |
| 53 num_flexfec_streams_ = test->GetNumFlexfecStreams(); | 62 num_audio_streams_ = test->GetNumAudioStreams(); |
| 54 RTC_DCHECK(num_video_streams_ > 0 || num_audio_streams_ > 0); | 63 num_flexfec_streams_ = test->GetNumFlexfecStreams(); |
| 55 Call::Config send_config(test->GetSenderCallConfig()); | 64 RTC_DCHECK(num_video_streams_ > 0 || num_audio_streams_ > 0); |
| 56 if (num_audio_streams_ > 0) { | 65 Call::Config send_config(test->GetSenderCallConfig()); |
| 57 CreateFakeAudioDevices(test->CreateCapturer(), test->CreateRenderer()); | |
| 58 test->OnFakeAudioDevicesCreated(fake_send_audio_device_.get(), | |
| 59 fake_recv_audio_device_.get()); | |
| 60 apm_send_ = AudioProcessing::Create(); | |
| 61 apm_recv_ = AudioProcessing::Create(); | |
| 62 CreateVoiceEngines(); | |
| 63 AudioState::Config audio_state_config; | |
| 64 audio_state_config.voice_engine = voe_send_.voice_engine; | |
| 65 audio_state_config.audio_mixer = AudioMixerImpl::Create(); | |
| 66 audio_state_config.audio_processing = apm_send_; | |
| 67 send_config.audio_state = AudioState::Create(audio_state_config); | |
| 68 } | |
| 69 CreateSenderCall(send_config); | |
| 70 if (sender_call_transport_controller_ != nullptr) { | |
| 71 test->OnRtpTransportControllerSendCreated( | |
| 72 sender_call_transport_controller_); | |
| 73 } | |
| 74 if (test->ShouldCreateReceivers()) { | |
| 75 Call::Config recv_config(test->GetReceiverCallConfig()); | |
| 76 if (num_audio_streams_ > 0) { | 66 if (num_audio_streams_ > 0) { |
| 67 CreateFakeAudioDevices(test->CreateCapturer(), test->CreateRenderer()); | |
| 68 test->OnFakeAudioDevicesCreated(fake_send_audio_device_.get(), | |
| 69 fake_recv_audio_device_.get()); | |
| 70 apm_send_ = AudioProcessing::Create(); | |
| 71 apm_recv_ = AudioProcessing::Create(); | |
| 72 CreateVoiceEngines(); | |
| 77 AudioState::Config audio_state_config; | 73 AudioState::Config audio_state_config; |
| 78 audio_state_config.voice_engine = voe_recv_.voice_engine; | 74 audio_state_config.voice_engine = voe_send_.voice_engine; |
| 79 audio_state_config.audio_mixer = AudioMixerImpl::Create(); | 75 audio_state_config.audio_mixer = AudioMixerImpl::Create(); |
| 80 audio_state_config.audio_processing = apm_recv_; | 76 audio_state_config.audio_processing = apm_send_; |
| 81 recv_config.audio_state = AudioState::Create(audio_state_config); | 77 send_config.audio_state = AudioState::Create(audio_state_config); |
| 82 } | 78 } |
| 83 CreateReceiverCall(recv_config); | 79 CreateSenderCall(send_config); |
| 84 } | 80 if (sender_call_transport_controller_ != nullptr) { |
| 85 test->OnCallsCreated(sender_call_.get(), receiver_call_.get()); | 81 test->OnRtpTransportControllerSendCreated( |
| 86 receive_transport_.reset(test->CreateReceiveTransport()); | 82 sender_call_transport_controller_); |
| 87 send_transport_.reset(test->CreateSendTransport(sender_call_.get())); | 83 } |
| 84 if (test->ShouldCreateReceivers()) { | |
| 85 Call::Config recv_config(test->GetReceiverCallConfig()); | |
| 86 if (num_audio_streams_ > 0) { | |
| 87 AudioState::Config audio_state_config; | |
| 88 audio_state_config.voice_engine = voe_recv_.voice_engine; | |
| 89 audio_state_config.audio_mixer = AudioMixerImpl::Create(); | |
| 90 audio_state_config.audio_processing = apm_recv_; | |
| 91 recv_config.audio_state = AudioState::Create(audio_state_config); | |
| 92 } | |
| 93 CreateReceiverCall(recv_config); | |
| 94 } | |
| 95 test->OnCallsCreated(sender_call_.get(), receiver_call_.get()); | |
| 96 receive_transport_.reset(test->CreateReceiveTransport(&task_queue_)); | |
| 97 send_transport_.reset( | |
| 98 test->CreateSendTransport(&task_queue_, sender_call_.get())); | |
| 88 | 99 |
| 89 if (test->ShouldCreateReceivers()) { | 100 if (test->ShouldCreateReceivers()) { |
| 90 send_transport_->SetReceiver(receiver_call_->Receiver()); | 101 send_transport_->SetReceiver(receiver_call_->Receiver()); |
| 91 receive_transport_->SetReceiver(sender_call_->Receiver()); | 102 receive_transport_->SetReceiver(sender_call_->Receiver()); |
| 92 if (num_video_streams_ > 0) | 103 if (num_video_streams_ > 0) |
| 93 receiver_call_->SignalChannelNetworkState(MediaType::VIDEO, kNetworkUp); | 104 receiver_call_->SignalChannelNetworkState(MediaType::VIDEO, kNetworkUp); |
| 105 if (num_audio_streams_ > 0) | |
| 106 receiver_call_->SignalChannelNetworkState(MediaType::AUDIO, kNetworkUp); | |
| 107 } else { | |
| 108 // Sender-only call delivers to itself. | |
| 109 send_transport_->SetReceiver(sender_call_->Receiver()); | |
| 110 receive_transport_->SetReceiver(nullptr); | |
| 111 } | |
| 112 | |
| 113 CreateSendConfig(num_video_streams_, num_audio_streams_, | |
| 114 num_flexfec_streams_, send_transport_.get()); | |
| 115 if (test->ShouldCreateReceivers()) { | |
| 116 CreateMatchingReceiveConfigs(receive_transport_.get()); | |
| 117 } | |
| 118 if (num_video_streams_ > 0) { | |
| 119 test->ModifyVideoConfigs(&video_send_config_, &video_receive_configs_, | |
| 120 &video_encoder_config_); | |
| 121 } | |
| 122 if (num_audio_streams_ > 0) { | |
| 123 test->ModifyAudioConfigs(&audio_send_config_, &audio_receive_configs_); | |
| 124 } | |
| 125 if (num_flexfec_streams_ > 0) { | |
| 126 test->ModifyFlexfecConfigs(&flexfec_receive_configs_); | |
| 127 } | |
| 128 | |
| 129 if (num_flexfec_streams_ > 0) { | |
| 130 CreateFlexfecStreams(); | |
| 131 test->OnFlexfecStreamsCreated(flexfec_receive_streams_); | |
| 132 } | |
| 133 if (num_video_streams_ > 0) { | |
| 134 CreateVideoStreams(); | |
| 135 test->OnVideoStreamsCreated(video_send_stream_, video_receive_streams_); | |
| 136 } | |
| 137 if (num_audio_streams_ > 0) { | |
| 138 CreateAudioStreams(); | |
| 139 test->OnAudioStreamsCreated(audio_send_stream_, audio_receive_streams_); | |
| 140 } | |
| 141 | |
| 142 if (num_video_streams_ > 0) { | |
| 143 int width = kDefaultWidth; | |
| 144 int height = kDefaultHeight; | |
| 145 int frame_rate = kDefaultFramerate; | |
| 146 test->ModifyVideoCaptureStartResolution(&width, &height, &frame_rate); | |
| 147 CreateFrameGeneratorCapturer(frame_rate, width, height); | |
| 148 test->OnFrameGeneratorCapturerCreated(frame_generator_capturer_.get()); | |
| 149 } | |
| 150 | |
| 151 Start(); | |
| 152 }); | |
| 153 | |
| 154 test->PerformTest(); | |
| 155 | |
| 156 task_queue_.SendTask([this]() { | |
| 157 Stop(); | |
| 158 DestroyStreams(); | |
| 159 send_transport_.reset(); | |
| 160 receive_transport_.reset(); | |
| 161 DestroyCalls(); | |
| 94 if (num_audio_streams_ > 0) | 162 if (num_audio_streams_ > 0) |
| 95 receiver_call_->SignalChannelNetworkState(MediaType::AUDIO, kNetworkUp); | 163 DestroyVoiceEngines(); |
| 96 } else { | 164 }); |
| 97 // Sender-only call delivers to itself. | |
| 98 send_transport_->SetReceiver(sender_call_->Receiver()); | |
| 99 receive_transport_->SetReceiver(nullptr); | |
| 100 } | |
| 101 | |
| 102 CreateSendConfig(num_video_streams_, num_audio_streams_, num_flexfec_streams_, | |
| 103 send_transport_.get()); | |
| 104 if (test->ShouldCreateReceivers()) { | |
| 105 CreateMatchingReceiveConfigs(receive_transport_.get()); | |
| 106 } | |
| 107 if (num_video_streams_ > 0) { | |
| 108 test->ModifyVideoConfigs(&video_send_config_, &video_receive_configs_, | |
| 109 &video_encoder_config_); | |
| 110 } | |
| 111 if (num_audio_streams_ > 0) { | |
| 112 test->ModifyAudioConfigs(&audio_send_config_, &audio_receive_configs_); | |
| 113 } | |
| 114 if (num_flexfec_streams_ > 0) { | |
| 115 test->ModifyFlexfecConfigs(&flexfec_receive_configs_); | |
| 116 } | |
| 117 | |
| 118 if (num_flexfec_streams_ > 0) { | |
| 119 CreateFlexfecStreams(); | |
| 120 test->OnFlexfecStreamsCreated(flexfec_receive_streams_); | |
| 121 } | |
| 122 if (num_video_streams_ > 0) { | |
| 123 CreateVideoStreams(); | |
| 124 test->OnVideoStreamsCreated(video_send_stream_, video_receive_streams_); | |
| 125 } | |
| 126 if (num_audio_streams_ > 0) { | |
| 127 CreateAudioStreams(); | |
| 128 test->OnAudioStreamsCreated(audio_send_stream_, audio_receive_streams_); | |
| 129 } | |
| 130 | |
| 131 if (num_video_streams_ > 0) { | |
| 132 int width = kDefaultWidth; | |
| 133 int height = kDefaultHeight; | |
| 134 int frame_rate = kDefaultFramerate; | |
| 135 test->ModifyVideoCaptureStartResolution(&width, &height, &frame_rate); | |
| 136 CreateFrameGeneratorCapturer(frame_rate, width, height); | |
| 137 test->OnFrameGeneratorCapturerCreated(frame_generator_capturer_.get()); | |
| 138 } | |
| 139 | |
| 140 Start(); | |
| 141 test->PerformTest(); | |
| 142 send_transport_->StopSending(); | |
| 143 receive_transport_->StopSending(); | |
| 144 Stop(); | |
| 145 | |
| 146 DestroyStreams(); | |
| 147 DestroyCalls(); | |
| 148 if (num_audio_streams_ > 0) | |
| 149 DestroyVoiceEngines(); | |
| 150 | 165 |
| 151 test->OnTestFinished(); | 166 test->OnTestFinished(); |
| 152 } | 167 } |
| 153 | 168 |
| 154 void CallTest::CreateCalls(const Call::Config& sender_config, | 169 void CallTest::CreateCalls(const Call::Config& sender_config, |
| 155 const Call::Config& receiver_config) { | 170 const Call::Config& receiver_config) { |
| 156 CreateSenderCall(sender_config); | 171 CreateSenderCall(sender_config); |
| 157 CreateReceiverCall(receiver_config); | 172 CreateReceiverCall(receiver_config); |
| 158 } | 173 } |
| 159 | 174 |
| (...skipping 350 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 510 Call::Config BaseTest::GetReceiverCallConfig() { | 525 Call::Config BaseTest::GetReceiverCallConfig() { |
| 511 return Call::Config(event_log_.get()); | 526 return Call::Config(event_log_.get()); |
| 512 } | 527 } |
| 513 | 528 |
| 514 void BaseTest::OnRtpTransportControllerSendCreated( | 529 void BaseTest::OnRtpTransportControllerSendCreated( |
| 515 RtpTransportControllerSend* controller) {} | 530 RtpTransportControllerSend* controller) {} |
| 516 | 531 |
| 517 void BaseTest::OnCallsCreated(Call* sender_call, Call* receiver_call) { | 532 void BaseTest::OnCallsCreated(Call* sender_call, Call* receiver_call) { |
| 518 } | 533 } |
| 519 | 534 |
| 520 test::PacketTransport* BaseTest::CreateSendTransport(Call* sender_call) { | 535 test::PacketTransport* BaseTest::CreateSendTransport( |
| 521 return new PacketTransport(sender_call, this, test::PacketTransport::kSender, | 536 SingleThreadedTaskQueueForTesting* task_queue, |
| 522 CallTest::payload_type_map_, | 537 Call* sender_call) { |
| 523 FakeNetworkPipe::Config()); | 538 return new PacketTransport( |
| 539 task_queue, sender_call, this, test::PacketTransport::kSender, | |
| 540 CallTest::payload_type_map_, FakeNetworkPipe::Config()); | |
| 524 } | 541 } |
| 525 | 542 |
| 526 test::PacketTransport* BaseTest::CreateReceiveTransport() { | 543 test::PacketTransport* BaseTest::CreateReceiveTransport( |
| 527 return new PacketTransport(nullptr, this, test::PacketTransport::kReceiver, | 544 SingleThreadedTaskQueueForTesting* task_queue) { |
| 528 CallTest::payload_type_map_, | 545 return new PacketTransport( |
| 529 FakeNetworkPipe::Config()); | 546 task_queue, nullptr, this, test::PacketTransport::kReceiver, |
| 547 CallTest::payload_type_map_, FakeNetworkPipe::Config()); | |
| 530 } | 548 } |
| 531 | 549 |
| 532 size_t BaseTest::GetNumVideoStreams() const { | 550 size_t BaseTest::GetNumVideoStreams() const { |
| 533 return 1; | 551 return 1; |
| 534 } | 552 } |
| 535 | 553 |
| 536 size_t BaseTest::GetNumAudioStreams() const { | 554 size_t BaseTest::GetNumAudioStreams() const { |
| 537 return 0; | 555 return 0; |
| 538 } | 556 } |
| 539 | 557 |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 586 | 604 |
| 587 EndToEndTest::EndToEndTest(unsigned int timeout_ms) : BaseTest(timeout_ms) { | 605 EndToEndTest::EndToEndTest(unsigned int timeout_ms) : BaseTest(timeout_ms) { |
| 588 } | 606 } |
| 589 | 607 |
| 590 bool EndToEndTest::ShouldCreateReceivers() const { | 608 bool EndToEndTest::ShouldCreateReceivers() const { |
| 591 return true; | 609 return true; |
| 592 } | 610 } |
| 593 | 611 |
| 594 } // namespace test | 612 } // namespace test |
| 595 } // namespace webrtc | 613 } // namespace webrtc |
| OLD | NEW |