Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(958)

Side by Side Diff: webrtc/call/call_perf_tests.cc

Issue 1909333002: Switch voice transport to use Call and Stream instead of VoENetwork. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Remove VoENetwork from perf test. Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2013 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
(...skipping 23 matching lines...) Expand all
34 #include "webrtc/test/fake_decoder.h" 34 #include "webrtc/test/fake_decoder.h"
35 #include "webrtc/test/fake_encoder.h" 35 #include "webrtc/test/fake_encoder.h"
36 #include "webrtc/test/frame_generator.h" 36 #include "webrtc/test/frame_generator.h"
37 #include "webrtc/test/frame_generator_capturer.h" 37 #include "webrtc/test/frame_generator_capturer.h"
38 #include "webrtc/test/histogram.h" 38 #include "webrtc/test/histogram.h"
39 #include "webrtc/test/rtp_rtcp_observer.h" 39 #include "webrtc/test/rtp_rtcp_observer.h"
40 #include "webrtc/test/testsupport/fileutils.h" 40 #include "webrtc/test/testsupport/fileutils.h"
41 #include "webrtc/test/testsupport/perf_test.h" 41 #include "webrtc/test/testsupport/perf_test.h"
42 #include "webrtc/voice_engine/include/voe_base.h" 42 #include "webrtc/voice_engine/include/voe_base.h"
43 #include "webrtc/voice_engine/include/voe_codec.h" 43 #include "webrtc/voice_engine/include/voe_codec.h"
44 #include "webrtc/voice_engine/include/voe_network.h"
45 #include "webrtc/voice_engine/include/voe_rtp_rtcp.h" 44 #include "webrtc/voice_engine/include/voe_rtp_rtcp.h"
46 #include "webrtc/voice_engine/include/voe_video_sync.h" 45 #include "webrtc/voice_engine/include/voe_video_sync.h"
47 46
48 using webrtc::test::DriftingClock; 47 using webrtc::test::DriftingClock;
49 using webrtc::test::FakeAudioDevice; 48 using webrtc::test::FakeAudioDevice;
50 49
51 namespace webrtc { 50 namespace webrtc {
52 51
53 class CallPerfTest : public test::CallTest { 52 class CallPerfTest : public test::CallTest {
54 protected: 53 protected:
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after
142 }; 141 };
143 142
144 void CallPerfTest::TestAudioVideoSync(FecMode fec, 143 void CallPerfTest::TestAudioVideoSync(FecMode fec,
145 CreateOrder create_first, 144 CreateOrder create_first,
146 float video_ntp_speed, 145 float video_ntp_speed,
147 float video_rtp_speed, 146 float video_rtp_speed,
148 float audio_rtp_speed) { 147 float audio_rtp_speed) {
149 const char* kSyncGroup = "av_sync"; 148 const char* kSyncGroup = "av_sync";
150 const uint32_t kAudioSendSsrc = 1234; 149 const uint32_t kAudioSendSsrc = 1234;
151 const uint32_t kAudioRecvSsrc = 5678; 150 const uint32_t kAudioRecvSsrc = 5678;
152 class AudioPacketReceiver : public PacketReceiver {
153 public:
154 AudioPacketReceiver(int channel, VoENetwork* voe_network)
155 : channel_(channel),
156 voe_network_(voe_network),
157 parser_(RtpHeaderParser::Create()) {}
158 DeliveryStatus DeliverPacket(MediaType media_type,
159 const uint8_t* packet,
160 size_t length,
161 const PacketTime& packet_time) override {
162 EXPECT_TRUE(media_type == MediaType::ANY ||
163 media_type == MediaType::AUDIO);
164 int ret;
165 if (parser_->IsRtcp(packet, length)) {
166 ret = voe_network_->ReceivedRTCPPacket(channel_, packet, length);
167 } else {
168 ret = voe_network_->ReceivedRTPPacket(channel_, packet, length,
169 PacketTime());
170 }
171 return ret == 0 ? DELIVERY_OK : DELIVERY_PACKET_ERROR;
172 }
173
174 private:
175 int channel_;
176 VoENetwork* voe_network_;
177 std::unique_ptr<RtpHeaderParser> parser_;
178 };
179 151
180 test::ClearHistograms(); 152 test::ClearHistograms();
181 VoiceEngine* voice_engine = VoiceEngine::Create(); 153 VoiceEngine* voice_engine = VoiceEngine::Create();
182 VoEBase* voe_base = VoEBase::GetInterface(voice_engine); 154 VoEBase* voe_base = VoEBase::GetInterface(voice_engine);
183 VoECodec* voe_codec = VoECodec::GetInterface(voice_engine); 155 VoECodec* voe_codec = VoECodec::GetInterface(voice_engine);
184 VoENetwork* voe_network = VoENetwork::GetInterface(voice_engine);
185 const std::string audio_filename = 156 const std::string audio_filename =
186 test::ResourcePath("voice_engine/audio_long16", "pcm"); 157 test::ResourcePath("voice_engine/audio_long16", "pcm");
187 ASSERT_STRNE("", audio_filename.c_str()); 158 ASSERT_STRNE("", audio_filename.c_str());
188 FakeAudioDevice fake_audio_device(Clock::GetRealTimeClock(), audio_filename, 159 FakeAudioDevice fake_audio_device(Clock::GetRealTimeClock(), audio_filename,
189 audio_rtp_speed); 160 audio_rtp_speed);
190 EXPECT_EQ(0, voe_base->Init(&fake_audio_device, nullptr)); 161 EXPECT_EQ(0, voe_base->Init(&fake_audio_device, nullptr));
191 Config voe_config; 162 Config voe_config;
192 voe_config.Set<VoicePacing>(new VoicePacing(true)); 163 voe_config.Set<VoicePacing>(new VoicePacing(true));
193 int send_channel_id = voe_base->CreateChannel(voe_config); 164 int send_channel_id = voe_base->CreateChannel(voe_config);
194 int recv_channel_id = voe_base->CreateChannel(); 165 int recv_channel_id = voe_base->CreateChannel();
195 166
196 AudioState::Config send_audio_state_config; 167 AudioState::Config send_audio_state_config;
197 send_audio_state_config.voice_engine = voice_engine; 168 send_audio_state_config.voice_engine = voice_engine;
198 Call::Config sender_config; 169 Call::Config sender_config;
199 sender_config.audio_state = AudioState::Create(send_audio_state_config); 170 sender_config.audio_state = AudioState::Create(send_audio_state_config);
200 Call::Config receiver_config; 171 Call::Config receiver_config;
201 receiver_config.audio_state = sender_config.audio_state; 172 receiver_config.audio_state = sender_config.audio_state;
202 CreateCalls(sender_config, receiver_config); 173 CreateCalls(sender_config, receiver_config);
203 174
204 AudioPacketReceiver voe_send_packet_receiver(send_channel_id, voe_network);
205 AudioPacketReceiver voe_recv_packet_receiver(recv_channel_id, voe_network);
206 175
207 VideoRtcpAndSyncObserver observer(Clock::GetRealTimeClock()); 176 VideoRtcpAndSyncObserver observer(Clock::GetRealTimeClock());
208 177
209 FakeNetworkPipe::Config net_config; 178 // Helper class to ensure we deliver correct media_type to the receiving call.
210 net_config.queue_delay_ms = 500; 179 class MediaTypePacketReceiver : public PacketReceiver {
211 net_config.loss_percent = 5; 180 public:
212 test::PacketTransport audio_send_transport( 181 MediaTypePacketReceiver(PacketReceiver* packet_receiver,
213 nullptr, &observer, test::PacketTransport::kSender, net_config); 182 MediaType media_type)
214 audio_send_transport.SetReceiver(&voe_recv_packet_receiver); 183 : packet_receiver_(packet_receiver), media_type_(media_type) {}
215 test::PacketTransport audio_receive_transport(
216 nullptr, &observer, test::PacketTransport::kReceiver, net_config);
217 audio_receive_transport.SetReceiver(&voe_send_packet_receiver);
218 184
219 internal::TransportAdapter send_transport_adapter(&audio_send_transport); 185 DeliveryStatus DeliverPacket(MediaType media_type,
220 send_transport_adapter.Enable(); 186 const uint8_t* packet,
221 EXPECT_EQ(0, voe_network->RegisterExternalTransport(send_channel_id, 187 size_t length,
222 send_transport_adapter)); 188 const PacketTime& packet_time) override {
189 return packet_receiver_->DeliverPacket(media_type_, packet, length,
190 packet_time);
191 }
192 private:
193 PacketReceiver* packet_receiver_;
194 const MediaType media_type_;
the sun 2016/04/22 12:40:31 RTC_DISALLOW_IMPLICIT_CONSTRUCTORS
mflodman 2016/04/27 13:42:17 Done.
195 };
223 196
224 internal::TransportAdapter recv_transport_adapter(&audio_receive_transport); 197 FakeNetworkPipe::Config audio_net_config;
225 recv_transport_adapter.Enable(); 198 audio_net_config.queue_delay_ms = 500;
226 EXPECT_EQ(0, voe_network->RegisterExternalTransport(recv_channel_id, 199 audio_net_config.loss_percent = 5;
227 recv_transport_adapter)); 200 test::PacketTransport audio_send_transport(sender_call_.get(), &observer,
201 test::PacketTransport::kSender,
202 audio_net_config);
203 MediaTypePacketReceiver audio_receiver(receiver_call_->Receiver(),
204 MediaType::AUDIO);
205 audio_send_transport.SetReceiver(&audio_receiver);
228 206
229 test::PacketTransport sync_send_transport(sender_call_.get(), &observer, 207 test::PacketTransport video_send_transport(sender_call_.get(), &observer,
230 test::PacketTransport::kSender, 208 test::PacketTransport::kSender,
231 FakeNetworkPipe::Config()); 209 FakeNetworkPipe::Config());
232 sync_send_transport.SetReceiver(receiver_call_->Receiver()); 210 MediaTypePacketReceiver video_receiver(receiver_call_->Receiver(),
233 test::PacketTransport sync_receive_transport(receiver_call_.get(), &observer, 211 MediaType::VIDEO);
234 test::PacketTransport::kReceiver, 212 video_send_transport.SetReceiver(&video_receiver);
235 FakeNetworkPipe::Config()); 213
236 sync_receive_transport.SetReceiver(sender_call_->Receiver()); 214 test::PacketTransport receive_transport(
215 receiver_call_.get(), &observer, test::PacketTransport::kReceiver,
216 FakeNetworkPipe::Config());
217 receive_transport.SetReceiver(sender_call_->Receiver());
237 218
238 test::FakeDecoder fake_decoder; 219 test::FakeDecoder fake_decoder;
239 220
240 CreateSendConfig(1, 0, &sync_send_transport); 221 CreateSendConfig(1, 0, &video_send_transport);
241 CreateMatchingReceiveConfigs(&sync_receive_transport); 222 CreateMatchingReceiveConfigs(&receive_transport);
242 223
243 AudioSendStream::Config audio_send_config(&audio_send_transport); 224 AudioSendStream::Config audio_send_config(&audio_send_transport);
244 audio_send_config.voe_channel_id = send_channel_id; 225 audio_send_config.voe_channel_id = send_channel_id;
245 audio_send_config.rtp.ssrc = kAudioSendSsrc; 226 audio_send_config.rtp.ssrc = kAudioSendSsrc;
246 AudioSendStream* audio_send_stream = 227 AudioSendStream* audio_send_stream =
247 sender_call_->CreateAudioSendStream(audio_send_config); 228 sender_call_->CreateAudioSendStream(audio_send_config);
248 229
249 CodecInst isac = {103, "ISAC", 16000, 480, 1, 32000}; 230 CodecInst isac = {103, "ISAC", 16000, 480, 1, 32000};
250 EXPECT_EQ(0, voe_codec->SetSendCodec(send_channel_id, isac)); 231 EXPECT_EQ(0, voe_codec->SetSendCodec(send_channel_id, isac));
251 232
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
291 272
292 EXPECT_TRUE(observer.Wait()) 273 EXPECT_TRUE(observer.Wait())
293 << "Timed out while waiting for audio and video to be synchronized."; 274 << "Timed out while waiting for audio and video to be synchronized.";
294 275
295 EXPECT_EQ(0, voe_base->StopSend(send_channel_id)); 276 EXPECT_EQ(0, voe_base->StopSend(send_channel_id));
296 EXPECT_EQ(0, voe_base->StopReceive(recv_channel_id)); 277 EXPECT_EQ(0, voe_base->StopReceive(recv_channel_id));
297 EXPECT_EQ(0, voe_base->StopPlayout(recv_channel_id)); 278 EXPECT_EQ(0, voe_base->StopPlayout(recv_channel_id));
298 fake_audio_device.Stop(); 279 fake_audio_device.Stop();
299 280
300 Stop(); 281 Stop();
301 sync_send_transport.StopSending(); 282 video_send_transport.StopSending();
302 sync_receive_transport.StopSending();
303 audio_send_transport.StopSending(); 283 audio_send_transport.StopSending();
304 audio_receive_transport.StopSending(); 284 receive_transport.StopSending();
305 285
306 DestroyStreams(); 286 DestroyStreams();
307 287
308 sender_call_->DestroyAudioSendStream(audio_send_stream); 288 sender_call_->DestroyAudioSendStream(audio_send_stream);
309 receiver_call_->DestroyAudioReceiveStream(audio_receive_stream); 289 receiver_call_->DestroyAudioReceiveStream(audio_receive_stream);
310 290
311 voe_base->DeleteChannel(send_channel_id); 291 voe_base->DeleteChannel(send_channel_id);
312 voe_base->DeleteChannel(recv_channel_id); 292 voe_base->DeleteChannel(recv_channel_id);
313 voe_base->Release(); 293 voe_base->Release();
314 voe_codec->Release(); 294 voe_codec->Release();
315 voe_network->Release();
316 295
317 DestroyCalls(); 296 DestroyCalls();
318 297
319 VoiceEngine::Delete(voice_engine); 298 VoiceEngine::Delete(voice_engine);
320 299
321 EXPECT_EQ(1, test::NumHistogramSamples("WebRTC.Video.AVSyncOffsetInMs")); 300 EXPECT_EQ(1, test::NumHistogramSamples("WebRTC.Video.AVSyncOffsetInMs"));
322 } 301 }
323 302
324 TEST_F(CallPerfTest, PlaysOutAudioAndVideoInSyncWithVideoNtpDrift) { 303 TEST_F(CallPerfTest, PlaysOutAudioAndVideoInSyncWithVideoNtpDrift) {
325 TestAudioVideoSync(FecMode::kOff, CreateOrder::kAudioFirst, 304 TestAudioVideoSync(FecMode::kOff, CreateOrder::kAudioFirst,
(...skipping 385 matching lines...) Expand 10 before | Expand all | Expand 10 after
711 int encoder_inits_; 690 int encoder_inits_;
712 uint32_t last_set_bitrate_; 691 uint32_t last_set_bitrate_;
713 VideoSendStream* send_stream_; 692 VideoSendStream* send_stream_;
714 VideoEncoderConfig encoder_config_; 693 VideoEncoderConfig encoder_config_;
715 } test; 694 } test;
716 695
717 RunBaseTest(&test); 696 RunBaseTest(&test);
718 } 697 }
719 698
720 } // namespace webrtc 699 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698