blob: 9c7a2678af5887a14f613fabab6493db80d3e22a [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
Danil Chapovalov304ea5f2019-04-11 15:18:18 +020013#include <memory>
14
Mirko Bonadei2ab97f62019-07-18 13:44:12 +020015#include "absl/flags/flag.h"
Danil Chapovalov4ba04b72019-06-26 15:49:47 +020016#include "api/rtc_event_log/rtc_event_log_factory.h"
Niels Möllerd8b9ed72019-05-08 13:53:51 +020017#include "api/rtc_event_log_output_file.h"
Danil Chapovalov304ea5f2019-04-11 15:18:18 +020018#include "api/task_queue/default_task_queue_factory.h"
Danil Chapovalov44db4362019-09-30 04:16:28 +020019#include "api/task_queue/task_queue_base.h"
Danil Chapovalov304ea5f2019-04-11 15:18:18 +020020#include "api/task_queue/task_queue_factory.h"
Artem Titov4e199e92018-08-20 13:30:39 +020021#include "call/fake_network_pipe.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020022#include "rtc_base/checks.h"
23#include "rtc_base/logging.h"
24#include "rtc_base/platform_thread.h"
Steve Anton10542f22019-01-11 09:11:00 -080025#include "rtc_base/string_encode.h"
Danil Chapovalov82a3f0a2019-10-21 09:24:27 +020026#include "rtc_base/task_queue_for_test.h"
Tommi6b117a52019-08-20 09:58:56 +020027#include "rtc_base/time_utils.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020028#include "test/encoder_settings.h"
Per Kjellander914351d2019-02-15 10:54:55 +010029#include "test/field_trial.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020030#include "test/gtest.h"
31#include "test/testsupport/perf_test.h"
pbos@webrtc.org744fbc72013-09-10 09:26:25 +000032
Mirko Bonadei2ab97f62019-07-18 13:44:12 +020033ABSL_FLAG(std::string,
34 ramp_dump_name,
35 "",
36 "Filename for dumped received RTP stream.");
37
pbos@webrtc.org744fbc72013-09-10 09:26:25 +000038namespace webrtc {
pbos@webrtc.org29023282013-09-11 10:14:56 +000039namespace {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000040
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +020041constexpr TimeDelta kPollInterval = TimeDelta::Millis<20>();
philipel5ef2bc12017-02-21 07:28:31 -080042static const int kExpectedHighVideoBitrateBps = 80000;
stefandb752f92016-12-05 08:23:40 -080043static const int kExpectedHighAudioBitrateBps = 30000;
44static const int kLowBandwidthLimitBps = 20000;
Sebastian Jansson12fb1702018-02-23 11:34:18 +010045// Set target detected bitrate to slightly larger than the target bitrate to
46// avoid flakiness.
47static const int kLowBitrateMarginBps = 2000;
pbos@webrtc.org29023282013-09-11 10:14:56 +000048
stefanff483612015-12-21 03:14:00 -080049std::vector<uint32_t> GenerateSsrcs(size_t num_streams, uint32_t ssrc_offset) {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000050 std::vector<uint32_t> ssrcs;
51 for (size_t i = 0; i != num_streams; ++i)
52 ssrcs.push_back(static_cast<uint32_t>(ssrc_offset + i));
53 return ssrcs;
54}
mflodman@webrtc.orgeb16b812014-06-16 08:57:39 +000055} // namespace
henrik.lundin@webrtc.org845862f2014-03-06 07:19:28 +000056
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +020057RampUpTester::RampUpTester(size_t num_video_streams,
58 size_t num_audio_streams,
59 size_t num_flexfec_streams,
60 unsigned int start_bitrate_bps,
61 int64_t min_run_time_ms,
62 const std::string& extension_type,
63 bool rtx,
64 bool red,
65 bool report_perf_stats,
66 TaskQueueBase* task_queue)
stefan4fbd1452015-09-28 03:57:14 -070067 : EndToEndTest(test::CallTest::kLongTimeoutMs),
stefan4fbd1452015-09-28 03:57:14 -070068 clock_(Clock::GetRealTimeClock()),
stefanff483612015-12-21 03:14:00 -080069 num_video_streams_(num_video_streams),
70 num_audio_streams_(num_audio_streams),
philipel5ef2bc12017-02-21 07:28:31 -080071 num_flexfec_streams_(num_flexfec_streams),
stefan4fbd1452015-09-28 03:57:14 -070072 rtx_(rtx),
73 red_(red),
stefan45b5fe52017-03-09 06:27:02 -080074 report_perf_stats_(report_perf_stats),
mflodman86cc6ff2016-07-26 04:44:06 -070075 sender_call_(nullptr),
stefan4fbd1452015-09-28 03:57:14 -070076 send_stream_(nullptr),
sprang4847ae62017-06-27 07:06:52 -070077 send_transport_(nullptr),
Artem Titov631cafa2018-08-21 21:01:00 +020078 send_simulated_network_(nullptr),
stefan4fbd1452015-09-28 03:57:14 -070079 start_bitrate_bps_(start_bitrate_bps),
stefan5a2c5062017-01-27 06:43:18 -080080 min_run_time_ms_(min_run_time_ms),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000081 expected_bitrate_bps_(0),
Erik Språngf3a7c9d2015-10-05 14:03:22 +020082 test_start_ms_(-1),
stefan4fbd1452015-09-28 03:57:14 -070083 ramp_up_finished_ms_(-1),
84 extension_type_(extension_type),
stefanff483612015-12-21 03:14:00 -080085 video_ssrcs_(GenerateSsrcs(num_video_streams_, 100)),
86 video_rtx_ssrcs_(GenerateSsrcs(num_video_streams_, 200)),
87 audio_ssrcs_(GenerateSsrcs(num_audio_streams_, 300)),
Tommi5e005f42019-08-05 15:29:14 +020088 task_queue_(task_queue) {
philipel5ef2bc12017-02-21 07:28:31 -080089 if (red_)
90 EXPECT_EQ(0u, num_flexfec_streams_);
Stefan Holmerff2a6352016-01-14 10:00:21 +010091 EXPECT_LE(num_audio_streams_, 1u);
stefan4fbd1452015-09-28 03:57:14 -070092}
93
Tommi5e005f42019-08-05 15:29:14 +020094RampUpTester::~RampUpTester() {
95 // Special case for WebRTC-QuickPerfTest/Enabled/
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +020096 SendTask(RTC_FROM_HERE, task_queue_, [this] { pending_task_.Stop(); });
Tommi5e005f42019-08-05 15:29:14 +020097}
stefan4fbd1452015-09-28 03:57:14 -070098
Niels Möllerde8e6e62018-11-13 15:10:33 +010099void RampUpTester::ModifySenderBitrateConfig(
100 BitrateConstraints* bitrate_config) {
stefan4fbd1452015-09-28 03:57:14 -0700101 if (start_bitrate_bps_ != 0) {
Niels Möllerde8e6e62018-11-13 15:10:33 +0100102 bitrate_config->start_bitrate_bps = start_bitrate_bps_;
stefan4fbd1452015-09-28 03:57:14 -0700103 }
Niels Möllerde8e6e62018-11-13 15:10:33 +0100104 bitrate_config->min_bitrate_bps = 10000;
stefan4fbd1452015-09-28 03:57:14 -0700105}
106
stefanff483612015-12-21 03:14:00 -0800107void RampUpTester::OnVideoStreamsCreated(
stefan4fbd1452015-09-28 03:57:14 -0700108 VideoSendStream* send_stream,
109 const std::vector<VideoReceiveStream*>& receive_streams) {
110 send_stream_ = send_stream;
111}
112
Danil Chapovalov44db4362019-09-30 04:16:28 +0200113std::unique_ptr<test::PacketTransport> RampUpTester::CreateSendTransport(
114 TaskQueueBase* task_queue,
eladalon413ee9a2017-08-22 04:02:52 -0700115 Call* sender_call) {
Mirko Bonadei317a1f02019-09-17 17:06:18 +0200116 auto network = std::make_unique<SimulatedNetwork>(forward_transport_config_);
Artem Titov631cafa2018-08-21 21:01:00 +0200117 send_simulated_network_ = network.get();
Danil Chapovalov44db4362019-09-30 04:16:28 +0200118 auto send_transport = std::make_unique<test::PacketTransport>(
eladalon413ee9a2017-08-22 04:02:52 -0700119 task_queue, sender_call, this, test::PacketTransport::kSender,
Artem Titov4e199e92018-08-20 13:30:39 +0200120 test::CallTest::payload_type_map_,
Mirko Bonadei317a1f02019-09-17 17:06:18 +0200121 std::make_unique<FakeNetworkPipe>(Clock::GetRealTimeClock(),
122 std::move(network)));
Danil Chapovalov44db4362019-09-30 04:16:28 +0200123 send_transport_ = send_transport.get();
124 return send_transport;
stefanf116bd02015-10-27 08:29:42 -0700125}
126
Stefan Holmerd20e6512016-01-12 15:51:22 +0100127size_t RampUpTester::GetNumVideoStreams() const {
128 return num_video_streams_;
129}
130
Stefan Holmerff2a6352016-01-14 10:00:21 +0100131size_t RampUpTester::GetNumAudioStreams() const {
132 return num_audio_streams_;
133}
134
philipel5ef2bc12017-02-21 07:28:31 -0800135size_t RampUpTester::GetNumFlexfecStreams() const {
136 return num_flexfec_streams_;
137}
138
perkjfa10b552016-10-02 23:45:26 -0700139class RampUpTester::VideoStreamFactory
140 : public VideoEncoderConfig::VideoStreamFactoryInterface {
141 public:
142 VideoStreamFactory() {}
143
144 private:
145 std::vector<VideoStream> CreateEncoderStreams(
146 int width,
147 int height,
148 const VideoEncoderConfig& encoder_config) override {
149 std::vector<VideoStream> streams =
150 test::CreateVideoStreams(width, height, encoder_config);
151 if (encoder_config.number_of_streams == 1) {
152 streams[0].target_bitrate_bps = streams[0].max_bitrate_bps = 2000000;
153 }
154 return streams;
155 }
156};
157
stefanff483612015-12-21 03:14:00 -0800158void RampUpTester::ModifyVideoConfigs(
stefan4fbd1452015-09-28 03:57:14 -0700159 VideoSendStream::Config* send_config,
160 std::vector<VideoReceiveStream::Config>* receive_configs,
161 VideoEncoderConfig* encoder_config) {
162 send_config->suspend_below_min_bitrate = true;
perkjfa10b552016-10-02 23:45:26 -0700163 encoder_config->number_of_streams = num_video_streams_;
164 encoder_config->max_bitrate_bps = 2000000;
165 encoder_config->video_stream_factory =
166 new rtc::RefCountedObject<RampUpTester::VideoStreamFactory>();
stefanff483612015-12-21 03:14:00 -0800167 if (num_video_streams_ == 1) {
stefan4fbd1452015-09-28 03:57:14 -0700168 // For single stream rampup until 1mbps
169 expected_bitrate_bps_ = kSingleStreamTargetBps;
170 } else {
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200171 // To ensure simulcast rate allocation.
172 send_config->rtp.payload_name = "VP8";
173 encoder_config->codec_type = kVideoCodecVP8;
perkjfa10b552016-10-02 23:45:26 -0700174 std::vector<VideoStream> streams = test::CreateVideoStreams(
175 test::CallTest::kDefaultWidth, test::CallTest::kDefaultHeight,
176 *encoder_config);
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200177 // For multi stream rampup until all streams are being sent. That means
178 // enough bitrate to send all the target streams plus the min bitrate of
179 // the last one.
perkjfa10b552016-10-02 23:45:26 -0700180 expected_bitrate_bps_ = streams.back().min_bitrate_bps;
181 for (size_t i = 0; i < streams.size() - 1; ++i) {
182 expected_bitrate_bps_ += streams[i].target_bitrate_bps;
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000183 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000184 }
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000185
stefan4fbd1452015-09-28 03:57:14 -0700186 send_config->rtp.extensions.clear();
187
188 bool remb;
stefan43edf0f2015-11-20 18:05:48 -0800189 bool transport_cc;
isheriff6f8d6862016-05-26 11:24:55 -0700190 if (extension_type_ == RtpExtension::kAbsSendTimeUri) {
stefan4fbd1452015-09-28 03:57:14 -0700191 remb = true;
stefan43edf0f2015-11-20 18:05:48 -0800192 transport_cc = false;
stefan4fbd1452015-09-28 03:57:14 -0700193 send_config->rtp.extensions.push_back(
194 RtpExtension(extension_type_.c_str(), kAbsSendTimeExtensionId));
isheriff6f8d6862016-05-26 11:24:55 -0700195 } else if (extension_type_ == RtpExtension::kTransportSequenceNumberUri) {
stefan4fbd1452015-09-28 03:57:14 -0700196 remb = false;
stefan43edf0f2015-11-20 18:05:48 -0800197 transport_cc = true;
stefan4fbd1452015-09-28 03:57:14 -0700198 send_config->rtp.extensions.push_back(RtpExtension(
199 extension_type_.c_str(), kTransportSequenceNumberExtensionId));
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000200 } else {
stefan4fbd1452015-09-28 03:57:14 -0700201 remb = true;
stefan43edf0f2015-11-20 18:05:48 -0800202 transport_cc = false;
stefan4fbd1452015-09-28 03:57:14 -0700203 send_config->rtp.extensions.push_back(RtpExtension(
204 extension_type_.c_str(), kTransmissionTimeOffsetExtensionId));
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000205 }
stefan4fbd1452015-09-28 03:57:14 -0700206
207 send_config->rtp.nack.rtp_history_ms = test::CallTest::kNackRtpHistoryMs;
stefanff483612015-12-21 03:14:00 -0800208 send_config->rtp.ssrcs = video_ssrcs_;
stefan4fbd1452015-09-28 03:57:14 -0700209 if (rtx_) {
210 send_config->rtp.rtx.payload_type = test::CallTest::kSendRtxPayloadType;
stefanff483612015-12-21 03:14:00 -0800211 send_config->rtp.rtx.ssrcs = video_rtx_ssrcs_;
stefan4fbd1452015-09-28 03:57:14 -0700212 }
213 if (red_) {
brandtrb5f2c3f2016-10-04 23:28:39 -0700214 send_config->rtp.ulpfec.ulpfec_payload_type =
stefan4fbd1452015-09-28 03:57:14 -0700215 test::CallTest::kUlpfecPayloadType;
brandtrb5f2c3f2016-10-04 23:28:39 -0700216 send_config->rtp.ulpfec.red_payload_type = test::CallTest::kRedPayloadType;
brandtrfbfb5362016-11-17 04:18:37 -0800217 if (rtx_) {
218 send_config->rtp.ulpfec.red_rtx_payload_type =
219 test::CallTest::kRtxRedPayloadType;
220 }
stefan4fbd1452015-09-28 03:57:14 -0700221 }
222
223 size_t i = 0;
224 for (VideoReceiveStream::Config& recv_config : *receive_configs) {
stefan43edf0f2015-11-20 18:05:48 -0800225 recv_config.rtp.transport_cc = transport_cc;
stefan4fbd1452015-09-28 03:57:14 -0700226 recv_config.rtp.extensions = send_config->rtp.extensions;
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200227 recv_config.decoders.reserve(1);
228 recv_config.decoders[0].payload_type = send_config->rtp.payload_type;
Niels Möllercb7e1d22018-09-11 15:56:04 +0200229 recv_config.decoders[0].video_format =
230 SdpVideoFormat(send_config->rtp.payload_name);
stefan4fbd1452015-09-28 03:57:14 -0700231
stefanff483612015-12-21 03:14:00 -0800232 recv_config.rtp.remote_ssrc = video_ssrcs_[i];
stefan4fbd1452015-09-28 03:57:14 -0700233 recv_config.rtp.nack.rtp_history_ms = send_config->rtp.nack.rtp_history_ms;
234
235 if (red_) {
nisse3b3622f2017-09-26 02:49:21 -0700236 recv_config.rtp.red_payload_type =
brandtrb5f2c3f2016-10-04 23:28:39 -0700237 send_config->rtp.ulpfec.red_payload_type;
nisse3b3622f2017-09-26 02:49:21 -0700238 recv_config.rtp.ulpfec_payload_type =
brandtrb5f2c3f2016-10-04 23:28:39 -0700239 send_config->rtp.ulpfec.ulpfec_payload_type;
brandtrfbfb5362016-11-17 04:18:37 -0800240 if (rtx_) {
nisseca5706d2017-09-11 02:32:16 -0700241 recv_config.rtp.rtx_associated_payload_types
242 [send_config->rtp.ulpfec.red_rtx_payload_type] =
243 send_config->rtp.ulpfec.red_payload_type;
brandtrfbfb5362016-11-17 04:18:37 -0800244 }
stefan4fbd1452015-09-28 03:57:14 -0700245 }
246
247 if (rtx_) {
brandtr14742122017-01-27 04:53:07 -0800248 recv_config.rtp.rtx_ssrc = video_rtx_ssrcs_[i];
249 recv_config.rtp
nisse26e3abb2017-08-25 04:44:25 -0700250 .rtx_associated_payload_types[send_config->rtp.rtx.payload_type] =
Niels Möller259a4972018-04-05 15:36:51 +0200251 send_config->rtp.payload_type;
stefan4fbd1452015-09-28 03:57:14 -0700252 }
253 ++i;
254 }
philipel5ef2bc12017-02-21 07:28:31 -0800255
256 RTC_DCHECK_LE(num_flexfec_streams_, 1);
257 if (num_flexfec_streams_ == 1) {
258 send_config->rtp.flexfec.payload_type = test::CallTest::kFlexfecPayloadType;
259 send_config->rtp.flexfec.ssrc = test::CallTest::kFlexfecSendSsrc;
260 send_config->rtp.flexfec.protected_media_ssrcs = {video_ssrcs_[0]};
261 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000262}
263
Stefan Holmerff2a6352016-01-14 10:00:21 +0100264void RampUpTester::ModifyAudioConfigs(
265 AudioSendStream::Config* send_config,
266 std::vector<AudioReceiveStream::Config>* receive_configs) {
267 if (num_audio_streams_ == 0)
268 return;
269
isheriff6f8d6862016-05-26 11:24:55 -0700270 EXPECT_NE(RtpExtension::kTimestampOffsetUri, extension_type_)
Stefan Holmerff2a6352016-01-14 10:00:21 +0100271 << "Audio BWE not supported with toffset.";
philipel5ef2bc12017-02-21 07:28:31 -0800272 EXPECT_NE(RtpExtension::kAbsSendTimeUri, extension_type_)
273 << "Audio BWE not supported with abs-send-time.";
Stefan Holmerff2a6352016-01-14 10:00:21 +0100274
275 send_config->rtp.ssrc = audio_ssrcs_[0];
276 send_config->rtp.extensions.clear();
277
minyue10cbb462016-11-07 09:29:22 -0800278 send_config->min_bitrate_bps = 6000;
279 send_config->max_bitrate_bps = 60000;
mflodman86cc6ff2016-07-26 04:44:06 -0700280
Stefan Holmerff2a6352016-01-14 10:00:21 +0100281 bool transport_cc = false;
philipel5ef2bc12017-02-21 07:28:31 -0800282 if (extension_type_ == RtpExtension::kTransportSequenceNumberUri) {
Stefan Holmerff2a6352016-01-14 10:00:21 +0100283 transport_cc = true;
284 send_config->rtp.extensions.push_back(RtpExtension(
285 extension_type_.c_str(), kTransportSequenceNumberExtensionId));
286 }
287
288 for (AudioReceiveStream::Config& recv_config : *receive_configs) {
Stefan Holmerff2a6352016-01-14 10:00:21 +0100289 recv_config.rtp.transport_cc = transport_cc;
290 recv_config.rtp.extensions = send_config->rtp.extensions;
291 recv_config.rtp.remote_ssrc = send_config->rtp.ssrc;
292 }
293}
294
philipel5ef2bc12017-02-21 07:28:31 -0800295void RampUpTester::ModifyFlexfecConfigs(
296 std::vector<FlexfecReceiveStream::Config>* receive_configs) {
297 if (num_flexfec_streams_ == 0)
298 return;
299 RTC_DCHECK_EQ(1, num_flexfec_streams_);
300 (*receive_configs)[0].payload_type = test::CallTest::kFlexfecPayloadType;
301 (*receive_configs)[0].remote_ssrc = test::CallTest::kFlexfecSendSsrc;
302 (*receive_configs)[0].protected_media_ssrcs = {video_ssrcs_[0]};
303 (*receive_configs)[0].local_ssrc = video_ssrcs_[0];
304 if (extension_type_ == RtpExtension::kAbsSendTimeUri) {
305 (*receive_configs)[0].transport_cc = false;
306 (*receive_configs)[0].rtp_header_extensions.push_back(
307 RtpExtension(extension_type_.c_str(), kAbsSendTimeExtensionId));
308 } else if (extension_type_ == RtpExtension::kTransportSequenceNumberUri) {
309 (*receive_configs)[0].transport_cc = true;
310 (*receive_configs)[0].rtp_header_extensions.push_back(RtpExtension(
311 extension_type_.c_str(), kTransportSequenceNumberExtensionId));
312 }
313}
314
stefan4fbd1452015-09-28 03:57:14 -0700315void RampUpTester::OnCallsCreated(Call* sender_call, Call* receiver_call) {
Tommi5e005f42019-08-05 15:29:14 +0200316 RTC_DCHECK(sender_call);
stefan4fbd1452015-09-28 03:57:14 -0700317 sender_call_ = sender_call;
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +0200318 pending_task_ = RepeatingTaskHandle::Start(task_queue_, [this] {
319 PollStats();
320 return kPollInterval;
321 });
pbos@webrtc.org32452b22014-10-22 12:15:24 +0000322}
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000323
tommi0f8b4032017-02-22 11:22:05 -0800324void RampUpTester::PollStats() {
Tommi6b117a52019-08-20 09:58:56 +0200325 RTC_DCHECK_RUN_ON(task_queue_);
326
Tommi5e005f42019-08-05 15:29:14 +0200327 Call::Stats stats = sender_call_->GetStats();
328 EXPECT_GE(expected_bitrate_bps_, 0);
stefan4fbd1452015-09-28 03:57:14 -0700329
Tommi5e005f42019-08-05 15:29:14 +0200330 if (stats.send_bandwidth_bps >= expected_bitrate_bps_ &&
331 (min_run_time_ms_ == -1 ||
332 clock_->TimeInMilliseconds() - test_start_ms_ >= min_run_time_ms_)) {
333 ramp_up_finished_ms_ = clock_->TimeInMilliseconds();
334 observation_complete_.Set();
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +0200335 pending_task_.Stop();
Tommi5e005f42019-08-05 15:29:14 +0200336 }
Erik Språng468e62a2015-07-06 10:50:47 +0200337}
338
stefan4fbd1452015-09-28 03:57:14 -0700339void RampUpTester::ReportResult(const std::string& measurement,
340 size_t value,
341 const std::string& units) const {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000342 webrtc::test::PrintResult(
343 measurement, "",
stefanff483612015-12-21 03:14:00 -0800344 ::testing::UnitTest::GetInstance()->current_test_info()->name(), value,
345 units, false);
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000346}
347
stefan092508a2015-09-29 02:26:42 -0700348void RampUpTester::AccumulateStats(const VideoSendStream::StreamStats& stream,
349 size_t* total_packets_sent,
350 size_t* total_sent,
351 size_t* padding_sent,
352 size_t* media_sent) const {
stefan4fbd1452015-09-28 03:57:14 -0700353 *total_packets_sent += stream.rtp_stats.transmitted.packets +
354 stream.rtp_stats.retransmitted.packets +
355 stream.rtp_stats.fec.packets;
356 *total_sent += stream.rtp_stats.transmitted.TotalBytes() +
357 stream.rtp_stats.retransmitted.TotalBytes() +
358 stream.rtp_stats.fec.TotalBytes();
359 *padding_sent += stream.rtp_stats.transmitted.padding_bytes +
360 stream.rtp_stats.retransmitted.padding_bytes +
361 stream.rtp_stats.fec.padding_bytes;
362 *media_sent += stream.rtp_stats.MediaPayloadBytes();
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000363}
364
stefan4fbd1452015-09-28 03:57:14 -0700365void RampUpTester::TriggerTestDone() {
Erik Språngf3a7c9d2015-10-05 14:03:22 +0200366 RTC_DCHECK_GE(test_start_ms_, 0);
367
Stefan Holmerff2a6352016-01-14 10:00:21 +0100368 // TODO(holmer): Add audio send stats here too when those APIs are available.
mflodman86cc6ff2016-07-26 04:44:06 -0700369 if (!send_stream_)
370 return;
371
Tommi5e005f42019-08-05 15:29:14 +0200372 // Stop polling stats.
373 // Corner case for field_trials=WebRTC-QuickPerfTest/Enabled/
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +0200374 SendTask(RTC_FROM_HERE, task_queue_, [this] { pending_task_.Stop(); });
Tommi5e005f42019-08-05 15:29:14 +0200375
stefan4fbd1452015-09-28 03:57:14 -0700376 VideoSendStream::Stats send_stats = send_stream_->GetStats();
Tommi5e005f42019-08-05 15:29:14 +0200377 send_stream_ = nullptr; // To avoid dereferencing a bad pointer.
stefan4fbd1452015-09-28 03:57:14 -0700378
379 size_t total_packets_sent = 0;
380 size_t total_sent = 0;
381 size_t padding_sent = 0;
382 size_t media_sent = 0;
stefanff483612015-12-21 03:14:00 -0800383 for (uint32_t ssrc : video_ssrcs_) {
stefan092508a2015-09-29 02:26:42 -0700384 AccumulateStats(send_stats.substreams[ssrc], &total_packets_sent,
385 &total_sent, &padding_sent, &media_sent);
stefan4fbd1452015-09-28 03:57:14 -0700386 }
387
388 size_t rtx_total_packets_sent = 0;
389 size_t rtx_total_sent = 0;
390 size_t rtx_padding_sent = 0;
391 size_t rtx_media_sent = 0;
stefanff483612015-12-21 03:14:00 -0800392 for (uint32_t rtx_ssrc : video_rtx_ssrcs_) {
stefan092508a2015-09-29 02:26:42 -0700393 AccumulateStats(send_stats.substreams[rtx_ssrc], &rtx_total_packets_sent,
394 &rtx_total_sent, &rtx_padding_sent, &rtx_media_sent);
stefan4fbd1452015-09-28 03:57:14 -0700395 }
396
stefan5a2c5062017-01-27 06:43:18 -0800397 if (report_perf_stats_) {
stefan5a2c5062017-01-27 06:43:18 -0800398 ReportResult("ramp-up-media-sent", media_sent, "bytes");
399 ReportResult("ramp-up-padding-sent", padding_sent, "bytes");
stefan5a2c5062017-01-27 06:43:18 -0800400 ReportResult("ramp-up-rtx-media-sent", rtx_media_sent, "bytes");
401 ReportResult("ramp-up-rtx-padding-sent", rtx_padding_sent, "bytes");
402 if (ramp_up_finished_ms_ >= 0) {
403 ReportResult("ramp-up-time", ramp_up_finished_ms_ - test_start_ms_,
404 "milliseconds");
405 }
406 ReportResult("ramp-up-average-network-latency",
407 send_transport_->GetAverageDelayMs(), "milliseconds");
stefan4fbd1452015-09-28 03:57:14 -0700408 }
409}
410
411void RampUpTester::PerformTest() {
Erik Språngf3a7c9d2015-10-05 14:03:22 +0200412 test_start_ms_ = clock_->TimeInMilliseconds();
Peter Boström5811a392015-12-10 13:02:50 +0100413 EXPECT_TRUE(Wait()) << "Timed out while waiting for ramp-up to complete.";
stefan4fbd1452015-09-28 03:57:14 -0700414 TriggerTestDone();
415}
416
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +0200417RampUpDownUpTester::RampUpDownUpTester(size_t num_video_streams,
418 size_t num_audio_streams,
419 size_t num_flexfec_streams,
420 unsigned int start_bitrate_bps,
421 const std::string& extension_type,
422 bool rtx,
423 bool red,
424 const std::vector<int>& loss_rates,
425 bool report_perf_stats,
426 TaskQueueBase* task_queue)
Stefan Holmerff2a6352016-01-14 10:00:21 +0100427 : RampUpTester(num_video_streams,
428 num_audio_streams,
philipel5ef2bc12017-02-21 07:28:31 -0800429 num_flexfec_streams,
Stefan Holmerff2a6352016-01-14 10:00:21 +0100430 start_bitrate_bps,
stefan5a2c5062017-01-27 06:43:18 -0800431 0,
Stefan Holmerff2a6352016-01-14 10:00:21 +0100432 extension_type,
433 rtx,
stefan5a2c5062017-01-27 06:43:18 -0800434 red,
Tommi5e005f42019-08-05 15:29:14 +0200435 report_perf_stats,
436 task_queue),
stefan76d9c9c2017-04-01 06:51:09 -0700437 link_rates_({4 * GetExpectedHighBitrate() / (3 * 1000),
438 kLowBandwidthLimitBps / 1000,
439 4 * GetExpectedHighBitrate() / (3 * 1000), 0}),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000440 test_state_(kFirstRampup),
philipel5ef2bc12017-02-21 07:28:31 -0800441 next_state_(kTransitionToNextState),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000442 state_start_ms_(clock_->TimeInMilliseconds()),
stefan4fbd1452015-09-28 03:57:14 -0700443 interval_start_ms_(clock_->TimeInMilliseconds()),
philipel5ef2bc12017-02-21 07:28:31 -0800444 sent_bytes_(0),
445 loss_rates_(loss_rates) {
446 forward_transport_config_.link_capacity_kbps = link_rates_[test_state_];
447 forward_transport_config_.queue_delay_ms = 100;
448 forward_transport_config_.loss_percent = loss_rates_[test_state_];
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000449}
450
stefan4fbd1452015-09-28 03:57:14 -0700451RampUpDownUpTester::~RampUpDownUpTester() {}
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000452
tommi0f8b4032017-02-22 11:22:05 -0800453void RampUpDownUpTester::PollStats() {
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +0200454 if (test_state_ == kTestEnd) {
455 pending_task_.Stop();
456 }
Tommi5e005f42019-08-05 15:29:14 +0200457
458 int transmit_bitrate_bps = 0;
459 bool suspended = false;
460 if (num_video_streams_ > 0 && send_stream_) {
461 webrtc::VideoSendStream::Stats stats = send_stream_->GetStats();
462 for (const auto& it : stats.substreams) {
463 transmit_bitrate_bps += it.second.total_bitrate_bps;
Alex Narest78609d52017-10-20 10:37:47 +0200464 }
Tommi5e005f42019-08-05 15:29:14 +0200465 suspended = stats.suspended;
466 }
467 if (num_audio_streams_ > 0 && sender_call_) {
468 // An audio send stream doesn't have bitrate stats, so the call send BW is
469 // currently used instead.
470 transmit_bitrate_bps = sender_call_->GetStats().send_bandwidth_bps;
471 }
472
473 EvolveTestState(transmit_bitrate_bps, suspended);
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000474}
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000475
Niels Möllerde8e6e62018-11-13 15:10:33 +0100476void RampUpDownUpTester::ModifyReceiverBitrateConfig(
477 BitrateConstraints* bitrate_config) {
478 bitrate_config->min_bitrate_bps = 10000;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000479}
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000480
stefan4fbd1452015-09-28 03:57:14 -0700481std::string RampUpDownUpTester::GetModifierString() const {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000482 std::string str("_");
stefanff483612015-12-21 03:14:00 -0800483 if (num_video_streams_ > 0) {
Jonas Olsson0a713b62018-04-04 15:49:32 +0200484 str += rtc::ToString(num_video_streams_);
stefanff483612015-12-21 03:14:00 -0800485 str += "stream";
486 str += (num_video_streams_ > 1 ? "s" : "");
487 str += "_";
488 }
489 if (num_audio_streams_ > 0) {
Jonas Olsson0a713b62018-04-04 15:49:32 +0200490 str += rtc::ToString(num_audio_streams_);
stefanff483612015-12-21 03:14:00 -0800491 str += "stream";
492 str += (num_audio_streams_ > 1 ? "s" : "");
493 str += "_";
494 }
stefan4fbd1452015-09-28 03:57:14 -0700495 str += (rtx_ ? "" : "no");
Edward Lemurdd3987f2018-01-04 19:44:54 +0100496 str += "rtx_";
497 str += (red_ ? "" : "no");
498 str += "red";
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000499 return str;
500}
andresp@webrtc.orgc1480792014-03-20 03:23:55 +0000501
stefandb752f92016-12-05 08:23:40 -0800502int RampUpDownUpTester::GetExpectedHighBitrate() const {
stefan38d8b3c2017-01-09 04:19:24 -0800503 int expected_bitrate_bps = 0;
504 if (num_audio_streams_ > 0)
505 expected_bitrate_bps += kExpectedHighAudioBitrateBps;
506 if (num_video_streams_ > 0)
507 expected_bitrate_bps += kExpectedHighVideoBitrateBps;
508 return expected_bitrate_bps;
509}
510
philipel5ef2bc12017-02-21 07:28:31 -0800511size_t RampUpDownUpTester::GetFecBytes() const {
512 size_t flex_fec_bytes = 0;
513 if (num_flexfec_streams_ > 0) {
514 webrtc::VideoSendStream::Stats stats = send_stream_->GetStats();
515 for (const auto& kv : stats.substreams)
516 flex_fec_bytes += kv.second.rtp_stats.fec.TotalBytes();
517 }
518 return flex_fec_bytes;
519}
520
521bool RampUpDownUpTester::ExpectingFec() const {
522 return num_flexfec_streams_ > 0 && forward_transport_config_.loss_percent > 0;
523}
524
stefan4fbd1452015-09-28 03:57:14 -0700525void RampUpDownUpTester::EvolveTestState(int bitrate_bps, bool suspended) {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000526 int64_t now = clock_->TimeInMilliseconds();
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000527 switch (test_state_) {
philipel5ef2bc12017-02-21 07:28:31 -0800528 case kFirstRampup:
stefan4fbd1452015-09-28 03:57:14 -0700529 EXPECT_FALSE(suspended);
stefandb752f92016-12-05 08:23:40 -0800530 if (bitrate_bps >= GetExpectedHighBitrate()) {
stefan45b5fe52017-03-09 06:27:02 -0800531 if (report_perf_stats_) {
532 webrtc::test::PrintResult("ramp_up_down_up", GetModifierString(),
533 "first_rampup", now - state_start_ms_, "ms",
534 false);
535 }
philipel5ef2bc12017-02-21 07:28:31 -0800536 // Apply loss during the transition between states if FEC is enabled.
537 forward_transport_config_.loss_percent = loss_rates_[test_state_];
538 test_state_ = kTransitionToNextState;
539 next_state_ = kLowRate;
andresp@webrtc.orgc1480792014-03-20 03:23:55 +0000540 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000541 break;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000542 case kLowRate: {
mflodman86cc6ff2016-07-26 04:44:06 -0700543 // Audio streams are never suspended.
544 bool check_suspend_state = num_video_streams_ > 0;
Sebastian Jansson12fb1702018-02-23 11:34:18 +0100545 if (bitrate_bps < kLowBandwidthLimitBps + kLowBitrateMarginBps &&
mflodman86cc6ff2016-07-26 04:44:06 -0700546 suspended == check_suspend_state) {
stefan45b5fe52017-03-09 06:27:02 -0800547 if (report_perf_stats_) {
548 webrtc::test::PrintResult("ramp_up_down_up", GetModifierString(),
549 "rampdown", now - state_start_ms_, "ms",
550 false);
551 }
philipel5ef2bc12017-02-21 07:28:31 -0800552 // Apply loss during the transition between states if FEC is enabled.
553 forward_transport_config_.loss_percent = loss_rates_[test_state_];
554 test_state_ = kTransitionToNextState;
555 next_state_ = kSecondRampup;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000556 }
557 break;
558 }
philipel5ef2bc12017-02-21 07:28:31 -0800559 case kSecondRampup:
stefandb752f92016-12-05 08:23:40 -0800560 if (bitrate_bps >= GetExpectedHighBitrate() && !suspended) {
stefan45b5fe52017-03-09 06:27:02 -0800561 if (report_perf_stats_) {
562 webrtc::test::PrintResult("ramp_up_down_up", GetModifierString(),
563 "second_rampup", now - state_start_ms_,
564 "ms", false);
565 ReportResult("ramp-up-down-up-average-network-latency",
566 send_transport_->GetAverageDelayMs(), "milliseconds");
567 }
philipel5ef2bc12017-02-21 07:28:31 -0800568 // Apply loss during the transition between states if FEC is enabled.
569 forward_transport_config_.loss_percent = loss_rates_[test_state_];
570 test_state_ = kTransitionToNextState;
571 next_state_ = kTestEnd;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000572 }
573 break;
philipel5ef2bc12017-02-21 07:28:31 -0800574 case kTestEnd:
575 observation_complete_.Set();
576 break;
577 case kTransitionToNextState:
578 if (!ExpectingFec() || GetFecBytes() > 0) {
579 test_state_ = next_state_;
580 forward_transport_config_.link_capacity_kbps = link_rates_[test_state_];
581 // No loss while ramping up and down as it may affect the BWE
582 // negatively, making the test flaky.
583 forward_transport_config_.loss_percent = 0;
584 state_start_ms_ = now;
585 interval_start_ms_ = now;
586 sent_bytes_ = 0;
Artem Titov631cafa2018-08-21 21:01:00 +0200587 send_simulated_network_->SetConfig(forward_transport_config_);
philipel5ef2bc12017-02-21 07:28:31 -0800588 }
589 break;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000590 }
591}
pbos@webrtc.orgf577ae92014-03-19 08:43:57 +0000592
stefan4fbd1452015-09-28 03:57:14 -0700593class RampUpTest : public test::CallTest {
Erik Språng6b8d3552015-09-24 15:06:57 +0200594 public:
Danil Chapovalov304ea5f2019-04-11 15:18:18 +0200595 RampUpTest()
596 : task_queue_factory_(CreateDefaultTaskQueueFactory()),
597 rtc_event_log_factory_(task_queue_factory_.get()) {
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200598 std::string dump_name(absl::GetFlag(FLAGS_ramp_dump_name));
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200599 if (!dump_name.empty()) {
Danil Chapovalov304ea5f2019-04-11 15:18:18 +0200600 send_event_log_ = rtc_event_log_factory_.CreateRtcEventLog(
601 RtcEventLog::EncodingType::Legacy);
602 recv_event_log_ = rtc_event_log_factory_.CreateRtcEventLog(
603 RtcEventLog::EncodingType::Legacy);
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200604 bool event_log_started =
605 send_event_log_->StartLogging(
Mirko Bonadei317a1f02019-09-17 17:06:18 +0200606 std::make_unique<RtcEventLogOutputFile>(
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200607 dump_name + ".send.rtc.dat", RtcEventLog::kUnlimitedOutput),
608 RtcEventLog::kImmediateOutput) &&
609 recv_event_log_->StartLogging(
Mirko Bonadei317a1f02019-09-17 17:06:18 +0200610 std::make_unique<RtcEventLogOutputFile>(
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200611 dump_name + ".recv.rtc.dat", RtcEventLog::kUnlimitedOutput),
612 RtcEventLog::kImmediateOutput);
613 RTC_DCHECK(event_log_started);
614 }
615 }
Danil Chapovalov304ea5f2019-04-11 15:18:18 +0200616
617 private:
618 const std::unique_ptr<TaskQueueFactory> task_queue_factory_;
619 RtcEventLogFactory rtc_event_log_factory_;
Erik Språng6b8d3552015-09-24 15:06:57 +0200620};
621
Stefan Holmerff2a6352016-01-14 10:00:21 +0100622static const uint32_t kStartBitrateBps = 60000;
623
stefan38d8b3c2017-01-09 04:19:24 -0800624TEST_F(RampUpTest, UpDownUpAbsSendTimeSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800625 std::vector<int> loss_rates = {0, 0, 0, 0};
626 RampUpDownUpTester test(3, 0, 0, kStartBitrateBps,
stefan45b5fe52017-03-09 06:27:02 -0800627 RtpExtension::kAbsSendTimeUri, true, true, loss_rates,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200628 true, task_queue());
stefane74eef12016-01-08 06:47:13 -0800629 RunBaseTest(&test);
Shao Changbine62202f2015-04-21 20:24:50 +0800630}
Stefan Holmerff2a6352016-01-14 10:00:21 +0100631
Taylor Brandstetterba6b5032018-02-16 09:59:56 -0800632// TODO(bugs.webrtc.org/8878)
633#if defined(WEBRTC_MAC)
634#define MAYBE_UpDownUpTransportSequenceNumberRtx \
635 DISABLED_UpDownUpTransportSequenceNumberRtx
636#else
637#define MAYBE_UpDownUpTransportSequenceNumberRtx \
638 UpDownUpTransportSequenceNumberRtx
639#endif
640TEST_F(RampUpTest, MAYBE_UpDownUpTransportSequenceNumberRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800641 std::vector<int> loss_rates = {0, 0, 0, 0};
642 RampUpDownUpTester test(3, 0, 0, kStartBitrateBps,
isheriff6f8d6862016-05-26 11:24:55 -0700643 RtpExtension::kTransportSequenceNumberUri, true,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200644 false, loss_rates, true, task_queue());
philipel5ef2bc12017-02-21 07:28:31 -0800645 RunBaseTest(&test);
646}
647
stefan45b5fe52017-03-09 06:27:02 -0800648// TODO(holmer): Tests which don't report perf stats should be moved to a
649// different executable since they per definition are not perf tests.
Taylor Brandstetter05d98222017-10-10 12:12:53 -0700650// This test is disabled because it crashes on Linux, and is flaky on other
651// platforms. See: crbug.com/webrtc/7919
652TEST_F(RampUpTest, DISABLED_UpDownUpTransportSequenceNumberPacketLoss) {
philipel5ef2bc12017-02-21 07:28:31 -0800653 std::vector<int> loss_rates = {20, 0, 0, 0};
654 RampUpDownUpTester test(1, 0, 1, kStartBitrateBps,
655 RtpExtension::kTransportSequenceNumberUri, true,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200656 false, loss_rates, false, task_queue());
Stefan Holmerff2a6352016-01-14 10:00:21 +0100657 RunBaseTest(&test);
658}
659
Taylor Brandstetterab86e7f2018-02-12 15:16:02 -0800660// TODO(bugs.webrtc.org/8878)
661#if defined(WEBRTC_MAC)
662#define MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx \
663 DISABLED_UpDownUpAudioVideoTransportSequenceNumberRtx
664#else
665#define MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx \
666 UpDownUpAudioVideoTransportSequenceNumberRtx
667#endif
668TEST_F(RampUpTest, MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx) {
Per Kjellander914351d2019-02-15 10:54:55 +0100669 test::ScopedFieldTrials field_trials("WebRTC-Audio-SendSideBwe/Enabled/");
philipel5ef2bc12017-02-21 07:28:31 -0800670 std::vector<int> loss_rates = {0, 0, 0, 0};
671 RampUpDownUpTester test(3, 1, 0, kStartBitrateBps,
isheriff6f8d6862016-05-26 11:24:55 -0700672 RtpExtension::kTransportSequenceNumberUri, true,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200673 false, loss_rates, false, task_queue());
Stefan Holmerff2a6352016-01-14 10:00:21 +0100674 RunBaseTest(&test);
675}
676
stefan38d8b3c2017-01-09 04:19:24 -0800677TEST_F(RampUpTest, UpDownUpAudioTransportSequenceNumberRtx) {
Per Kjellander914351d2019-02-15 10:54:55 +0100678 test::ScopedFieldTrials field_trials("WebRTC-Audio-SendSideBwe/Enabled/");
philipel5ef2bc12017-02-21 07:28:31 -0800679 std::vector<int> loss_rates = {0, 0, 0, 0};
680 RampUpDownUpTester test(0, 1, 0, kStartBitrateBps,
mflodman86cc6ff2016-07-26 04:44:06 -0700681 RtpExtension::kTransportSequenceNumberUri, true,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200682 false, loss_rates, false, task_queue());
mflodman86cc6ff2016-07-26 04:44:06 -0700683 RunBaseTest(&test);
684}
685
stefan38d8b3c2017-01-09 04:19:24 -0800686TEST_F(RampUpTest, TOffsetSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800687 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kTimestampOffsetUri, true,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200688 true, true, task_queue());
stefan38d8b3c2017-01-09 04:19:24 -0800689 RunBaseTest(&test);
690}
691
692TEST_F(RampUpTest, AbsSendTime) {
philipel5ef2bc12017-02-21 07:28:31 -0800693 RampUpTester test(1, 0, 0, 0, 0, RtpExtension::kAbsSendTimeUri, false, false,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200694 false, task_queue());
stefane74eef12016-01-08 06:47:13 -0800695 RunBaseTest(&test);
pbos@webrtc.org85bd53e2014-12-10 10:36:20 +0000696}
697
stefan38d8b3c2017-01-09 04:19:24 -0800698TEST_F(RampUpTest, AbsSendTimeSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800699 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kAbsSendTimeUri, true, true,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200700 true, task_queue());
stefane74eef12016-01-08 06:47:13 -0800701 RunBaseTest(&test);
pbos@webrtc.org85bd53e2014-12-10 10:36:20 +0000702}
703
stefan38d8b3c2017-01-09 04:19:24 -0800704TEST_F(RampUpTest, TransportSequenceNumber) {
philipel5ef2bc12017-02-21 07:28:31 -0800705 RampUpTester test(1, 0, 0, 0, 0, RtpExtension::kTransportSequenceNumberUri,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200706 false, false, false, task_queue());
stefane74eef12016-01-08 06:47:13 -0800707 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200708}
709
710TEST_F(RampUpTest, TransportSequenceNumberSimulcast) {
philipel5ef2bc12017-02-21 07:28:31 -0800711 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kTransportSequenceNumberUri,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200712 false, false, false, task_queue());
stefane74eef12016-01-08 06:47:13 -0800713 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200714}
715
stefan38d8b3c2017-01-09 04:19:24 -0800716TEST_F(RampUpTest, TransportSequenceNumberSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800717 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kTransportSequenceNumberUri,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200718 true, true, true, task_queue());
stefan5a2c5062017-01-27 06:43:18 -0800719 RunBaseTest(&test);
720}
721
Niels Möllercd2e1052018-11-08 10:23:13 +0100722TEST_F(RampUpTest, AudioTransportSequenceNumber) {
philipel5ef2bc12017-02-21 07:28:31 -0800723 RampUpTester test(0, 1, 0, 300000, 10000,
stefan5a2c5062017-01-27 06:43:18 -0800724 RtpExtension::kTransportSequenceNumberUri, false, false,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200725 false, task_queue());
stefane74eef12016-01-08 06:47:13 -0800726 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200727}
pbos@webrtc.org744fbc72013-09-10 09:26:25 +0000728} // namespace webrtc