blob: 3c89670a9fbd5d7878e699f20804742c32aa1950 [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"
Ali Tofigh641a1b12022-05-17 11:48:46 +020016#include "absl/strings/string_view.h"
Danil Chapovalov4ba04b72019-06-26 15:49:47 +020017#include "api/rtc_event_log/rtc_event_log_factory.h"
Niels Möllerd8b9ed72019-05-08 13:53:51 +020018#include "api/rtc_event_log_output_file.h"
Danil Chapovalov304ea5f2019-04-11 15:18:18 +020019#include "api/task_queue/default_task_queue_factory.h"
Danil Chapovalov44db4362019-09-30 04:16:28 +020020#include "api/task_queue/task_queue_base.h"
Danil Chapovalov304ea5f2019-04-11 15:18:18 +020021#include "api/task_queue/task_queue_factory.h"
Artem Titov14b42c22022-09-26 13:21:14 +020022#include "api/test/metrics/global_metrics_logger_and_exporter.h"
23#include "api/test/metrics/metric.h"
Artem Titov4e199e92018-08-20 13:30:39 +020024#include "call/fake_network_pipe.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020025#include "rtc_base/checks.h"
26#include "rtc_base/logging.h"
27#include "rtc_base/platform_thread.h"
Steve Anton10542f22019-01-11 09:11:00 -080028#include "rtc_base/string_encode.h"
Danil Chapovalov82a3f0a2019-10-21 09:24:27 +020029#include "rtc_base/task_queue_for_test.h"
Tommi6b117a52019-08-20 09:58:56 +020030#include "rtc_base/time_utils.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020031#include "test/encoder_settings.h"
32#include "test/gtest.h"
pbos@webrtc.org744fbc72013-09-10 09:26:25 +000033
Mirko Bonadei2ab97f62019-07-18 13:44:12 +020034ABSL_FLAG(std::string,
35 ramp_dump_name,
36 "",
37 "Filename for dumped received RTP stream.");
38
pbos@webrtc.org744fbc72013-09-10 09:26:25 +000039namespace webrtc {
pbos@webrtc.org29023282013-09-11 10:14:56 +000040namespace {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000041
Artem Titov14b42c22022-09-26 13:21:14 +020042using ::webrtc::test::GetGlobalMetricsLogger;
43using ::webrtc::test::ImprovementDirection;
44using ::webrtc::test::Unit;
45
Danil Chapovalov0c626af2020-02-10 11:16:00 +010046constexpr TimeDelta kPollInterval = TimeDelta::Millis(20);
philipel5ef2bc12017-02-21 07:28:31 -080047static const int kExpectedHighVideoBitrateBps = 80000;
stefandb752f92016-12-05 08:23:40 -080048static const int kExpectedHighAudioBitrateBps = 30000;
49static const int kLowBandwidthLimitBps = 20000;
Sebastian Jansson12fb1702018-02-23 11:34:18 +010050// Set target detected bitrate to slightly larger than the target bitrate to
51// avoid flakiness.
52static const int kLowBitrateMarginBps = 2000;
pbos@webrtc.org29023282013-09-11 10:14:56 +000053
stefanff483612015-12-21 03:14:00 -080054std::vector<uint32_t> GenerateSsrcs(size_t num_streams, uint32_t ssrc_offset) {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000055 std::vector<uint32_t> ssrcs;
56 for (size_t i = 0; i != num_streams; ++i)
57 ssrcs.push_back(static_cast<uint32_t>(ssrc_offset + i));
58 return ssrcs;
59}
Artem Titov14b42c22022-09-26 13:21:14 +020060
mflodman@webrtc.orgeb16b812014-06-16 08:57:39 +000061} // namespace
henrik.lundin@webrtc.org845862f2014-03-06 07:19:28 +000062
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +020063RampUpTester::RampUpTester(size_t num_video_streams,
64 size_t num_audio_streams,
65 size_t num_flexfec_streams,
66 unsigned int start_bitrate_bps,
67 int64_t min_run_time_ms,
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +020068 bool rtx,
69 bool red,
70 bool report_perf_stats,
71 TaskQueueBase* task_queue)
Markus Handellf4f22872022-08-16 11:02:45 +000072 : EndToEndTest(test::CallTest::kLongTimeout),
stefan4fbd1452015-09-28 03:57:14 -070073 clock_(Clock::GetRealTimeClock()),
stefanff483612015-12-21 03:14:00 -080074 num_video_streams_(num_video_streams),
75 num_audio_streams_(num_audio_streams),
philipel5ef2bc12017-02-21 07:28:31 -080076 num_flexfec_streams_(num_flexfec_streams),
stefan4fbd1452015-09-28 03:57:14 -070077 rtx_(rtx),
78 red_(red),
stefan45b5fe52017-03-09 06:27:02 -080079 report_perf_stats_(report_perf_stats),
mflodman86cc6ff2016-07-26 04:44:06 -070080 sender_call_(nullptr),
stefan4fbd1452015-09-28 03:57:14 -070081 send_stream_(nullptr),
sprang4847ae62017-06-27 07:06:52 -070082 send_transport_(nullptr),
Artem Titov631cafa2018-08-21 21:01:00 +020083 send_simulated_network_(nullptr),
stefan4fbd1452015-09-28 03:57:14 -070084 start_bitrate_bps_(start_bitrate_bps),
stefan5a2c5062017-01-27 06:43:18 -080085 min_run_time_ms_(min_run_time_ms),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000086 expected_bitrate_bps_(0),
Erik Språngf3a7c9d2015-10-05 14:03:22 +020087 test_start_ms_(-1),
stefan4fbd1452015-09-28 03:57:14 -070088 ramp_up_finished_ms_(-1),
stefanff483612015-12-21 03:14:00 -080089 video_ssrcs_(GenerateSsrcs(num_video_streams_, 100)),
90 video_rtx_ssrcs_(GenerateSsrcs(num_video_streams_, 200)),
91 audio_ssrcs_(GenerateSsrcs(num_audio_streams_, 300)),
Tommi5e005f42019-08-05 15:29:14 +020092 task_queue_(task_queue) {
philipel5ef2bc12017-02-21 07:28:31 -080093 if (red_)
94 EXPECT_EQ(0u, num_flexfec_streams_);
Stefan Holmerff2a6352016-01-14 10:00:21 +010095 EXPECT_LE(num_audio_streams_, 1u);
stefan4fbd1452015-09-28 03:57:14 -070096}
97
Danil Chapovalov577c5802019-10-31 12:33:17 +010098RampUpTester::~RampUpTester() = default;
stefan4fbd1452015-09-28 03:57:14 -070099
Niels Möllerde8e6e62018-11-13 15:10:33 +0100100void RampUpTester::ModifySenderBitrateConfig(
101 BitrateConstraints* bitrate_config) {
stefan4fbd1452015-09-28 03:57:14 -0700102 if (start_bitrate_bps_ != 0) {
Niels Möllerde8e6e62018-11-13 15:10:33 +0100103 bitrate_config->start_bitrate_bps = start_bitrate_bps_;
stefan4fbd1452015-09-28 03:57:14 -0700104 }
Niels Möllerde8e6e62018-11-13 15:10:33 +0100105 bitrate_config->min_bitrate_bps = 10000;
stefan4fbd1452015-09-28 03:57:14 -0700106}
107
stefanff483612015-12-21 03:14:00 -0800108void RampUpTester::OnVideoStreamsCreated(
stefan4fbd1452015-09-28 03:57:14 -0700109 VideoSendStream* send_stream,
Tommif6f45432022-05-20 15:21:20 +0200110 const std::vector<VideoReceiveStreamInterface*>& receive_streams) {
stefan4fbd1452015-09-28 03:57:14 -0700111 send_stream_ = send_stream;
112}
113
Per Kjellander89870ff2023-01-19 15:45:58 +0000114BuiltInNetworkBehaviorConfig RampUpTester::GetSendTransportConfig() const {
115 return forward_transport_config_;
stefanf116bd02015-10-27 08:29:42 -0700116}
117
Stefan Holmerd20e6512016-01-12 15:51:22 +0100118size_t RampUpTester::GetNumVideoStreams() const {
119 return num_video_streams_;
120}
121
Stefan Holmerff2a6352016-01-14 10:00:21 +0100122size_t RampUpTester::GetNumAudioStreams() const {
123 return num_audio_streams_;
124}
125
philipel5ef2bc12017-02-21 07:28:31 -0800126size_t RampUpTester::GetNumFlexfecStreams() const {
127 return num_flexfec_streams_;
128}
129
perkjfa10b552016-10-02 23:45:26 -0700130class RampUpTester::VideoStreamFactory
131 : public VideoEncoderConfig::VideoStreamFactoryInterface {
132 public:
133 VideoStreamFactory() {}
134
135 private:
136 std::vector<VideoStream> CreateEncoderStreams(
Jonas Oreland80c87d72022-09-29 15:01:09 +0200137 int frame_width,
138 int frame_height,
perkjfa10b552016-10-02 23:45:26 -0700139 const VideoEncoderConfig& encoder_config) override {
140 std::vector<VideoStream> streams =
Jonas Oreland80c87d72022-09-29 15:01:09 +0200141 test::CreateVideoStreams(frame_width, frame_height, encoder_config);
perkjfa10b552016-10-02 23:45:26 -0700142 if (encoder_config.number_of_streams == 1) {
143 streams[0].target_bitrate_bps = streams[0].max_bitrate_bps = 2000000;
144 }
145 return streams;
146 }
147};
148
stefanff483612015-12-21 03:14:00 -0800149void RampUpTester::ModifyVideoConfigs(
stefan4fbd1452015-09-28 03:57:14 -0700150 VideoSendStream::Config* send_config,
Tommif6f45432022-05-20 15:21:20 +0200151 std::vector<VideoReceiveStreamInterface::Config>* receive_configs,
stefan4fbd1452015-09-28 03:57:14 -0700152 VideoEncoderConfig* encoder_config) {
153 send_config->suspend_below_min_bitrate = true;
perkjfa10b552016-10-02 23:45:26 -0700154 encoder_config->number_of_streams = num_video_streams_;
155 encoder_config->max_bitrate_bps = 2000000;
156 encoder_config->video_stream_factory =
Tomas Gunnarssonc1d58912021-04-22 19:21:43 +0200157 rtc::make_ref_counted<RampUpTester::VideoStreamFactory>();
stefanff483612015-12-21 03:14:00 -0800158 if (num_video_streams_ == 1) {
stefan4fbd1452015-09-28 03:57:14 -0700159 // For single stream rampup until 1mbps
160 expected_bitrate_bps_ = kSingleStreamTargetBps;
161 } else {
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200162 // To ensure simulcast rate allocation.
163 send_config->rtp.payload_name = "VP8";
164 encoder_config->codec_type = kVideoCodecVP8;
perkjfa10b552016-10-02 23:45:26 -0700165 std::vector<VideoStream> streams = test::CreateVideoStreams(
166 test::CallTest::kDefaultWidth, test::CallTest::kDefaultHeight,
167 *encoder_config);
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200168 // For multi stream rampup until all streams are being sent. That means
169 // enough bitrate to send all the target streams plus the min bitrate of
170 // the last one.
perkjfa10b552016-10-02 23:45:26 -0700171 expected_bitrate_bps_ = streams.back().min_bitrate_bps;
172 for (size_t i = 0; i < streams.size() - 1; ++i) {
173 expected_bitrate_bps_ += streams[i].target_bitrate_bps;
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000174 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000175 }
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000176
stefan4fbd1452015-09-28 03:57:14 -0700177 send_config->rtp.nack.rtp_history_ms = test::CallTest::kNackRtpHistoryMs;
stefanff483612015-12-21 03:14:00 -0800178 send_config->rtp.ssrcs = video_ssrcs_;
stefan4fbd1452015-09-28 03:57:14 -0700179 if (rtx_) {
180 send_config->rtp.rtx.payload_type = test::CallTest::kSendRtxPayloadType;
stefanff483612015-12-21 03:14:00 -0800181 send_config->rtp.rtx.ssrcs = video_rtx_ssrcs_;
stefan4fbd1452015-09-28 03:57:14 -0700182 }
183 if (red_) {
brandtrb5f2c3f2016-10-04 23:28:39 -0700184 send_config->rtp.ulpfec.ulpfec_payload_type =
stefan4fbd1452015-09-28 03:57:14 -0700185 test::CallTest::kUlpfecPayloadType;
brandtrb5f2c3f2016-10-04 23:28:39 -0700186 send_config->rtp.ulpfec.red_payload_type = test::CallTest::kRedPayloadType;
brandtrfbfb5362016-11-17 04:18:37 -0800187 if (rtx_) {
188 send_config->rtp.ulpfec.red_rtx_payload_type =
189 test::CallTest::kRtxRedPayloadType;
190 }
stefan4fbd1452015-09-28 03:57:14 -0700191 }
192
193 size_t i = 0;
Tommif6f45432022-05-20 15:21:20 +0200194 for (VideoReceiveStreamInterface::Config& recv_config : *receive_configs) {
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200195 recv_config.decoders.reserve(1);
196 recv_config.decoders[0].payload_type = send_config->rtp.payload_type;
Niels Möllercb7e1d22018-09-11 15:56:04 +0200197 recv_config.decoders[0].video_format =
198 SdpVideoFormat(send_config->rtp.payload_name);
stefan4fbd1452015-09-28 03:57:14 -0700199
stefanff483612015-12-21 03:14:00 -0800200 recv_config.rtp.remote_ssrc = video_ssrcs_[i];
stefan4fbd1452015-09-28 03:57:14 -0700201 recv_config.rtp.nack.rtp_history_ms = send_config->rtp.nack.rtp_history_ms;
202
203 if (red_) {
nisse3b3622f2017-09-26 02:49:21 -0700204 recv_config.rtp.red_payload_type =
brandtrb5f2c3f2016-10-04 23:28:39 -0700205 send_config->rtp.ulpfec.red_payload_type;
nisse3b3622f2017-09-26 02:49:21 -0700206 recv_config.rtp.ulpfec_payload_type =
brandtrb5f2c3f2016-10-04 23:28:39 -0700207 send_config->rtp.ulpfec.ulpfec_payload_type;
brandtrfbfb5362016-11-17 04:18:37 -0800208 if (rtx_) {
nisseca5706d2017-09-11 02:32:16 -0700209 recv_config.rtp.rtx_associated_payload_types
210 [send_config->rtp.ulpfec.red_rtx_payload_type] =
211 send_config->rtp.ulpfec.red_payload_type;
brandtrfbfb5362016-11-17 04:18:37 -0800212 }
stefan4fbd1452015-09-28 03:57:14 -0700213 }
214
215 if (rtx_) {
brandtr14742122017-01-27 04:53:07 -0800216 recv_config.rtp.rtx_ssrc = video_rtx_ssrcs_[i];
217 recv_config.rtp
nisse26e3abb2017-08-25 04:44:25 -0700218 .rtx_associated_payload_types[send_config->rtp.rtx.payload_type] =
Niels Möller259a4972018-04-05 15:36:51 +0200219 send_config->rtp.payload_type;
stefan4fbd1452015-09-28 03:57:14 -0700220 }
221 ++i;
222 }
philipel5ef2bc12017-02-21 07:28:31 -0800223
224 RTC_DCHECK_LE(num_flexfec_streams_, 1);
225 if (num_flexfec_streams_ == 1) {
226 send_config->rtp.flexfec.payload_type = test::CallTest::kFlexfecPayloadType;
227 send_config->rtp.flexfec.ssrc = test::CallTest::kFlexfecSendSsrc;
228 send_config->rtp.flexfec.protected_media_ssrcs = {video_ssrcs_[0]};
229 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000230}
231
Stefan Holmerff2a6352016-01-14 10:00:21 +0100232void RampUpTester::ModifyAudioConfigs(
233 AudioSendStream::Config* send_config,
Tommi3176ef72022-05-22 20:47:28 +0200234 std::vector<AudioReceiveStreamInterface::Config>* receive_configs) {
Stefan Holmerff2a6352016-01-14 10:00:21 +0100235 if (num_audio_streams_ == 0)
236 return;
237
Stefan Holmerff2a6352016-01-14 10:00:21 +0100238 send_config->rtp.ssrc = audio_ssrcs_[0];
minyue10cbb462016-11-07 09:29:22 -0800239 send_config->min_bitrate_bps = 6000;
240 send_config->max_bitrate_bps = 60000;
mflodman86cc6ff2016-07-26 04:44:06 -0700241
Tommi3176ef72022-05-22 20:47:28 +0200242 for (AudioReceiveStreamInterface::Config& recv_config : *receive_configs) {
Stefan Holmerff2a6352016-01-14 10:00:21 +0100243 recv_config.rtp.remote_ssrc = send_config->rtp.ssrc;
244 }
245}
246
philipel5ef2bc12017-02-21 07:28:31 -0800247void RampUpTester::ModifyFlexfecConfigs(
248 std::vector<FlexfecReceiveStream::Config>* receive_configs) {
249 if (num_flexfec_streams_ == 0)
250 return;
251 RTC_DCHECK_EQ(1, num_flexfec_streams_);
252 (*receive_configs)[0].payload_type = test::CallTest::kFlexfecPayloadType;
Tommi1c1f5402021-06-14 10:54:20 +0200253 (*receive_configs)[0].rtp.remote_ssrc = test::CallTest::kFlexfecSendSsrc;
philipel5ef2bc12017-02-21 07:28:31 -0800254 (*receive_configs)[0].protected_media_ssrcs = {video_ssrcs_[0]};
Tommi1c1f5402021-06-14 10:54:20 +0200255 (*receive_configs)[0].rtp.local_ssrc = video_ssrcs_[0];
philipel5ef2bc12017-02-21 07:28:31 -0800256}
257
stefan4fbd1452015-09-28 03:57:14 -0700258void RampUpTester::OnCallsCreated(Call* sender_call, Call* receiver_call) {
Tommi5e005f42019-08-05 15:29:14 +0200259 RTC_DCHECK(sender_call);
stefan4fbd1452015-09-28 03:57:14 -0700260 sender_call_ = sender_call;
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +0200261 pending_task_ = RepeatingTaskHandle::Start(task_queue_, [this] {
262 PollStats();
263 return kPollInterval;
264 });
pbos@webrtc.org32452b22014-10-22 12:15:24 +0000265}
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000266
Per Kjellander89870ff2023-01-19 15:45:58 +0000267void RampUpTester::OnTransportCreated(
268 test::PacketTransport* to_receiver,
269 SimulatedNetworkInterface* sender_network,
270 test::PacketTransport* to_sender,
271 SimulatedNetworkInterface* receiver_network) {
272 RTC_DCHECK_RUN_ON(task_queue_);
273
274 send_transport_ = to_receiver;
275 send_simulated_network_ = sender_network;
276}
277
tommi0f8b4032017-02-22 11:22:05 -0800278void RampUpTester::PollStats() {
Tommi6b117a52019-08-20 09:58:56 +0200279 RTC_DCHECK_RUN_ON(task_queue_);
280
Tommi5e005f42019-08-05 15:29:14 +0200281 Call::Stats stats = sender_call_->GetStats();
282 EXPECT_GE(expected_bitrate_bps_, 0);
stefan4fbd1452015-09-28 03:57:14 -0700283
Tommi5e005f42019-08-05 15:29:14 +0200284 if (stats.send_bandwidth_bps >= expected_bitrate_bps_ &&
285 (min_run_time_ms_ == -1 ||
286 clock_->TimeInMilliseconds() - test_start_ms_ >= min_run_time_ms_)) {
287 ramp_up_finished_ms_ = clock_->TimeInMilliseconds();
288 observation_complete_.Set();
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +0200289 pending_task_.Stop();
Tommi5e005f42019-08-05 15:29:14 +0200290 }
Erik Språng468e62a2015-07-06 10:50:47 +0200291}
292
Stefan Holmer6d113ea2022-01-05 17:03:49 +0100293void RampUpTester::ReportResult(
Ali Tofigh641a1b12022-05-17 11:48:46 +0200294 absl::string_view measurement,
Stefan Holmer6d113ea2022-01-05 17:03:49 +0100295 size_t value,
Artem Titov14b42c22022-09-26 13:21:14 +0200296 Unit unit,
297 ImprovementDirection improvement_direction) const {
298 GetGlobalMetricsLogger()->LogSingleValueMetric(
299 measurement,
stefanff483612015-12-21 03:14:00 -0800300 ::testing::UnitTest::GetInstance()->current_test_info()->name(), value,
Artem Titov14b42c22022-09-26 13:21:14 +0200301 unit, improvement_direction);
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000302}
303
stefan092508a2015-09-29 02:26:42 -0700304void RampUpTester::AccumulateStats(const VideoSendStream::StreamStats& stream,
305 size_t* total_packets_sent,
306 size_t* total_sent,
307 size_t* padding_sent,
308 size_t* media_sent) const {
stefan4fbd1452015-09-28 03:57:14 -0700309 *total_packets_sent += stream.rtp_stats.transmitted.packets +
310 stream.rtp_stats.retransmitted.packets +
311 stream.rtp_stats.fec.packets;
312 *total_sent += stream.rtp_stats.transmitted.TotalBytes() +
313 stream.rtp_stats.retransmitted.TotalBytes() +
314 stream.rtp_stats.fec.TotalBytes();
315 *padding_sent += stream.rtp_stats.transmitted.padding_bytes +
316 stream.rtp_stats.retransmitted.padding_bytes +
317 stream.rtp_stats.fec.padding_bytes;
318 *media_sent += stream.rtp_stats.MediaPayloadBytes();
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000319}
320
stefan4fbd1452015-09-28 03:57:14 -0700321void RampUpTester::TriggerTestDone() {
Erik Språngf3a7c9d2015-10-05 14:03:22 +0200322 RTC_DCHECK_GE(test_start_ms_, 0);
323
Tommi5e005f42019-08-05 15:29:14 +0200324 // Stop polling stats.
325 // Corner case for field_trials=WebRTC-QuickPerfTest/Enabled/
Danil Chapovalove519f382022-08-11 12:26:09 +0200326 SendTask(task_queue_, [this] { pending_task_.Stop(); });
Tommi5e005f42019-08-05 15:29:14 +0200327
Tommi9b7232a2020-05-15 10:09:27 +0200328 // TODO(holmer): Add audio send stats here too when those APIs are available.
329 if (!send_stream_)
330 return;
331
Tomas Gunnarsson788d8052021-05-03 16:23:08 +0200332 VideoSendStream::Stats send_stats;
Danil Chapovalove519f382022-08-11 12:26:09 +0200333 SendTask(task_queue_, [&] { send_stats = send_stream_->GetStats(); });
Tomas Gunnarsson788d8052021-05-03 16:23:08 +0200334
Tommi5e005f42019-08-05 15:29:14 +0200335 send_stream_ = nullptr; // To avoid dereferencing a bad pointer.
stefan4fbd1452015-09-28 03:57:14 -0700336
337 size_t total_packets_sent = 0;
338 size_t total_sent = 0;
339 size_t padding_sent = 0;
340 size_t media_sent = 0;
stefanff483612015-12-21 03:14:00 -0800341 for (uint32_t ssrc : video_ssrcs_) {
stefan092508a2015-09-29 02:26:42 -0700342 AccumulateStats(send_stats.substreams[ssrc], &total_packets_sent,
343 &total_sent, &padding_sent, &media_sent);
stefan4fbd1452015-09-28 03:57:14 -0700344 }
345
346 size_t rtx_total_packets_sent = 0;
347 size_t rtx_total_sent = 0;
348 size_t rtx_padding_sent = 0;
349 size_t rtx_media_sent = 0;
stefanff483612015-12-21 03:14:00 -0800350 for (uint32_t rtx_ssrc : video_rtx_ssrcs_) {
stefan092508a2015-09-29 02:26:42 -0700351 AccumulateStats(send_stats.substreams[rtx_ssrc], &rtx_total_packets_sent,
352 &rtx_total_sent, &rtx_padding_sent, &rtx_media_sent);
stefan4fbd1452015-09-28 03:57:14 -0700353 }
354
stefan5a2c5062017-01-27 06:43:18 -0800355 if (report_perf_stats_) {
Artem Titov14b42c22022-09-26 13:21:14 +0200356 ReportResult("ramp-up-media-sent", media_sent, Unit::kBytes,
357 ImprovementDirection::kBiggerIsBetter);
358 ReportResult("ramp-up-padding-sent", padding_sent, Unit::kBytes,
359 ImprovementDirection::kSmallerIsBetter);
360 ReportResult("ramp-up-rtx-media-sent", rtx_media_sent, Unit::kBytes,
361 ImprovementDirection::kBiggerIsBetter);
362 ReportResult("ramp-up-rtx-padding-sent", rtx_padding_sent, Unit::kBytes,
363 ImprovementDirection::kSmallerIsBetter);
stefan5a2c5062017-01-27 06:43:18 -0800364 if (ramp_up_finished_ms_ >= 0) {
365 ReportResult("ramp-up-time", ramp_up_finished_ms_ - test_start_ms_,
Artem Titov14b42c22022-09-26 13:21:14 +0200366 Unit::kMilliseconds, ImprovementDirection::kSmallerIsBetter);
stefan5a2c5062017-01-27 06:43:18 -0800367 }
368 ReportResult("ramp-up-average-network-latency",
Artem Titov14b42c22022-09-26 13:21:14 +0200369 send_transport_->GetAverageDelayMs(), Unit::kMilliseconds,
370 ImprovementDirection::kSmallerIsBetter);
stefan4fbd1452015-09-28 03:57:14 -0700371 }
372}
373
374void RampUpTester::PerformTest() {
Erik Språngf3a7c9d2015-10-05 14:03:22 +0200375 test_start_ms_ = clock_->TimeInMilliseconds();
Peter Boström5811a392015-12-10 13:02:50 +0100376 EXPECT_TRUE(Wait()) << "Timed out while waiting for ramp-up to complete.";
stefan4fbd1452015-09-28 03:57:14 -0700377 TriggerTestDone();
378}
379
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +0200380RampUpDownUpTester::RampUpDownUpTester(size_t num_video_streams,
381 size_t num_audio_streams,
382 size_t num_flexfec_streams,
383 unsigned int start_bitrate_bps,
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +0200384 bool rtx,
385 bool red,
386 const std::vector<int>& loss_rates,
387 bool report_perf_stats,
388 TaskQueueBase* task_queue)
Stefan Holmerff2a6352016-01-14 10:00:21 +0100389 : RampUpTester(num_video_streams,
390 num_audio_streams,
philipel5ef2bc12017-02-21 07:28:31 -0800391 num_flexfec_streams,
Stefan Holmerff2a6352016-01-14 10:00:21 +0100392 start_bitrate_bps,
stefan5a2c5062017-01-27 06:43:18 -0800393 0,
Stefan Holmerff2a6352016-01-14 10:00:21 +0100394 rtx,
stefan5a2c5062017-01-27 06:43:18 -0800395 red,
Tommi5e005f42019-08-05 15:29:14 +0200396 report_perf_stats,
397 task_queue),
stefan76d9c9c2017-04-01 06:51:09 -0700398 link_rates_({4 * GetExpectedHighBitrate() / (3 * 1000),
399 kLowBandwidthLimitBps / 1000,
400 4 * GetExpectedHighBitrate() / (3 * 1000), 0}),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000401 test_state_(kFirstRampup),
philipel5ef2bc12017-02-21 07:28:31 -0800402 next_state_(kTransitionToNextState),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000403 state_start_ms_(clock_->TimeInMilliseconds()),
stefan4fbd1452015-09-28 03:57:14 -0700404 interval_start_ms_(clock_->TimeInMilliseconds()),
philipel5ef2bc12017-02-21 07:28:31 -0800405 sent_bytes_(0),
406 loss_rates_(loss_rates) {
407 forward_transport_config_.link_capacity_kbps = link_rates_[test_state_];
408 forward_transport_config_.queue_delay_ms = 100;
409 forward_transport_config_.loss_percent = loss_rates_[test_state_];
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000410}
411
stefan4fbd1452015-09-28 03:57:14 -0700412RampUpDownUpTester::~RampUpDownUpTester() {}
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000413
tommi0f8b4032017-02-22 11:22:05 -0800414void RampUpDownUpTester::PollStats() {
Danil Chapovalov9f5ae7b2019-10-21 11:08:13 +0200415 if (test_state_ == kTestEnd) {
416 pending_task_.Stop();
417 }
Tommi5e005f42019-08-05 15:29:14 +0200418
419 int transmit_bitrate_bps = 0;
420 bool suspended = false;
421 if (num_video_streams_ > 0 && send_stream_) {
422 webrtc::VideoSendStream::Stats stats = send_stream_->GetStats();
423 for (const auto& it : stats.substreams) {
424 transmit_bitrate_bps += it.second.total_bitrate_bps;
Alex Narest78609d52017-10-20 10:37:47 +0200425 }
Tommi5e005f42019-08-05 15:29:14 +0200426 suspended = stats.suspended;
427 }
428 if (num_audio_streams_ > 0 && sender_call_) {
429 // An audio send stream doesn't have bitrate stats, so the call send BW is
430 // currently used instead.
431 transmit_bitrate_bps = sender_call_->GetStats().send_bandwidth_bps;
432 }
433
434 EvolveTestState(transmit_bitrate_bps, suspended);
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000435}
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000436
Niels Möllerde8e6e62018-11-13 15:10:33 +0100437void RampUpDownUpTester::ModifyReceiverBitrateConfig(
438 BitrateConstraints* bitrate_config) {
439 bitrate_config->min_bitrate_bps = 10000;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000440}
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000441
stefan4fbd1452015-09-28 03:57:14 -0700442std::string RampUpDownUpTester::GetModifierString() const {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000443 std::string str("_");
stefanff483612015-12-21 03:14:00 -0800444 if (num_video_streams_ > 0) {
Jonas Olsson0a713b62018-04-04 15:49:32 +0200445 str += rtc::ToString(num_video_streams_);
stefanff483612015-12-21 03:14:00 -0800446 str += "stream";
447 str += (num_video_streams_ > 1 ? "s" : "");
448 str += "_";
449 }
450 if (num_audio_streams_ > 0) {
Jonas Olsson0a713b62018-04-04 15:49:32 +0200451 str += rtc::ToString(num_audio_streams_);
stefanff483612015-12-21 03:14:00 -0800452 str += "stream";
453 str += (num_audio_streams_ > 1 ? "s" : "");
454 str += "_";
455 }
stefan4fbd1452015-09-28 03:57:14 -0700456 str += (rtx_ ? "" : "no");
Edward Lemurdd3987f2018-01-04 19:44:54 +0100457 str += "rtx_";
458 str += (red_ ? "" : "no");
459 str += "red";
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000460 return str;
461}
andresp@webrtc.orgc1480792014-03-20 03:23:55 +0000462
stefandb752f92016-12-05 08:23:40 -0800463int RampUpDownUpTester::GetExpectedHighBitrate() const {
stefan38d8b3c2017-01-09 04:19:24 -0800464 int expected_bitrate_bps = 0;
465 if (num_audio_streams_ > 0)
466 expected_bitrate_bps += kExpectedHighAudioBitrateBps;
467 if (num_video_streams_ > 0)
468 expected_bitrate_bps += kExpectedHighVideoBitrateBps;
469 return expected_bitrate_bps;
470}
471
philipel5ef2bc12017-02-21 07:28:31 -0800472size_t RampUpDownUpTester::GetFecBytes() const {
473 size_t flex_fec_bytes = 0;
474 if (num_flexfec_streams_ > 0) {
475 webrtc::VideoSendStream::Stats stats = send_stream_->GetStats();
476 for (const auto& kv : stats.substreams)
477 flex_fec_bytes += kv.second.rtp_stats.fec.TotalBytes();
478 }
479 return flex_fec_bytes;
480}
481
482bool RampUpDownUpTester::ExpectingFec() const {
483 return num_flexfec_streams_ > 0 && forward_transport_config_.loss_percent > 0;
484}
485
stefan4fbd1452015-09-28 03:57:14 -0700486void RampUpDownUpTester::EvolveTestState(int bitrate_bps, bool suspended) {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000487 int64_t now = clock_->TimeInMilliseconds();
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000488 switch (test_state_) {
philipel5ef2bc12017-02-21 07:28:31 -0800489 case kFirstRampup:
stefan4fbd1452015-09-28 03:57:14 -0700490 EXPECT_FALSE(suspended);
stefandb752f92016-12-05 08:23:40 -0800491 if (bitrate_bps >= GetExpectedHighBitrate()) {
stefan45b5fe52017-03-09 06:27:02 -0800492 if (report_perf_stats_) {
Artem Titov14b42c22022-09-26 13:21:14 +0200493 GetGlobalMetricsLogger()->LogSingleValueMetric(
494 "ramp_up_down_up" + GetModifierString(), "first_rampup",
495 now - state_start_ms_, Unit::kMilliseconds,
496 ImprovementDirection::kSmallerIsBetter);
stefan45b5fe52017-03-09 06:27:02 -0800497 }
philipel5ef2bc12017-02-21 07:28:31 -0800498 // Apply loss during the transition between states if FEC is enabled.
499 forward_transport_config_.loss_percent = loss_rates_[test_state_];
500 test_state_ = kTransitionToNextState;
501 next_state_ = kLowRate;
andresp@webrtc.orgc1480792014-03-20 03:23:55 +0000502 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000503 break;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000504 case kLowRate: {
mflodman86cc6ff2016-07-26 04:44:06 -0700505 // Audio streams are never suspended.
506 bool check_suspend_state = num_video_streams_ > 0;
Sebastian Jansson12fb1702018-02-23 11:34:18 +0100507 if (bitrate_bps < kLowBandwidthLimitBps + kLowBitrateMarginBps &&
mflodman86cc6ff2016-07-26 04:44:06 -0700508 suspended == check_suspend_state) {
stefan45b5fe52017-03-09 06:27:02 -0800509 if (report_perf_stats_) {
Artem Titov14b42c22022-09-26 13:21:14 +0200510 GetGlobalMetricsLogger()->LogSingleValueMetric(
511 "ramp_up_down_up" + GetModifierString(), "rampdown",
512 now - state_start_ms_, Unit::kMilliseconds,
513 ImprovementDirection::kSmallerIsBetter);
stefan45b5fe52017-03-09 06:27:02 -0800514 }
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_ = kSecondRampup;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000519 }
520 break;
521 }
philipel5ef2bc12017-02-21 07:28:31 -0800522 case kSecondRampup:
stefandb752f92016-12-05 08:23:40 -0800523 if (bitrate_bps >= GetExpectedHighBitrate() && !suspended) {
stefan45b5fe52017-03-09 06:27:02 -0800524 if (report_perf_stats_) {
Artem Titov14b42c22022-09-26 13:21:14 +0200525 GetGlobalMetricsLogger()->LogSingleValueMetric(
526 "ramp_up_down_up" + GetModifierString(), "second_rampup",
527 now - state_start_ms_, Unit::kMilliseconds,
528 ImprovementDirection::kSmallerIsBetter);
stefan45b5fe52017-03-09 06:27:02 -0800529 ReportResult("ramp-up-down-up-average-network-latency",
Artem Titov14b42c22022-09-26 13:21:14 +0200530 send_transport_->GetAverageDelayMs(),
531 Unit::kMilliseconds,
532 ImprovementDirection::kSmallerIsBetter);
stefan45b5fe52017-03-09 06:27:02 -0800533 }
philipel5ef2bc12017-02-21 07:28:31 -0800534 // Apply loss during the transition between states if FEC is enabled.
535 forward_transport_config_.loss_percent = loss_rates_[test_state_];
536 test_state_ = kTransitionToNextState;
537 next_state_ = kTestEnd;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000538 }
539 break;
philipel5ef2bc12017-02-21 07:28:31 -0800540 case kTestEnd:
541 observation_complete_.Set();
542 break;
543 case kTransitionToNextState:
544 if (!ExpectingFec() || GetFecBytes() > 0) {
545 test_state_ = next_state_;
546 forward_transport_config_.link_capacity_kbps = link_rates_[test_state_];
547 // No loss while ramping up and down as it may affect the BWE
548 // negatively, making the test flaky.
549 forward_transport_config_.loss_percent = 0;
550 state_start_ms_ = now;
551 interval_start_ms_ = now;
552 sent_bytes_ = 0;
Artem Titov631cafa2018-08-21 21:01:00 +0200553 send_simulated_network_->SetConfig(forward_transport_config_);
philipel5ef2bc12017-02-21 07:28:31 -0800554 }
555 break;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000556 }
557}
pbos@webrtc.orgf577ae92014-03-19 08:43:57 +0000558
stefan4fbd1452015-09-28 03:57:14 -0700559class RampUpTest : public test::CallTest {
Erik Språng6b8d3552015-09-24 15:06:57 +0200560 public:
Danil Chapovalov304ea5f2019-04-11 15:18:18 +0200561 RampUpTest()
562 : task_queue_factory_(CreateDefaultTaskQueueFactory()),
563 rtc_event_log_factory_(task_queue_factory_.get()) {
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200564 std::string dump_name(absl::GetFlag(FLAGS_ramp_dump_name));
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200565 if (!dump_name.empty()) {
Danil Chapovalov304ea5f2019-04-11 15:18:18 +0200566 send_event_log_ = rtc_event_log_factory_.CreateRtcEventLog(
567 RtcEventLog::EncodingType::Legacy);
568 recv_event_log_ = rtc_event_log_factory_.CreateRtcEventLog(
569 RtcEventLog::EncodingType::Legacy);
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200570 bool event_log_started =
571 send_event_log_->StartLogging(
Mirko Bonadei317a1f02019-09-17 17:06:18 +0200572 std::make_unique<RtcEventLogOutputFile>(
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200573 dump_name + ".send.rtc.dat", RtcEventLog::kUnlimitedOutput),
574 RtcEventLog::kImmediateOutput) &&
575 recv_event_log_->StartLogging(
Mirko Bonadei317a1f02019-09-17 17:06:18 +0200576 std::make_unique<RtcEventLogOutputFile>(
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200577 dump_name + ".recv.rtc.dat", RtcEventLog::kUnlimitedOutput),
578 RtcEventLog::kImmediateOutput);
579 RTC_DCHECK(event_log_started);
580 }
581 }
Danil Chapovalov304ea5f2019-04-11 15:18:18 +0200582
583 private:
584 const std::unique_ptr<TaskQueueFactory> task_queue_factory_;
585 RtcEventLogFactory rtc_event_log_factory_;
Erik Språng6b8d3552015-09-24 15:06:57 +0200586};
587
Stefan Holmerff2a6352016-01-14 10:00:21 +0100588static const uint32_t kStartBitrateBps = 60000;
589
stefan38d8b3c2017-01-09 04:19:24 -0800590TEST_F(RampUpTest, UpDownUpAbsSendTimeSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800591 std::vector<int> loss_rates = {0, 0, 0, 0};
Per K5671c642023-01-25 12:58:50 +0100592 RegisterRtpExtension(
593 RtpExtension(RtpExtension::kAbsSendTimeUri, kAbsSendTimeExtensionId));
594 RampUpDownUpTester test(3, 0, 0, kStartBitrateBps, true, true, loss_rates,
Danil Chapovalovd15a0282019-10-22 10:48:17 +0200595 true, task_queue());
stefane74eef12016-01-08 06:47:13 -0800596 RunBaseTest(&test);
Shao Changbine62202f2015-04-21 20:24:50 +0800597}
Stefan Holmerff2a6352016-01-14 10:00:21 +0100598
Taylor Brandstetterba6b5032018-02-16 09:59:56 -0800599// TODO(bugs.webrtc.org/8878)
600#if defined(WEBRTC_MAC)
601#define MAYBE_UpDownUpTransportSequenceNumberRtx \
602 DISABLED_UpDownUpTransportSequenceNumberRtx
603#else
604#define MAYBE_UpDownUpTransportSequenceNumberRtx \
605 UpDownUpTransportSequenceNumberRtx
606#endif
607TEST_F(RampUpTest, MAYBE_UpDownUpTransportSequenceNumberRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800608 std::vector<int> loss_rates = {0, 0, 0, 0};
Per K5671c642023-01-25 12:58:50 +0100609 RegisterRtpExtension(RtpExtension(RtpExtension::kTransportSequenceNumberUri,
610 kTransportSequenceNumberExtensionId));
611 RampUpDownUpTester test(3, 0, 0, kStartBitrateBps, true, false, loss_rates,
612 true, task_queue());
philipel5ef2bc12017-02-21 07:28:31 -0800613 RunBaseTest(&test);
614}
615
stefan45b5fe52017-03-09 06:27:02 -0800616// TODO(holmer): Tests which don't report perf stats should be moved to a
617// different executable since they per definition are not perf tests.
Taylor Brandstetter05d98222017-10-10 12:12:53 -0700618// This test is disabled because it crashes on Linux, and is flaky on other
619// platforms. See: crbug.com/webrtc/7919
620TEST_F(RampUpTest, DISABLED_UpDownUpTransportSequenceNumberPacketLoss) {
philipel5ef2bc12017-02-21 07:28:31 -0800621 std::vector<int> loss_rates = {20, 0, 0, 0};
Per K5671c642023-01-25 12:58:50 +0100622 RegisterRtpExtension(RtpExtension(RtpExtension::kTransportSequenceNumberUri,
623 kTransportSequenceNumberExtensionId));
624 RampUpDownUpTester test(1, 0, 1, kStartBitrateBps, true, false, loss_rates,
625 false, task_queue());
Stefan Holmerff2a6352016-01-14 10:00:21 +0100626 RunBaseTest(&test);
627}
628
Taylor Brandstetterab86e7f2018-02-12 15:16:02 -0800629// TODO(bugs.webrtc.org/8878)
630#if defined(WEBRTC_MAC)
631#define MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx \
632 DISABLED_UpDownUpAudioVideoTransportSequenceNumberRtx
633#else
634#define MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx \
635 UpDownUpAudioVideoTransportSequenceNumberRtx
636#endif
637TEST_F(RampUpTest, MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800638 std::vector<int> loss_rates = {0, 0, 0, 0};
Per K5671c642023-01-25 12:58:50 +0100639 RegisterRtpExtension(RtpExtension(RtpExtension::kTransportSequenceNumberUri,
640 kTransportSequenceNumberExtensionId));
641 RampUpDownUpTester test(3, 1, 0, kStartBitrateBps, true, false, loss_rates,
642 false, task_queue());
Stefan Holmerff2a6352016-01-14 10:00:21 +0100643 RunBaseTest(&test);
644}
645
stefan38d8b3c2017-01-09 04:19:24 -0800646TEST_F(RampUpTest, UpDownUpAudioTransportSequenceNumberRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800647 std::vector<int> loss_rates = {0, 0, 0, 0};
Per K5671c642023-01-25 12:58:50 +0100648 RegisterRtpExtension(RtpExtension(RtpExtension::kTransportSequenceNumberUri,
649 kTransportSequenceNumberExtensionId));
650 RampUpDownUpTester test(0, 1, 0, kStartBitrateBps, true, false, loss_rates,
651 false, task_queue());
mflodman86cc6ff2016-07-26 04:44:06 -0700652 RunBaseTest(&test);
653}
654
stefan38d8b3c2017-01-09 04:19:24 -0800655TEST_F(RampUpTest, TOffsetSimulcastRedRtx) {
Per K5671c642023-01-25 12:58:50 +0100656 RegisterRtpExtension(RtpExtension(RtpExtension::kTimestampOffsetUri,
657 kTransmissionTimeOffsetExtensionId));
658 RampUpTester test(3, 0, 0, 0, 0, true, true, true, task_queue());
stefan38d8b3c2017-01-09 04:19:24 -0800659 RunBaseTest(&test);
660}
661
662TEST_F(RampUpTest, AbsSendTime) {
Per K5671c642023-01-25 12:58:50 +0100663 RegisterRtpExtension(
664 RtpExtension(RtpExtension::kAbsSendTimeUri, kAbsSendTimeExtensionId));
665 RampUpTester test(1, 0, 0, 0, 0, false, false, false, task_queue());
stefane74eef12016-01-08 06:47:13 -0800666 RunBaseTest(&test);
pbos@webrtc.org85bd53e2014-12-10 10:36:20 +0000667}
668
stefan38d8b3c2017-01-09 04:19:24 -0800669TEST_F(RampUpTest, AbsSendTimeSimulcastRedRtx) {
Per K5671c642023-01-25 12:58:50 +0100670 RegisterRtpExtension(
671 RtpExtension(RtpExtension::kAbsSendTimeUri, kAbsSendTimeExtensionId));
672 RampUpTester test(3, 0, 0, 0, 0, true, true, true, task_queue());
stefane74eef12016-01-08 06:47:13 -0800673 RunBaseTest(&test);
pbos@webrtc.org85bd53e2014-12-10 10:36:20 +0000674}
675
stefan38d8b3c2017-01-09 04:19:24 -0800676TEST_F(RampUpTest, TransportSequenceNumber) {
Per K5671c642023-01-25 12:58:50 +0100677 RegisterRtpExtension(RtpExtension(RtpExtension::kTransportSequenceNumberUri,
678 kTransportSequenceNumberExtensionId));
679 RampUpTester test(1, 0, 0, 0, 0, false, false, false, task_queue());
stefane74eef12016-01-08 06:47:13 -0800680 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200681}
682
683TEST_F(RampUpTest, TransportSequenceNumberSimulcast) {
Per K5671c642023-01-25 12:58:50 +0100684 RegisterRtpExtension(RtpExtension(RtpExtension::kTransportSequenceNumberUri,
685 kTransportSequenceNumberExtensionId));
686 RampUpTester test(3, 0, 0, 0, 0, false, false, false, task_queue());
stefane74eef12016-01-08 06:47:13 -0800687 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200688}
689
stefan38d8b3c2017-01-09 04:19:24 -0800690TEST_F(RampUpTest, TransportSequenceNumberSimulcastRedRtx) {
Per K5671c642023-01-25 12:58:50 +0100691 RegisterRtpExtension(RtpExtension(RtpExtension::kTransportSequenceNumberUri,
692 kTransportSequenceNumberExtensionId));
693 RampUpTester test(3, 0, 0, 0, 0, true, true, true, task_queue());
stefan5a2c5062017-01-27 06:43:18 -0800694 RunBaseTest(&test);
695}
696
Niels Möllercd2e1052018-11-08 10:23:13 +0100697TEST_F(RampUpTest, AudioTransportSequenceNumber) {
Per K5671c642023-01-25 12:58:50 +0100698 RegisterRtpExtension(RtpExtension(RtpExtension::kTransportSequenceNumberUri,
699 kTransportSequenceNumberExtensionId));
700 RampUpTester test(0, 1, 0, 300000, 10000, false, false, false, task_queue());
stefane74eef12016-01-08 06:47:13 -0800701 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200702}
Artem Titov14b42c22022-09-26 13:21:14 +0200703
pbos@webrtc.org744fbc72013-09-10 09:26:25 +0000704} // namespace webrtc