blob: 1655db32545ebadcf027fc7a6f682ce2eee9de32 [file] [log] [blame]
pbos@webrtc.org744fbc72013-09-10 09:26:25 +00001/*
2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved.
3 *
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
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
pbos@webrtc.org744fbc72013-09-10 09:26:25 +000010
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#include "call/rampup_tests.h"
stefanff483612015-12-21 03:14:00 -080012
Artem Titov4e199e92018-08-20 13:30:39 +020013#include "call/fake_network_pipe.h"
Sebastian Janssonf5e767d2018-10-15 13:24:31 +020014#include "logging/rtc_event_log/output/rtc_event_log_output_file.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020015#include "rtc_base/checks.h"
Sebastian Janssonf5e767d2018-10-15 13:24:31 +020016#include "rtc_base/flags.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020017#include "rtc_base/logging.h"
18#include "rtc_base/platform_thread.h"
Jonas Olsson0a713b62018-04-04 15:49:32 +020019#include "rtc_base/stringencode.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020020#include "test/encoder_settings.h"
21#include "test/gtest.h"
22#include "test/testsupport/perf_test.h"
pbos@webrtc.org744fbc72013-09-10 09:26:25 +000023
24namespace webrtc {
pbos@webrtc.org29023282013-09-11 10:14:56 +000025namespace {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000026
Stefan Holmer723dff12015-10-05 14:59:41 +020027static const int64_t kPollIntervalMs = 20;
philipel5ef2bc12017-02-21 07:28:31 -080028static const int kExpectedHighVideoBitrateBps = 80000;
stefandb752f92016-12-05 08:23:40 -080029static const int kExpectedHighAudioBitrateBps = 30000;
30static const int kLowBandwidthLimitBps = 20000;
Sebastian Jansson12fb1702018-02-23 11:34:18 +010031// Set target detected bitrate to slightly larger than the target bitrate to
32// avoid flakiness.
33static const int kLowBitrateMarginBps = 2000;
pbos@webrtc.org29023282013-09-11 10:14:56 +000034
stefanff483612015-12-21 03:14:00 -080035std::vector<uint32_t> GenerateSsrcs(size_t num_streams, uint32_t ssrc_offset) {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000036 std::vector<uint32_t> ssrcs;
37 for (size_t i = 0; i != num_streams; ++i)
38 ssrcs.push_back(static_cast<uint32_t>(ssrc_offset + i));
39 return ssrcs;
40}
mflodman@webrtc.orgeb16b812014-06-16 08:57:39 +000041} // namespace
henrik.lundin@webrtc.org845862f2014-03-06 07:19:28 +000042
Mirko Bonadei2dfa9982018-10-18 11:35:32 +020043WEBRTC_DEFINE_string(ramp_dump_name,
44 "",
45 "Filename for dumped received RTP stream.");
Sebastian Janssonf5e767d2018-10-15 13:24:31 +020046
stefanff483612015-12-21 03:14:00 -080047RampUpTester::RampUpTester(size_t num_video_streams,
48 size_t num_audio_streams,
philipel5ef2bc12017-02-21 07:28:31 -080049 size_t num_flexfec_streams,
stefan4fbd1452015-09-28 03:57:14 -070050 unsigned int start_bitrate_bps,
stefan5a2c5062017-01-27 06:43:18 -080051 int64_t min_run_time_ms,
stefan4fbd1452015-09-28 03:57:14 -070052 const std::string& extension_type,
53 bool rtx,
stefan5a2c5062017-01-27 06:43:18 -080054 bool red,
55 bool report_perf_stats)
stefan4fbd1452015-09-28 03:57:14 -070056 : EndToEndTest(test::CallTest::kLongTimeoutMs),
stefan4fbd1452015-09-28 03:57:14 -070057 clock_(Clock::GetRealTimeClock()),
stefanff483612015-12-21 03:14:00 -080058 num_video_streams_(num_video_streams),
59 num_audio_streams_(num_audio_streams),
philipel5ef2bc12017-02-21 07:28:31 -080060 num_flexfec_streams_(num_flexfec_streams),
stefan4fbd1452015-09-28 03:57:14 -070061 rtx_(rtx),
62 red_(red),
stefan45b5fe52017-03-09 06:27:02 -080063 report_perf_stats_(report_perf_stats),
mflodman86cc6ff2016-07-26 04:44:06 -070064 sender_call_(nullptr),
stefan4fbd1452015-09-28 03:57:14 -070065 send_stream_(nullptr),
sprang4847ae62017-06-27 07:06:52 -070066 send_transport_(nullptr),
Artem Titov631cafa2018-08-21 21:01:00 +020067 send_simulated_network_(nullptr),
stefan4fbd1452015-09-28 03:57:14 -070068 start_bitrate_bps_(start_bitrate_bps),
stefan5a2c5062017-01-27 06:43:18 -080069 min_run_time_ms_(min_run_time_ms),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000070 expected_bitrate_bps_(0),
Erik Språngf3a7c9d2015-10-05 14:03:22 +020071 test_start_ms_(-1),
stefan4fbd1452015-09-28 03:57:14 -070072 ramp_up_finished_ms_(-1),
73 extension_type_(extension_type),
stefanff483612015-12-21 03:14:00 -080074 video_ssrcs_(GenerateSsrcs(num_video_streams_, 100)),
75 video_rtx_ssrcs_(GenerateSsrcs(num_video_streams_, 200)),
76 audio_ssrcs_(GenerateSsrcs(num_audio_streams_, 300)),
Peter Boström8c38e8b2015-11-26 17:45:47 +010077 poller_thread_(&BitrateStatsPollingThread,
78 this,
mflodman86cc6ff2016-07-26 04:44:06 -070079 "BitrateStatsPollingThread") {
philipel5ef2bc12017-02-21 07:28:31 -080080 if (red_)
81 EXPECT_EQ(0u, num_flexfec_streams_);
Stefan Holmerff2a6352016-01-14 10:00:21 +010082 EXPECT_LE(num_audio_streams_, 1u);
stefan4fbd1452015-09-28 03:57:14 -070083}
84
Yves Gerey665174f2018-06-19 15:03:05 +020085RampUpTester::~RampUpTester() {}
stefan4fbd1452015-09-28 03:57:14 -070086
Sebastian Jansson72582242018-07-13 13:19:42 +020087void RampUpTester::ModifySenderCallConfig(Call::Config* config) {
stefan4fbd1452015-09-28 03:57:14 -070088 if (start_bitrate_bps_ != 0) {
Sebastian Jansson72582242018-07-13 13:19:42 +020089 config->bitrate_config.start_bitrate_bps = start_bitrate_bps_;
stefan4fbd1452015-09-28 03:57:14 -070090 }
Sebastian Jansson72582242018-07-13 13:19:42 +020091 config->bitrate_config.min_bitrate_bps = 10000;
stefan4fbd1452015-09-28 03:57:14 -070092}
93
stefanff483612015-12-21 03:14:00 -080094void RampUpTester::OnVideoStreamsCreated(
stefan4fbd1452015-09-28 03:57:14 -070095 VideoSendStream* send_stream,
96 const std::vector<VideoReceiveStream*>& receive_streams) {
97 send_stream_ = send_stream;
98}
99
eladalon413ee9a2017-08-22 04:02:52 -0700100test::PacketTransport* RampUpTester::CreateSendTransport(
101 test::SingleThreadedTaskQueueForTesting* task_queue,
102 Call* sender_call) {
Artem Titov631cafa2018-08-21 21:01:00 +0200103 auto network = absl::make_unique<SimulatedNetwork>(forward_transport_config_);
104 send_simulated_network_ = network.get();
minyue20c84cc2017-04-10 16:57:57 -0700105 send_transport_ = new test::PacketTransport(
eladalon413ee9a2017-08-22 04:02:52 -0700106 task_queue, sender_call, this, test::PacketTransport::kSender,
Artem Titov4e199e92018-08-20 13:30:39 +0200107 test::CallTest::payload_type_map_,
Artem Titov631cafa2018-08-21 21:01:00 +0200108 absl::make_unique<FakeNetworkPipe>(Clock::GetRealTimeClock(),
109 std::move(network)));
stefane74eef12016-01-08 06:47:13 -0800110 return send_transport_;
stefanf116bd02015-10-27 08:29:42 -0700111}
112
Stefan Holmerd20e6512016-01-12 15:51:22 +0100113size_t RampUpTester::GetNumVideoStreams() const {
114 return num_video_streams_;
115}
116
Stefan Holmerff2a6352016-01-14 10:00:21 +0100117size_t RampUpTester::GetNumAudioStreams() const {
118 return num_audio_streams_;
119}
120
philipel5ef2bc12017-02-21 07:28:31 -0800121size_t RampUpTester::GetNumFlexfecStreams() const {
122 return num_flexfec_streams_;
123}
124
perkjfa10b552016-10-02 23:45:26 -0700125class RampUpTester::VideoStreamFactory
126 : public VideoEncoderConfig::VideoStreamFactoryInterface {
127 public:
128 VideoStreamFactory() {}
129
130 private:
131 std::vector<VideoStream> CreateEncoderStreams(
132 int width,
133 int height,
134 const VideoEncoderConfig& encoder_config) override {
135 std::vector<VideoStream> streams =
136 test::CreateVideoStreams(width, height, encoder_config);
137 if (encoder_config.number_of_streams == 1) {
138 streams[0].target_bitrate_bps = streams[0].max_bitrate_bps = 2000000;
139 }
140 return streams;
141 }
142};
143
stefanff483612015-12-21 03:14:00 -0800144void RampUpTester::ModifyVideoConfigs(
stefan4fbd1452015-09-28 03:57:14 -0700145 VideoSendStream::Config* send_config,
146 std::vector<VideoReceiveStream::Config>* receive_configs,
147 VideoEncoderConfig* encoder_config) {
148 send_config->suspend_below_min_bitrate = true;
perkjfa10b552016-10-02 23:45:26 -0700149 encoder_config->number_of_streams = num_video_streams_;
150 encoder_config->max_bitrate_bps = 2000000;
151 encoder_config->video_stream_factory =
152 new rtc::RefCountedObject<RampUpTester::VideoStreamFactory>();
stefanff483612015-12-21 03:14:00 -0800153 if (num_video_streams_ == 1) {
stefan4fbd1452015-09-28 03:57:14 -0700154 // For single stream rampup until 1mbps
155 expected_bitrate_bps_ = kSingleStreamTargetBps;
156 } else {
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200157 // To ensure simulcast rate allocation.
158 send_config->rtp.payload_name = "VP8";
159 encoder_config->codec_type = kVideoCodecVP8;
perkjfa10b552016-10-02 23:45:26 -0700160 std::vector<VideoStream> streams = test::CreateVideoStreams(
161 test::CallTest::kDefaultWidth, test::CallTest::kDefaultHeight,
162 *encoder_config);
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200163 // For multi stream rampup until all streams are being sent. That means
164 // enough bitrate to send all the target streams plus the min bitrate of
165 // the last one.
perkjfa10b552016-10-02 23:45:26 -0700166 expected_bitrate_bps_ = streams.back().min_bitrate_bps;
167 for (size_t i = 0; i < streams.size() - 1; ++i) {
168 expected_bitrate_bps_ += streams[i].target_bitrate_bps;
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000169 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000170 }
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000171
stefan4fbd1452015-09-28 03:57:14 -0700172 send_config->rtp.extensions.clear();
173
174 bool remb;
stefan43edf0f2015-11-20 18:05:48 -0800175 bool transport_cc;
isheriff6f8d6862016-05-26 11:24:55 -0700176 if (extension_type_ == RtpExtension::kAbsSendTimeUri) {
stefan4fbd1452015-09-28 03:57:14 -0700177 remb = true;
stefan43edf0f2015-11-20 18:05:48 -0800178 transport_cc = false;
stefan4fbd1452015-09-28 03:57:14 -0700179 send_config->rtp.extensions.push_back(
180 RtpExtension(extension_type_.c_str(), kAbsSendTimeExtensionId));
isheriff6f8d6862016-05-26 11:24:55 -0700181 } else if (extension_type_ == RtpExtension::kTransportSequenceNumberUri) {
stefan4fbd1452015-09-28 03:57:14 -0700182 remb = false;
stefan43edf0f2015-11-20 18:05:48 -0800183 transport_cc = true;
stefan4fbd1452015-09-28 03:57:14 -0700184 send_config->rtp.extensions.push_back(RtpExtension(
185 extension_type_.c_str(), kTransportSequenceNumberExtensionId));
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000186 } else {
stefan4fbd1452015-09-28 03:57:14 -0700187 remb = true;
stefan43edf0f2015-11-20 18:05:48 -0800188 transport_cc = false;
stefan4fbd1452015-09-28 03:57:14 -0700189 send_config->rtp.extensions.push_back(RtpExtension(
190 extension_type_.c_str(), kTransmissionTimeOffsetExtensionId));
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000191 }
stefan4fbd1452015-09-28 03:57:14 -0700192
193 send_config->rtp.nack.rtp_history_ms = test::CallTest::kNackRtpHistoryMs;
stefanff483612015-12-21 03:14:00 -0800194 send_config->rtp.ssrcs = video_ssrcs_;
stefan4fbd1452015-09-28 03:57:14 -0700195 if (rtx_) {
196 send_config->rtp.rtx.payload_type = test::CallTest::kSendRtxPayloadType;
stefanff483612015-12-21 03:14:00 -0800197 send_config->rtp.rtx.ssrcs = video_rtx_ssrcs_;
stefan4fbd1452015-09-28 03:57:14 -0700198 }
199 if (red_) {
brandtrb5f2c3f2016-10-04 23:28:39 -0700200 send_config->rtp.ulpfec.ulpfec_payload_type =
stefan4fbd1452015-09-28 03:57:14 -0700201 test::CallTest::kUlpfecPayloadType;
brandtrb5f2c3f2016-10-04 23:28:39 -0700202 send_config->rtp.ulpfec.red_payload_type = test::CallTest::kRedPayloadType;
brandtrfbfb5362016-11-17 04:18:37 -0800203 if (rtx_) {
204 send_config->rtp.ulpfec.red_rtx_payload_type =
205 test::CallTest::kRtxRedPayloadType;
206 }
stefan4fbd1452015-09-28 03:57:14 -0700207 }
208
209 size_t i = 0;
210 for (VideoReceiveStream::Config& recv_config : *receive_configs) {
211 recv_config.rtp.remb = remb;
stefan43edf0f2015-11-20 18:05:48 -0800212 recv_config.rtp.transport_cc = transport_cc;
stefan4fbd1452015-09-28 03:57:14 -0700213 recv_config.rtp.extensions = send_config->rtp.extensions;
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200214 recv_config.decoders.reserve(1);
215 recv_config.decoders[0].payload_type = send_config->rtp.payload_type;
Niels Möllercb7e1d22018-09-11 15:56:04 +0200216 recv_config.decoders[0].video_format =
217 SdpVideoFormat(send_config->rtp.payload_name);
stefan4fbd1452015-09-28 03:57:14 -0700218
stefanff483612015-12-21 03:14:00 -0800219 recv_config.rtp.remote_ssrc = video_ssrcs_[i];
stefan4fbd1452015-09-28 03:57:14 -0700220 recv_config.rtp.nack.rtp_history_ms = send_config->rtp.nack.rtp_history_ms;
221
222 if (red_) {
nisse3b3622f2017-09-26 02:49:21 -0700223 recv_config.rtp.red_payload_type =
brandtrb5f2c3f2016-10-04 23:28:39 -0700224 send_config->rtp.ulpfec.red_payload_type;
nisse3b3622f2017-09-26 02:49:21 -0700225 recv_config.rtp.ulpfec_payload_type =
brandtrb5f2c3f2016-10-04 23:28:39 -0700226 send_config->rtp.ulpfec.ulpfec_payload_type;
brandtrfbfb5362016-11-17 04:18:37 -0800227 if (rtx_) {
nisseca5706d2017-09-11 02:32:16 -0700228 recv_config.rtp.rtx_associated_payload_types
229 [send_config->rtp.ulpfec.red_rtx_payload_type] =
230 send_config->rtp.ulpfec.red_payload_type;
brandtrfbfb5362016-11-17 04:18:37 -0800231 }
stefan4fbd1452015-09-28 03:57:14 -0700232 }
233
234 if (rtx_) {
brandtr14742122017-01-27 04:53:07 -0800235 recv_config.rtp.rtx_ssrc = video_rtx_ssrcs_[i];
236 recv_config.rtp
nisse26e3abb2017-08-25 04:44:25 -0700237 .rtx_associated_payload_types[send_config->rtp.rtx.payload_type] =
Niels Möller259a4972018-04-05 15:36:51 +0200238 send_config->rtp.payload_type;
stefan4fbd1452015-09-28 03:57:14 -0700239 }
240 ++i;
241 }
philipel5ef2bc12017-02-21 07:28:31 -0800242
243 RTC_DCHECK_LE(num_flexfec_streams_, 1);
244 if (num_flexfec_streams_ == 1) {
245 send_config->rtp.flexfec.payload_type = test::CallTest::kFlexfecPayloadType;
246 send_config->rtp.flexfec.ssrc = test::CallTest::kFlexfecSendSsrc;
247 send_config->rtp.flexfec.protected_media_ssrcs = {video_ssrcs_[0]};
248 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000249}
250
Stefan Holmerff2a6352016-01-14 10:00:21 +0100251void RampUpTester::ModifyAudioConfigs(
252 AudioSendStream::Config* send_config,
253 std::vector<AudioReceiveStream::Config>* receive_configs) {
254 if (num_audio_streams_ == 0)
255 return;
256
isheriff6f8d6862016-05-26 11:24:55 -0700257 EXPECT_NE(RtpExtension::kTimestampOffsetUri, extension_type_)
Stefan Holmerff2a6352016-01-14 10:00:21 +0100258 << "Audio BWE not supported with toffset.";
philipel5ef2bc12017-02-21 07:28:31 -0800259 EXPECT_NE(RtpExtension::kAbsSendTimeUri, extension_type_)
260 << "Audio BWE not supported with abs-send-time.";
Stefan Holmerff2a6352016-01-14 10:00:21 +0100261
262 send_config->rtp.ssrc = audio_ssrcs_[0];
263 send_config->rtp.extensions.clear();
264
minyue10cbb462016-11-07 09:29:22 -0800265 send_config->min_bitrate_bps = 6000;
266 send_config->max_bitrate_bps = 60000;
mflodman86cc6ff2016-07-26 04:44:06 -0700267
Stefan Holmerff2a6352016-01-14 10:00:21 +0100268 bool transport_cc = false;
philipel5ef2bc12017-02-21 07:28:31 -0800269 if (extension_type_ == RtpExtension::kTransportSequenceNumberUri) {
Stefan Holmerff2a6352016-01-14 10:00:21 +0100270 transport_cc = true;
271 send_config->rtp.extensions.push_back(RtpExtension(
272 extension_type_.c_str(), kTransportSequenceNumberExtensionId));
273 }
274
275 for (AudioReceiveStream::Config& recv_config : *receive_configs) {
Stefan Holmerff2a6352016-01-14 10:00:21 +0100276 recv_config.rtp.transport_cc = transport_cc;
277 recv_config.rtp.extensions = send_config->rtp.extensions;
278 recv_config.rtp.remote_ssrc = send_config->rtp.ssrc;
279 }
280}
281
philipel5ef2bc12017-02-21 07:28:31 -0800282void RampUpTester::ModifyFlexfecConfigs(
283 std::vector<FlexfecReceiveStream::Config>* receive_configs) {
284 if (num_flexfec_streams_ == 0)
285 return;
286 RTC_DCHECK_EQ(1, num_flexfec_streams_);
287 (*receive_configs)[0].payload_type = test::CallTest::kFlexfecPayloadType;
288 (*receive_configs)[0].remote_ssrc = test::CallTest::kFlexfecSendSsrc;
289 (*receive_configs)[0].protected_media_ssrcs = {video_ssrcs_[0]};
290 (*receive_configs)[0].local_ssrc = video_ssrcs_[0];
291 if (extension_type_ == RtpExtension::kAbsSendTimeUri) {
292 (*receive_configs)[0].transport_cc = false;
293 (*receive_configs)[0].rtp_header_extensions.push_back(
294 RtpExtension(extension_type_.c_str(), kAbsSendTimeExtensionId));
295 } else if (extension_type_ == RtpExtension::kTransportSequenceNumberUri) {
296 (*receive_configs)[0].transport_cc = true;
297 (*receive_configs)[0].rtp_header_extensions.push_back(RtpExtension(
298 extension_type_.c_str(), kTransportSequenceNumberExtensionId));
299 }
300}
301
stefan4fbd1452015-09-28 03:57:14 -0700302void RampUpTester::OnCallsCreated(Call* sender_call, Call* receiver_call) {
303 sender_call_ = sender_call;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000304}
305
tommi0f8b4032017-02-22 11:22:05 -0800306void RampUpTester::BitrateStatsPollingThread(void* obj) {
307 static_cast<RampUpTester*>(obj)->PollStats();
pbos@webrtc.org32452b22014-10-22 12:15:24 +0000308}
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000309
tommi0f8b4032017-02-22 11:22:05 -0800310void RampUpTester::PollStats() {
311 do {
312 if (sender_call_) {
313 Call::Stats stats = sender_call_->GetStats();
stefan4fbd1452015-09-28 03:57:14 -0700314
tommi0f8b4032017-02-22 11:22:05 -0800315 EXPECT_GE(expected_bitrate_bps_, 0);
316 if (stats.send_bandwidth_bps >= expected_bitrate_bps_ &&
317 (min_run_time_ms_ == -1 ||
318 clock_->TimeInMilliseconds() - test_start_ms_ >= min_run_time_ms_)) {
319 ramp_up_finished_ms_ = clock_->TimeInMilliseconds();
320 observation_complete_.Set();
321 }
stefan4fbd1452015-09-28 03:57:14 -0700322 }
tommi0f8b4032017-02-22 11:22:05 -0800323 } while (!stop_event_.Wait(kPollIntervalMs));
Erik Språng468e62a2015-07-06 10:50:47 +0200324}
325
stefan4fbd1452015-09-28 03:57:14 -0700326void RampUpTester::ReportResult(const std::string& measurement,
327 size_t value,
328 const std::string& units) const {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000329 webrtc::test::PrintResult(
330 measurement, "",
stefanff483612015-12-21 03:14:00 -0800331 ::testing::UnitTest::GetInstance()->current_test_info()->name(), value,
332 units, false);
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000333}
334
stefan092508a2015-09-29 02:26:42 -0700335void RampUpTester::AccumulateStats(const VideoSendStream::StreamStats& stream,
336 size_t* total_packets_sent,
337 size_t* total_sent,
338 size_t* padding_sent,
339 size_t* media_sent) const {
stefan4fbd1452015-09-28 03:57:14 -0700340 *total_packets_sent += stream.rtp_stats.transmitted.packets +
341 stream.rtp_stats.retransmitted.packets +
342 stream.rtp_stats.fec.packets;
343 *total_sent += stream.rtp_stats.transmitted.TotalBytes() +
344 stream.rtp_stats.retransmitted.TotalBytes() +
345 stream.rtp_stats.fec.TotalBytes();
346 *padding_sent += stream.rtp_stats.transmitted.padding_bytes +
347 stream.rtp_stats.retransmitted.padding_bytes +
348 stream.rtp_stats.fec.padding_bytes;
349 *media_sent += stream.rtp_stats.MediaPayloadBytes();
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000350}
351
stefan4fbd1452015-09-28 03:57:14 -0700352void RampUpTester::TriggerTestDone() {
Erik Språngf3a7c9d2015-10-05 14:03:22 +0200353 RTC_DCHECK_GE(test_start_ms_, 0);
354
Stefan Holmerff2a6352016-01-14 10:00:21 +0100355 // TODO(holmer): Add audio send stats here too when those APIs are available.
mflodman86cc6ff2016-07-26 04:44:06 -0700356 if (!send_stream_)
357 return;
358
stefan4fbd1452015-09-28 03:57:14 -0700359 VideoSendStream::Stats send_stats = send_stream_->GetStats();
360
361 size_t total_packets_sent = 0;
362 size_t total_sent = 0;
363 size_t padding_sent = 0;
364 size_t media_sent = 0;
stefanff483612015-12-21 03:14:00 -0800365 for (uint32_t ssrc : video_ssrcs_) {
stefan092508a2015-09-29 02:26:42 -0700366 AccumulateStats(send_stats.substreams[ssrc], &total_packets_sent,
367 &total_sent, &padding_sent, &media_sent);
stefan4fbd1452015-09-28 03:57:14 -0700368 }
369
370 size_t rtx_total_packets_sent = 0;
371 size_t rtx_total_sent = 0;
372 size_t rtx_padding_sent = 0;
373 size_t rtx_media_sent = 0;
stefanff483612015-12-21 03:14:00 -0800374 for (uint32_t rtx_ssrc : video_rtx_ssrcs_) {
stefan092508a2015-09-29 02:26:42 -0700375 AccumulateStats(send_stats.substreams[rtx_ssrc], &rtx_total_packets_sent,
376 &rtx_total_sent, &rtx_padding_sent, &rtx_media_sent);
stefan4fbd1452015-09-28 03:57:14 -0700377 }
378
stefan5a2c5062017-01-27 06:43:18 -0800379 if (report_perf_stats_) {
stefan5a2c5062017-01-27 06:43:18 -0800380 ReportResult("ramp-up-media-sent", media_sent, "bytes");
381 ReportResult("ramp-up-padding-sent", padding_sent, "bytes");
stefan5a2c5062017-01-27 06:43:18 -0800382 ReportResult("ramp-up-rtx-media-sent", rtx_media_sent, "bytes");
383 ReportResult("ramp-up-rtx-padding-sent", rtx_padding_sent, "bytes");
384 if (ramp_up_finished_ms_ >= 0) {
385 ReportResult("ramp-up-time", ramp_up_finished_ms_ - test_start_ms_,
386 "milliseconds");
387 }
388 ReportResult("ramp-up-average-network-latency",
389 send_transport_->GetAverageDelayMs(), "milliseconds");
stefan4fbd1452015-09-28 03:57:14 -0700390 }
391}
392
393void RampUpTester::PerformTest() {
Erik Språngf3a7c9d2015-10-05 14:03:22 +0200394 test_start_ms_ = clock_->TimeInMilliseconds();
Peter Boström8c38e8b2015-11-26 17:45:47 +0100395 poller_thread_.Start();
Peter Boström5811a392015-12-10 13:02:50 +0100396 EXPECT_TRUE(Wait()) << "Timed out while waiting for ramp-up to complete.";
stefan4fbd1452015-09-28 03:57:14 -0700397 TriggerTestDone();
tommi0f8b4032017-02-22 11:22:05 -0800398 stop_event_.Set();
Peter Boström8c38e8b2015-11-26 17:45:47 +0100399 poller_thread_.Stop();
stefan4fbd1452015-09-28 03:57:14 -0700400}
401
Stefan Holmerff2a6352016-01-14 10:00:21 +0100402RampUpDownUpTester::RampUpDownUpTester(size_t num_video_streams,
403 size_t num_audio_streams,
philipel5ef2bc12017-02-21 07:28:31 -0800404 size_t num_flexfec_streams,
stefan4fbd1452015-09-28 03:57:14 -0700405 unsigned int start_bitrate_bps,
406 const std::string& extension_type,
407 bool rtx,
philipel5ef2bc12017-02-21 07:28:31 -0800408 bool red,
stefan45b5fe52017-03-09 06:27:02 -0800409 const std::vector<int>& loss_rates,
410 bool report_perf_stats)
Stefan Holmerff2a6352016-01-14 10:00:21 +0100411 : RampUpTester(num_video_streams,
412 num_audio_streams,
philipel5ef2bc12017-02-21 07:28:31 -0800413 num_flexfec_streams,
Stefan Holmerff2a6352016-01-14 10:00:21 +0100414 start_bitrate_bps,
stefan5a2c5062017-01-27 06:43:18 -0800415 0,
Stefan Holmerff2a6352016-01-14 10:00:21 +0100416 extension_type,
417 rtx,
stefan5a2c5062017-01-27 06:43:18 -0800418 red,
stefan45b5fe52017-03-09 06:27:02 -0800419 report_perf_stats),
stefan76d9c9c2017-04-01 06:51:09 -0700420 link_rates_({4 * GetExpectedHighBitrate() / (3 * 1000),
421 kLowBandwidthLimitBps / 1000,
422 4 * GetExpectedHighBitrate() / (3 * 1000), 0}),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000423 test_state_(kFirstRampup),
philipel5ef2bc12017-02-21 07:28:31 -0800424 next_state_(kTransitionToNextState),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000425 state_start_ms_(clock_->TimeInMilliseconds()),
stefan4fbd1452015-09-28 03:57:14 -0700426 interval_start_ms_(clock_->TimeInMilliseconds()),
philipel5ef2bc12017-02-21 07:28:31 -0800427 sent_bytes_(0),
428 loss_rates_(loss_rates) {
429 forward_transport_config_.link_capacity_kbps = link_rates_[test_state_];
430 forward_transport_config_.queue_delay_ms = 100;
431 forward_transport_config_.loss_percent = loss_rates_[test_state_];
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000432}
433
stefan4fbd1452015-09-28 03:57:14 -0700434RampUpDownUpTester::~RampUpDownUpTester() {}
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000435
tommi0f8b4032017-02-22 11:22:05 -0800436void RampUpDownUpTester::PollStats() {
437 do {
Alex Narest78609d52017-10-20 10:37:47 +0200438 int transmit_bitrate_bps = 0;
439 bool suspended = false;
440 if (num_video_streams_ > 0) {
tommi0f8b4032017-02-22 11:22:05 -0800441 webrtc::VideoSendStream::Stats stats = send_stream_->GetStats();
tommi0f8b4032017-02-22 11:22:05 -0800442 for (auto it : stats.substreams) {
443 transmit_bitrate_bps += it.second.total_bitrate_bps;
444 }
Alex Narest78609d52017-10-20 10:37:47 +0200445 suspended = stats.suspended;
446 }
447 if (num_audio_streams_ > 0 && sender_call_ != nullptr) {
tommi0f8b4032017-02-22 11:22:05 -0800448 // An audio send stream doesn't have bitrate stats, so the call send BW is
449 // currently used instead.
Alex Narest78609d52017-10-20 10:37:47 +0200450 transmit_bitrate_bps = sender_call_->GetStats().send_bandwidth_bps;
mflodman@webrtc.orgeb16b812014-06-16 08:57:39 +0000451 }
Alex Narest78609d52017-10-20 10:37:47 +0200452 EvolveTestState(transmit_bitrate_bps, suspended);
tommi0f8b4032017-02-22 11:22:05 -0800453 } while (!stop_event_.Wait(kPollIntervalMs));
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000454}
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000455
Sebastian Jansson72582242018-07-13 13:19:42 +0200456void RampUpDownUpTester::ModifyReceiverCallConfig(Call::Config* config) {
457 config->bitrate_config.min_bitrate_bps = 10000;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000458}
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000459
stefan4fbd1452015-09-28 03:57:14 -0700460std::string RampUpDownUpTester::GetModifierString() const {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000461 std::string str("_");
stefanff483612015-12-21 03:14:00 -0800462 if (num_video_streams_ > 0) {
Jonas Olsson0a713b62018-04-04 15:49:32 +0200463 str += rtc::ToString(num_video_streams_);
stefanff483612015-12-21 03:14:00 -0800464 str += "stream";
465 str += (num_video_streams_ > 1 ? "s" : "");
466 str += "_";
467 }
468 if (num_audio_streams_ > 0) {
Jonas Olsson0a713b62018-04-04 15:49:32 +0200469 str += rtc::ToString(num_audio_streams_);
stefanff483612015-12-21 03:14:00 -0800470 str += "stream";
471 str += (num_audio_streams_ > 1 ? "s" : "");
472 str += "_";
473 }
stefan4fbd1452015-09-28 03:57:14 -0700474 str += (rtx_ ? "" : "no");
Edward Lemurdd3987f2018-01-04 19:44:54 +0100475 str += "rtx_";
476 str += (red_ ? "" : "no");
477 str += "red";
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000478 return str;
479}
andresp@webrtc.orgc1480792014-03-20 03:23:55 +0000480
stefandb752f92016-12-05 08:23:40 -0800481int RampUpDownUpTester::GetExpectedHighBitrate() const {
stefan38d8b3c2017-01-09 04:19:24 -0800482 int expected_bitrate_bps = 0;
483 if (num_audio_streams_ > 0)
484 expected_bitrate_bps += kExpectedHighAudioBitrateBps;
485 if (num_video_streams_ > 0)
486 expected_bitrate_bps += kExpectedHighVideoBitrateBps;
487 return expected_bitrate_bps;
488}
489
philipel5ef2bc12017-02-21 07:28:31 -0800490size_t RampUpDownUpTester::GetFecBytes() const {
491 size_t flex_fec_bytes = 0;
492 if (num_flexfec_streams_ > 0) {
493 webrtc::VideoSendStream::Stats stats = send_stream_->GetStats();
494 for (const auto& kv : stats.substreams)
495 flex_fec_bytes += kv.second.rtp_stats.fec.TotalBytes();
496 }
497 return flex_fec_bytes;
498}
499
500bool RampUpDownUpTester::ExpectingFec() const {
501 return num_flexfec_streams_ > 0 && forward_transport_config_.loss_percent > 0;
502}
503
stefan4fbd1452015-09-28 03:57:14 -0700504void RampUpDownUpTester::EvolveTestState(int bitrate_bps, bool suspended) {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000505 int64_t now = clock_->TimeInMilliseconds();
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000506 switch (test_state_) {
philipel5ef2bc12017-02-21 07:28:31 -0800507 case kFirstRampup:
stefan4fbd1452015-09-28 03:57:14 -0700508 EXPECT_FALSE(suspended);
stefandb752f92016-12-05 08:23:40 -0800509 if (bitrate_bps >= GetExpectedHighBitrate()) {
stefan45b5fe52017-03-09 06:27:02 -0800510 if (report_perf_stats_) {
511 webrtc::test::PrintResult("ramp_up_down_up", GetModifierString(),
512 "first_rampup", now - state_start_ms_, "ms",
513 false);
514 }
philipel5ef2bc12017-02-21 07:28:31 -0800515 // Apply loss during the transition between states if FEC is enabled.
516 forward_transport_config_.loss_percent = loss_rates_[test_state_];
517 test_state_ = kTransitionToNextState;
518 next_state_ = kLowRate;
andresp@webrtc.orgc1480792014-03-20 03:23:55 +0000519 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000520 break;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000521 case kLowRate: {
mflodman86cc6ff2016-07-26 04:44:06 -0700522 // Audio streams are never suspended.
523 bool check_suspend_state = num_video_streams_ > 0;
Sebastian Jansson12fb1702018-02-23 11:34:18 +0100524 if (bitrate_bps < kLowBandwidthLimitBps + kLowBitrateMarginBps &&
mflodman86cc6ff2016-07-26 04:44:06 -0700525 suspended == check_suspend_state) {
stefan45b5fe52017-03-09 06:27:02 -0800526 if (report_perf_stats_) {
527 webrtc::test::PrintResult("ramp_up_down_up", GetModifierString(),
528 "rampdown", now - state_start_ms_, "ms",
529 false);
530 }
philipel5ef2bc12017-02-21 07:28:31 -0800531 // Apply loss during the transition between states if FEC is enabled.
532 forward_transport_config_.loss_percent = loss_rates_[test_state_];
533 test_state_ = kTransitionToNextState;
534 next_state_ = kSecondRampup;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000535 }
536 break;
537 }
philipel5ef2bc12017-02-21 07:28:31 -0800538 case kSecondRampup:
stefandb752f92016-12-05 08:23:40 -0800539 if (bitrate_bps >= GetExpectedHighBitrate() && !suspended) {
stefan45b5fe52017-03-09 06:27:02 -0800540 if (report_perf_stats_) {
541 webrtc::test::PrintResult("ramp_up_down_up", GetModifierString(),
542 "second_rampup", now - state_start_ms_,
543 "ms", false);
544 ReportResult("ramp-up-down-up-average-network-latency",
545 send_transport_->GetAverageDelayMs(), "milliseconds");
546 }
philipel5ef2bc12017-02-21 07:28:31 -0800547 // Apply loss during the transition between states if FEC is enabled.
548 forward_transport_config_.loss_percent = loss_rates_[test_state_];
549 test_state_ = kTransitionToNextState;
550 next_state_ = kTestEnd;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000551 }
552 break;
philipel5ef2bc12017-02-21 07:28:31 -0800553 case kTestEnd:
554 observation_complete_.Set();
555 break;
556 case kTransitionToNextState:
557 if (!ExpectingFec() || GetFecBytes() > 0) {
558 test_state_ = next_state_;
559 forward_transport_config_.link_capacity_kbps = link_rates_[test_state_];
560 // No loss while ramping up and down as it may affect the BWE
561 // negatively, making the test flaky.
562 forward_transport_config_.loss_percent = 0;
563 state_start_ms_ = now;
564 interval_start_ms_ = now;
565 sent_bytes_ = 0;
Artem Titov631cafa2018-08-21 21:01:00 +0200566 send_simulated_network_->SetConfig(forward_transport_config_);
philipel5ef2bc12017-02-21 07:28:31 -0800567 }
568 break;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000569 }
570}
pbos@webrtc.orgf577ae92014-03-19 08:43:57 +0000571
stefan4fbd1452015-09-28 03:57:14 -0700572class RampUpTest : public test::CallTest {
Erik Språng6b8d3552015-09-24 15:06:57 +0200573 public:
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200574 RampUpTest() {
575 std::string dump_name(FLAG_ramp_dump_name);
576 if (!dump_name.empty()) {
577 send_event_log_ = RtcEventLog::Create(RtcEventLog::EncodingType::Legacy);
578 recv_event_log_ = RtcEventLog::Create(RtcEventLog::EncodingType::Legacy);
579 bool event_log_started =
580 send_event_log_->StartLogging(
581 absl::make_unique<RtcEventLogOutputFile>(
582 dump_name + ".send.rtc.dat", RtcEventLog::kUnlimitedOutput),
583 RtcEventLog::kImmediateOutput) &&
584 recv_event_log_->StartLogging(
585 absl::make_unique<RtcEventLogOutputFile>(
586 dump_name + ".recv.rtc.dat", RtcEventLog::kUnlimitedOutput),
587 RtcEventLog::kImmediateOutput);
588 RTC_DCHECK(event_log_started);
589 }
590 }
Erik Språng6b8d3552015-09-24 15:06:57 +0200591};
592
Stefan Holmerff2a6352016-01-14 10:00:21 +0100593static const uint32_t kStartBitrateBps = 60000;
594
stefan38d8b3c2017-01-09 04:19:24 -0800595TEST_F(RampUpTest, UpDownUpAbsSendTimeSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800596 std::vector<int> loss_rates = {0, 0, 0, 0};
597 RampUpDownUpTester test(3, 0, 0, kStartBitrateBps,
stefan45b5fe52017-03-09 06:27:02 -0800598 RtpExtension::kAbsSendTimeUri, true, true, loss_rates,
599 true);
stefane74eef12016-01-08 06:47:13 -0800600 RunBaseTest(&test);
Shao Changbine62202f2015-04-21 20:24:50 +0800601}
Stefan Holmerff2a6352016-01-14 10:00:21 +0100602
Taylor Brandstetterba6b5032018-02-16 09:59:56 -0800603// TODO(bugs.webrtc.org/8878)
604#if defined(WEBRTC_MAC)
605#define MAYBE_UpDownUpTransportSequenceNumberRtx \
606 DISABLED_UpDownUpTransportSequenceNumberRtx
607#else
608#define MAYBE_UpDownUpTransportSequenceNumberRtx \
609 UpDownUpTransportSequenceNumberRtx
610#endif
611TEST_F(RampUpTest, MAYBE_UpDownUpTransportSequenceNumberRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800612 std::vector<int> loss_rates = {0, 0, 0, 0};
613 RampUpDownUpTester test(3, 0, 0, kStartBitrateBps,
isheriff6f8d6862016-05-26 11:24:55 -0700614 RtpExtension::kTransportSequenceNumberUri, true,
stefan45b5fe52017-03-09 06:27:02 -0800615 false, loss_rates, true);
philipel5ef2bc12017-02-21 07:28:31 -0800616 RunBaseTest(&test);
617}
618
stefan45b5fe52017-03-09 06:27:02 -0800619// TODO(holmer): Tests which don't report perf stats should be moved to a
620// different executable since they per definition are not perf tests.
Taylor Brandstetter05d98222017-10-10 12:12:53 -0700621// This test is disabled because it crashes on Linux, and is flaky on other
622// platforms. See: crbug.com/webrtc/7919
623TEST_F(RampUpTest, DISABLED_UpDownUpTransportSequenceNumberPacketLoss) {
philipel5ef2bc12017-02-21 07:28:31 -0800624 std::vector<int> loss_rates = {20, 0, 0, 0};
625 RampUpDownUpTester test(1, 0, 1, kStartBitrateBps,
626 RtpExtension::kTransportSequenceNumberUri, true,
stefan45b5fe52017-03-09 06:27:02 -0800627 false, loss_rates, false);
Stefan Holmerff2a6352016-01-14 10:00:21 +0100628 RunBaseTest(&test);
629}
630
Taylor Brandstetterab86e7f2018-02-12 15:16:02 -0800631// TODO(bugs.webrtc.org/8878)
632#if defined(WEBRTC_MAC)
633#define MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx \
634 DISABLED_UpDownUpAudioVideoTransportSequenceNumberRtx
635#else
636#define MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx \
637 UpDownUpAudioVideoTransportSequenceNumberRtx
638#endif
639TEST_F(RampUpTest, MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800640 std::vector<int> loss_rates = {0, 0, 0, 0};
641 RampUpDownUpTester test(3, 1, 0, kStartBitrateBps,
isheriff6f8d6862016-05-26 11:24:55 -0700642 RtpExtension::kTransportSequenceNumberUri, true,
stefanff2ebf52017-03-13 01:27:03 -0700643 false, loss_rates, false);
Stefan Holmerff2a6352016-01-14 10:00:21 +0100644 RunBaseTest(&test);
645}
646
stefan38d8b3c2017-01-09 04:19:24 -0800647TEST_F(RampUpTest, UpDownUpAudioTransportSequenceNumberRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800648 std::vector<int> loss_rates = {0, 0, 0, 0};
649 RampUpDownUpTester test(0, 1, 0, kStartBitrateBps,
mflodman86cc6ff2016-07-26 04:44:06 -0700650 RtpExtension::kTransportSequenceNumberUri, true,
stefanff2ebf52017-03-13 01:27:03 -0700651 false, loss_rates, false);
mflodman86cc6ff2016-07-26 04:44:06 -0700652 RunBaseTest(&test);
653}
654
stefan38d8b3c2017-01-09 04:19:24 -0800655TEST_F(RampUpTest, TOffsetSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800656 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kTimestampOffsetUri, true,
657 true, true);
stefan38d8b3c2017-01-09 04:19:24 -0800658 RunBaseTest(&test);
659}
660
661TEST_F(RampUpTest, AbsSendTime) {
philipel5ef2bc12017-02-21 07:28:31 -0800662 RampUpTester test(1, 0, 0, 0, 0, RtpExtension::kAbsSendTimeUri, false, false,
stefanff2ebf52017-03-13 01:27:03 -0700663 false);
stefane74eef12016-01-08 06:47:13 -0800664 RunBaseTest(&test);
pbos@webrtc.org85bd53e2014-12-10 10:36:20 +0000665}
666
stefan38d8b3c2017-01-09 04:19:24 -0800667TEST_F(RampUpTest, AbsSendTimeSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800668 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kAbsSendTimeUri, true, true,
stefan5a2c5062017-01-27 06:43:18 -0800669 true);
stefane74eef12016-01-08 06:47:13 -0800670 RunBaseTest(&test);
pbos@webrtc.org85bd53e2014-12-10 10:36:20 +0000671}
672
stefan38d8b3c2017-01-09 04:19:24 -0800673TEST_F(RampUpTest, TransportSequenceNumber) {
philipel5ef2bc12017-02-21 07:28:31 -0800674 RampUpTester test(1, 0, 0, 0, 0, RtpExtension::kTransportSequenceNumberUri,
stefanff2ebf52017-03-13 01:27:03 -0700675 false, false, false);
stefane74eef12016-01-08 06:47:13 -0800676 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200677}
678
679TEST_F(RampUpTest, TransportSequenceNumberSimulcast) {
philipel5ef2bc12017-02-21 07:28:31 -0800680 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kTransportSequenceNumberUri,
stefanff2ebf52017-03-13 01:27:03 -0700681 false, false, false);
stefane74eef12016-01-08 06:47:13 -0800682 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200683}
684
stefan38d8b3c2017-01-09 04:19:24 -0800685TEST_F(RampUpTest, TransportSequenceNumberSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800686 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kTransportSequenceNumberUri,
stefan5a2c5062017-01-27 06:43:18 -0800687 true, true, true);
688 RunBaseTest(&test);
689}
690
Taylor Brandstetterab86e7f2018-02-12 15:16:02 -0800691// TODO(bugs.webrtc.org/8878)
692#if defined(WEBRTC_MAC)
693#define MAYBE_AudioTransportSequenceNumber DISABLED_AudioTransportSequenceNumber
694#else
695#define MAYBE_AudioTransportSequenceNumber AudioTransportSequenceNumber
696#endif
697TEST_F(RampUpTest, MAYBE_AudioTransportSequenceNumber) {
philipel5ef2bc12017-02-21 07:28:31 -0800698 RampUpTester test(0, 1, 0, 300000, 10000,
stefan5a2c5062017-01-27 06:43:18 -0800699 RtpExtension::kTransportSequenceNumberUri, false, false,
700 false);
stefane74eef12016-01-08 06:47:13 -0800701 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200702}
pbos@webrtc.org744fbc72013-09-10 09:26:25 +0000703} // namespace webrtc