blob: 0fc3627f163537f241cae9536efd602a8ec34a08 [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"
Steve Anton40d55332019-01-07 10:21:47 -080016#include "absl/memory/memory.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"
20#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"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020026#include "test/encoder_settings.h"
Per Kjellander914351d2019-02-15 10:54:55 +010027#include "test/field_trial.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020028#include "test/gtest.h"
29#include "test/testsupport/perf_test.h"
pbos@webrtc.org744fbc72013-09-10 09:26:25 +000030
Mirko Bonadei2ab97f62019-07-18 13:44:12 +020031ABSL_FLAG(std::string,
32 ramp_dump_name,
33 "",
34 "Filename for dumped received RTP stream.");
35
pbos@webrtc.org744fbc72013-09-10 09:26:25 +000036namespace webrtc {
pbos@webrtc.org29023282013-09-11 10:14:56 +000037namespace {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000038
Stefan Holmer723dff12015-10-05 14:59:41 +020039static const int64_t kPollIntervalMs = 20;
philipel5ef2bc12017-02-21 07:28:31 -080040static const int kExpectedHighVideoBitrateBps = 80000;
stefandb752f92016-12-05 08:23:40 -080041static const int kExpectedHighAudioBitrateBps = 30000;
42static const int kLowBandwidthLimitBps = 20000;
Sebastian Jansson12fb1702018-02-23 11:34:18 +010043// Set target detected bitrate to slightly larger than the target bitrate to
44// avoid flakiness.
45static const int kLowBitrateMarginBps = 2000;
pbos@webrtc.org29023282013-09-11 10:14:56 +000046
stefanff483612015-12-21 03:14:00 -080047std::vector<uint32_t> GenerateSsrcs(size_t num_streams, uint32_t ssrc_offset) {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000048 std::vector<uint32_t> ssrcs;
49 for (size_t i = 0; i != num_streams; ++i)
50 ssrcs.push_back(static_cast<uint32_t>(ssrc_offset + i));
51 return ssrcs;
52}
mflodman@webrtc.orgeb16b812014-06-16 08:57:39 +000053} // namespace
henrik.lundin@webrtc.org845862f2014-03-06 07:19:28 +000054
stefanff483612015-12-21 03:14:00 -080055RampUpTester::RampUpTester(size_t num_video_streams,
56 size_t num_audio_streams,
philipel5ef2bc12017-02-21 07:28:31 -080057 size_t num_flexfec_streams,
stefan4fbd1452015-09-28 03:57:14 -070058 unsigned int start_bitrate_bps,
stefan5a2c5062017-01-27 06:43:18 -080059 int64_t min_run_time_ms,
stefan4fbd1452015-09-28 03:57:14 -070060 const std::string& extension_type,
61 bool rtx,
stefan5a2c5062017-01-27 06:43:18 -080062 bool red,
63 bool report_perf_stats)
stefan4fbd1452015-09-28 03:57:14 -070064 : EndToEndTest(test::CallTest::kLongTimeoutMs),
stefan4fbd1452015-09-28 03:57:14 -070065 clock_(Clock::GetRealTimeClock()),
stefanff483612015-12-21 03:14:00 -080066 num_video_streams_(num_video_streams),
67 num_audio_streams_(num_audio_streams),
philipel5ef2bc12017-02-21 07:28:31 -080068 num_flexfec_streams_(num_flexfec_streams),
stefan4fbd1452015-09-28 03:57:14 -070069 rtx_(rtx),
70 red_(red),
stefan45b5fe52017-03-09 06:27:02 -080071 report_perf_stats_(report_perf_stats),
mflodman86cc6ff2016-07-26 04:44:06 -070072 sender_call_(nullptr),
stefan4fbd1452015-09-28 03:57:14 -070073 send_stream_(nullptr),
sprang4847ae62017-06-27 07:06:52 -070074 send_transport_(nullptr),
Artem Titov631cafa2018-08-21 21:01:00 +020075 send_simulated_network_(nullptr),
stefan4fbd1452015-09-28 03:57:14 -070076 start_bitrate_bps_(start_bitrate_bps),
stefan5a2c5062017-01-27 06:43:18 -080077 min_run_time_ms_(min_run_time_ms),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +000078 expected_bitrate_bps_(0),
Erik Språngf3a7c9d2015-10-05 14:03:22 +020079 test_start_ms_(-1),
stefan4fbd1452015-09-28 03:57:14 -070080 ramp_up_finished_ms_(-1),
81 extension_type_(extension_type),
stefanff483612015-12-21 03:14:00 -080082 video_ssrcs_(GenerateSsrcs(num_video_streams_, 100)),
83 video_rtx_ssrcs_(GenerateSsrcs(num_video_streams_, 200)),
84 audio_ssrcs_(GenerateSsrcs(num_audio_streams_, 300)),
Peter Boström8c38e8b2015-11-26 17:45:47 +010085 poller_thread_(&BitrateStatsPollingThread,
86 this,
mflodman86cc6ff2016-07-26 04:44:06 -070087 "BitrateStatsPollingThread") {
philipel5ef2bc12017-02-21 07:28:31 -080088 if (red_)
89 EXPECT_EQ(0u, num_flexfec_streams_);
Stefan Holmerff2a6352016-01-14 10:00:21 +010090 EXPECT_LE(num_audio_streams_, 1u);
stefan4fbd1452015-09-28 03:57:14 -070091}
92
Yves Gerey665174f2018-06-19 15:03:05 +020093RampUpTester::~RampUpTester() {}
stefan4fbd1452015-09-28 03:57:14 -070094
Niels Möllerde8e6e62018-11-13 15:10:33 +010095void RampUpTester::ModifySenderBitrateConfig(
96 BitrateConstraints* bitrate_config) {
stefan4fbd1452015-09-28 03:57:14 -070097 if (start_bitrate_bps_ != 0) {
Niels Möllerde8e6e62018-11-13 15:10:33 +010098 bitrate_config->start_bitrate_bps = start_bitrate_bps_;
stefan4fbd1452015-09-28 03:57:14 -070099 }
Niels Möllerde8e6e62018-11-13 15:10:33 +0100100 bitrate_config->min_bitrate_bps = 10000;
stefan4fbd1452015-09-28 03:57:14 -0700101}
102
stefanff483612015-12-21 03:14:00 -0800103void RampUpTester::OnVideoStreamsCreated(
stefan4fbd1452015-09-28 03:57:14 -0700104 VideoSendStream* send_stream,
105 const std::vector<VideoReceiveStream*>& receive_streams) {
106 send_stream_ = send_stream;
107}
108
eladalon413ee9a2017-08-22 04:02:52 -0700109test::PacketTransport* RampUpTester::CreateSendTransport(
110 test::SingleThreadedTaskQueueForTesting* task_queue,
111 Call* sender_call) {
Artem Titov631cafa2018-08-21 21:01:00 +0200112 auto network = absl::make_unique<SimulatedNetwork>(forward_transport_config_);
113 send_simulated_network_ = network.get();
minyue20c84cc2017-04-10 16:57:57 -0700114 send_transport_ = new test::PacketTransport(
eladalon413ee9a2017-08-22 04:02:52 -0700115 task_queue, sender_call, this, test::PacketTransport::kSender,
Artem Titov4e199e92018-08-20 13:30:39 +0200116 test::CallTest::payload_type_map_,
Artem Titov631cafa2018-08-21 21:01:00 +0200117 absl::make_unique<FakeNetworkPipe>(Clock::GetRealTimeClock(),
118 std::move(network)));
stefane74eef12016-01-08 06:47:13 -0800119 return send_transport_;
stefanf116bd02015-10-27 08:29:42 -0700120}
121
Stefan Holmerd20e6512016-01-12 15:51:22 +0100122size_t RampUpTester::GetNumVideoStreams() const {
123 return num_video_streams_;
124}
125
Stefan Holmerff2a6352016-01-14 10:00:21 +0100126size_t RampUpTester::GetNumAudioStreams() const {
127 return num_audio_streams_;
128}
129
philipel5ef2bc12017-02-21 07:28:31 -0800130size_t RampUpTester::GetNumFlexfecStreams() const {
131 return num_flexfec_streams_;
132}
133
perkjfa10b552016-10-02 23:45:26 -0700134class RampUpTester::VideoStreamFactory
135 : public VideoEncoderConfig::VideoStreamFactoryInterface {
136 public:
137 VideoStreamFactory() {}
138
139 private:
140 std::vector<VideoStream> CreateEncoderStreams(
141 int width,
142 int height,
143 const VideoEncoderConfig& encoder_config) override {
144 std::vector<VideoStream> streams =
145 test::CreateVideoStreams(width, height, encoder_config);
146 if (encoder_config.number_of_streams == 1) {
147 streams[0].target_bitrate_bps = streams[0].max_bitrate_bps = 2000000;
148 }
149 return streams;
150 }
151};
152
stefanff483612015-12-21 03:14:00 -0800153void RampUpTester::ModifyVideoConfigs(
stefan4fbd1452015-09-28 03:57:14 -0700154 VideoSendStream::Config* send_config,
155 std::vector<VideoReceiveStream::Config>* receive_configs,
156 VideoEncoderConfig* encoder_config) {
157 send_config->suspend_below_min_bitrate = true;
perkjfa10b552016-10-02 23:45:26 -0700158 encoder_config->number_of_streams = num_video_streams_;
159 encoder_config->max_bitrate_bps = 2000000;
160 encoder_config->video_stream_factory =
161 new rtc::RefCountedObject<RampUpTester::VideoStreamFactory>();
stefanff483612015-12-21 03:14:00 -0800162 if (num_video_streams_ == 1) {
stefan4fbd1452015-09-28 03:57:14 -0700163 // For single stream rampup until 1mbps
164 expected_bitrate_bps_ = kSingleStreamTargetBps;
165 } else {
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200166 // To ensure simulcast rate allocation.
167 send_config->rtp.payload_name = "VP8";
168 encoder_config->codec_type = kVideoCodecVP8;
perkjfa10b552016-10-02 23:45:26 -0700169 std::vector<VideoStream> streams = test::CreateVideoStreams(
170 test::CallTest::kDefaultWidth, test::CallTest::kDefaultHeight,
171 *encoder_config);
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200172 // For multi stream rampup until all streams are being sent. That means
173 // enough bitrate to send all the target streams plus the min bitrate of
174 // the last one.
perkjfa10b552016-10-02 23:45:26 -0700175 expected_bitrate_bps_ = streams.back().min_bitrate_bps;
176 for (size_t i = 0; i < streams.size() - 1; ++i) {
177 expected_bitrate_bps_ += streams[i].target_bitrate_bps;
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000178 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000179 }
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000180
stefan4fbd1452015-09-28 03:57:14 -0700181 send_config->rtp.extensions.clear();
182
183 bool remb;
stefan43edf0f2015-11-20 18:05:48 -0800184 bool transport_cc;
isheriff6f8d6862016-05-26 11:24:55 -0700185 if (extension_type_ == RtpExtension::kAbsSendTimeUri) {
stefan4fbd1452015-09-28 03:57:14 -0700186 remb = true;
stefan43edf0f2015-11-20 18:05:48 -0800187 transport_cc = false;
stefan4fbd1452015-09-28 03:57:14 -0700188 send_config->rtp.extensions.push_back(
189 RtpExtension(extension_type_.c_str(), kAbsSendTimeExtensionId));
isheriff6f8d6862016-05-26 11:24:55 -0700190 } else if (extension_type_ == RtpExtension::kTransportSequenceNumberUri) {
stefan4fbd1452015-09-28 03:57:14 -0700191 remb = false;
stefan43edf0f2015-11-20 18:05:48 -0800192 transport_cc = true;
stefan4fbd1452015-09-28 03:57:14 -0700193 send_config->rtp.extensions.push_back(RtpExtension(
194 extension_type_.c_str(), kTransportSequenceNumberExtensionId));
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000195 } else {
stefan4fbd1452015-09-28 03:57:14 -0700196 remb = true;
stefan43edf0f2015-11-20 18:05:48 -0800197 transport_cc = false;
stefan4fbd1452015-09-28 03:57:14 -0700198 send_config->rtp.extensions.push_back(RtpExtension(
199 extension_type_.c_str(), kTransmissionTimeOffsetExtensionId));
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000200 }
stefan4fbd1452015-09-28 03:57:14 -0700201
202 send_config->rtp.nack.rtp_history_ms = test::CallTest::kNackRtpHistoryMs;
stefanff483612015-12-21 03:14:00 -0800203 send_config->rtp.ssrcs = video_ssrcs_;
stefan4fbd1452015-09-28 03:57:14 -0700204 if (rtx_) {
205 send_config->rtp.rtx.payload_type = test::CallTest::kSendRtxPayloadType;
stefanff483612015-12-21 03:14:00 -0800206 send_config->rtp.rtx.ssrcs = video_rtx_ssrcs_;
stefan4fbd1452015-09-28 03:57:14 -0700207 }
208 if (red_) {
brandtrb5f2c3f2016-10-04 23:28:39 -0700209 send_config->rtp.ulpfec.ulpfec_payload_type =
stefan4fbd1452015-09-28 03:57:14 -0700210 test::CallTest::kUlpfecPayloadType;
brandtrb5f2c3f2016-10-04 23:28:39 -0700211 send_config->rtp.ulpfec.red_payload_type = test::CallTest::kRedPayloadType;
brandtrfbfb5362016-11-17 04:18:37 -0800212 if (rtx_) {
213 send_config->rtp.ulpfec.red_rtx_payload_type =
214 test::CallTest::kRtxRedPayloadType;
215 }
stefan4fbd1452015-09-28 03:57:14 -0700216 }
217
218 size_t i = 0;
219 for (VideoReceiveStream::Config& recv_config : *receive_configs) {
220 recv_config.rtp.remb = remb;
stefan43edf0f2015-11-20 18:05:48 -0800221 recv_config.rtp.transport_cc = transport_cc;
stefan4fbd1452015-09-28 03:57:14 -0700222 recv_config.rtp.extensions = send_config->rtp.extensions;
Ilya Nikolaevskiyb0588e62018-08-27 14:12:27 +0200223 recv_config.decoders.reserve(1);
224 recv_config.decoders[0].payload_type = send_config->rtp.payload_type;
Niels Möllercb7e1d22018-09-11 15:56:04 +0200225 recv_config.decoders[0].video_format =
226 SdpVideoFormat(send_config->rtp.payload_name);
stefan4fbd1452015-09-28 03:57:14 -0700227
stefanff483612015-12-21 03:14:00 -0800228 recv_config.rtp.remote_ssrc = video_ssrcs_[i];
stefan4fbd1452015-09-28 03:57:14 -0700229 recv_config.rtp.nack.rtp_history_ms = send_config->rtp.nack.rtp_history_ms;
230
231 if (red_) {
nisse3b3622f2017-09-26 02:49:21 -0700232 recv_config.rtp.red_payload_type =
brandtrb5f2c3f2016-10-04 23:28:39 -0700233 send_config->rtp.ulpfec.red_payload_type;
nisse3b3622f2017-09-26 02:49:21 -0700234 recv_config.rtp.ulpfec_payload_type =
brandtrb5f2c3f2016-10-04 23:28:39 -0700235 send_config->rtp.ulpfec.ulpfec_payload_type;
brandtrfbfb5362016-11-17 04:18:37 -0800236 if (rtx_) {
nisseca5706d2017-09-11 02:32:16 -0700237 recv_config.rtp.rtx_associated_payload_types
238 [send_config->rtp.ulpfec.red_rtx_payload_type] =
239 send_config->rtp.ulpfec.red_payload_type;
brandtrfbfb5362016-11-17 04:18:37 -0800240 }
stefan4fbd1452015-09-28 03:57:14 -0700241 }
242
243 if (rtx_) {
brandtr14742122017-01-27 04:53:07 -0800244 recv_config.rtp.rtx_ssrc = video_rtx_ssrcs_[i];
245 recv_config.rtp
nisse26e3abb2017-08-25 04:44:25 -0700246 .rtx_associated_payload_types[send_config->rtp.rtx.payload_type] =
Niels Möller259a4972018-04-05 15:36:51 +0200247 send_config->rtp.payload_type;
stefan4fbd1452015-09-28 03:57:14 -0700248 }
249 ++i;
250 }
philipel5ef2bc12017-02-21 07:28:31 -0800251
252 RTC_DCHECK_LE(num_flexfec_streams_, 1);
253 if (num_flexfec_streams_ == 1) {
254 send_config->rtp.flexfec.payload_type = test::CallTest::kFlexfecPayloadType;
255 send_config->rtp.flexfec.ssrc = test::CallTest::kFlexfecSendSsrc;
256 send_config->rtp.flexfec.protected_media_ssrcs = {video_ssrcs_[0]};
257 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000258}
259
Stefan Holmerff2a6352016-01-14 10:00:21 +0100260void RampUpTester::ModifyAudioConfigs(
261 AudioSendStream::Config* send_config,
262 std::vector<AudioReceiveStream::Config>* receive_configs) {
263 if (num_audio_streams_ == 0)
264 return;
265
isheriff6f8d6862016-05-26 11:24:55 -0700266 EXPECT_NE(RtpExtension::kTimestampOffsetUri, extension_type_)
Stefan Holmerff2a6352016-01-14 10:00:21 +0100267 << "Audio BWE not supported with toffset.";
philipel5ef2bc12017-02-21 07:28:31 -0800268 EXPECT_NE(RtpExtension::kAbsSendTimeUri, extension_type_)
269 << "Audio BWE not supported with abs-send-time.";
Stefan Holmerff2a6352016-01-14 10:00:21 +0100270
271 send_config->rtp.ssrc = audio_ssrcs_[0];
272 send_config->rtp.extensions.clear();
273
minyue10cbb462016-11-07 09:29:22 -0800274 send_config->min_bitrate_bps = 6000;
275 send_config->max_bitrate_bps = 60000;
mflodman86cc6ff2016-07-26 04:44:06 -0700276
Stefan Holmerff2a6352016-01-14 10:00:21 +0100277 bool transport_cc = false;
philipel5ef2bc12017-02-21 07:28:31 -0800278 if (extension_type_ == RtpExtension::kTransportSequenceNumberUri) {
Stefan Holmerff2a6352016-01-14 10:00:21 +0100279 transport_cc = true;
280 send_config->rtp.extensions.push_back(RtpExtension(
281 extension_type_.c_str(), kTransportSequenceNumberExtensionId));
282 }
283
284 for (AudioReceiveStream::Config& recv_config : *receive_configs) {
Stefan Holmerff2a6352016-01-14 10:00:21 +0100285 recv_config.rtp.transport_cc = transport_cc;
286 recv_config.rtp.extensions = send_config->rtp.extensions;
287 recv_config.rtp.remote_ssrc = send_config->rtp.ssrc;
288 }
289}
290
philipel5ef2bc12017-02-21 07:28:31 -0800291void RampUpTester::ModifyFlexfecConfigs(
292 std::vector<FlexfecReceiveStream::Config>* receive_configs) {
293 if (num_flexfec_streams_ == 0)
294 return;
295 RTC_DCHECK_EQ(1, num_flexfec_streams_);
296 (*receive_configs)[0].payload_type = test::CallTest::kFlexfecPayloadType;
297 (*receive_configs)[0].remote_ssrc = test::CallTest::kFlexfecSendSsrc;
298 (*receive_configs)[0].protected_media_ssrcs = {video_ssrcs_[0]};
299 (*receive_configs)[0].local_ssrc = video_ssrcs_[0];
300 if (extension_type_ == RtpExtension::kAbsSendTimeUri) {
301 (*receive_configs)[0].transport_cc = false;
302 (*receive_configs)[0].rtp_header_extensions.push_back(
303 RtpExtension(extension_type_.c_str(), kAbsSendTimeExtensionId));
304 } else if (extension_type_ == RtpExtension::kTransportSequenceNumberUri) {
305 (*receive_configs)[0].transport_cc = true;
306 (*receive_configs)[0].rtp_header_extensions.push_back(RtpExtension(
307 extension_type_.c_str(), kTransportSequenceNumberExtensionId));
308 }
309}
310
stefan4fbd1452015-09-28 03:57:14 -0700311void RampUpTester::OnCallsCreated(Call* sender_call, Call* receiver_call) {
312 sender_call_ = sender_call;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000313}
314
tommi0f8b4032017-02-22 11:22:05 -0800315void RampUpTester::BitrateStatsPollingThread(void* obj) {
316 static_cast<RampUpTester*>(obj)->PollStats();
pbos@webrtc.org32452b22014-10-22 12:15:24 +0000317}
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000318
tommi0f8b4032017-02-22 11:22:05 -0800319void RampUpTester::PollStats() {
320 do {
321 if (sender_call_) {
322 Call::Stats stats = sender_call_->GetStats();
stefan4fbd1452015-09-28 03:57:14 -0700323
tommi0f8b4032017-02-22 11:22:05 -0800324 EXPECT_GE(expected_bitrate_bps_, 0);
325 if (stats.send_bandwidth_bps >= expected_bitrate_bps_ &&
326 (min_run_time_ms_ == -1 ||
327 clock_->TimeInMilliseconds() - test_start_ms_ >= min_run_time_ms_)) {
328 ramp_up_finished_ms_ = clock_->TimeInMilliseconds();
329 observation_complete_.Set();
330 }
stefan4fbd1452015-09-28 03:57:14 -0700331 }
tommi0f8b4032017-02-22 11:22:05 -0800332 } while (!stop_event_.Wait(kPollIntervalMs));
Erik Språng468e62a2015-07-06 10:50:47 +0200333}
334
stefan4fbd1452015-09-28 03:57:14 -0700335void RampUpTester::ReportResult(const std::string& measurement,
336 size_t value,
337 const std::string& units) const {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000338 webrtc::test::PrintResult(
339 measurement, "",
stefanff483612015-12-21 03:14:00 -0800340 ::testing::UnitTest::GetInstance()->current_test_info()->name(), value,
341 units, false);
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000342}
343
stefan092508a2015-09-29 02:26:42 -0700344void RampUpTester::AccumulateStats(const VideoSendStream::StreamStats& stream,
345 size_t* total_packets_sent,
346 size_t* total_sent,
347 size_t* padding_sent,
348 size_t* media_sent) const {
stefan4fbd1452015-09-28 03:57:14 -0700349 *total_packets_sent += stream.rtp_stats.transmitted.packets +
350 stream.rtp_stats.retransmitted.packets +
351 stream.rtp_stats.fec.packets;
352 *total_sent += stream.rtp_stats.transmitted.TotalBytes() +
353 stream.rtp_stats.retransmitted.TotalBytes() +
354 stream.rtp_stats.fec.TotalBytes();
355 *padding_sent += stream.rtp_stats.transmitted.padding_bytes +
356 stream.rtp_stats.retransmitted.padding_bytes +
357 stream.rtp_stats.fec.padding_bytes;
358 *media_sent += stream.rtp_stats.MediaPayloadBytes();
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000359}
360
stefan4fbd1452015-09-28 03:57:14 -0700361void RampUpTester::TriggerTestDone() {
Erik Språngf3a7c9d2015-10-05 14:03:22 +0200362 RTC_DCHECK_GE(test_start_ms_, 0);
363
Stefan Holmerff2a6352016-01-14 10:00:21 +0100364 // TODO(holmer): Add audio send stats here too when those APIs are available.
mflodman86cc6ff2016-07-26 04:44:06 -0700365 if (!send_stream_)
366 return;
367
stefan4fbd1452015-09-28 03:57:14 -0700368 VideoSendStream::Stats send_stats = send_stream_->GetStats();
369
370 size_t total_packets_sent = 0;
371 size_t total_sent = 0;
372 size_t padding_sent = 0;
373 size_t media_sent = 0;
stefanff483612015-12-21 03:14:00 -0800374 for (uint32_t ssrc : video_ssrcs_) {
stefan092508a2015-09-29 02:26:42 -0700375 AccumulateStats(send_stats.substreams[ssrc], &total_packets_sent,
376 &total_sent, &padding_sent, &media_sent);
stefan4fbd1452015-09-28 03:57:14 -0700377 }
378
379 size_t rtx_total_packets_sent = 0;
380 size_t rtx_total_sent = 0;
381 size_t rtx_padding_sent = 0;
382 size_t rtx_media_sent = 0;
stefanff483612015-12-21 03:14:00 -0800383 for (uint32_t rtx_ssrc : video_rtx_ssrcs_) {
stefan092508a2015-09-29 02:26:42 -0700384 AccumulateStats(send_stats.substreams[rtx_ssrc], &rtx_total_packets_sent,
385 &rtx_total_sent, &rtx_padding_sent, &rtx_media_sent);
stefan4fbd1452015-09-28 03:57:14 -0700386 }
387
stefan5a2c5062017-01-27 06:43:18 -0800388 if (report_perf_stats_) {
stefan5a2c5062017-01-27 06:43:18 -0800389 ReportResult("ramp-up-media-sent", media_sent, "bytes");
390 ReportResult("ramp-up-padding-sent", padding_sent, "bytes");
stefan5a2c5062017-01-27 06:43:18 -0800391 ReportResult("ramp-up-rtx-media-sent", rtx_media_sent, "bytes");
392 ReportResult("ramp-up-rtx-padding-sent", rtx_padding_sent, "bytes");
393 if (ramp_up_finished_ms_ >= 0) {
394 ReportResult("ramp-up-time", ramp_up_finished_ms_ - test_start_ms_,
395 "milliseconds");
396 }
397 ReportResult("ramp-up-average-network-latency",
398 send_transport_->GetAverageDelayMs(), "milliseconds");
stefan4fbd1452015-09-28 03:57:14 -0700399 }
400}
401
402void RampUpTester::PerformTest() {
Erik Språngf3a7c9d2015-10-05 14:03:22 +0200403 test_start_ms_ = clock_->TimeInMilliseconds();
Peter Boström8c38e8b2015-11-26 17:45:47 +0100404 poller_thread_.Start();
Peter Boström5811a392015-12-10 13:02:50 +0100405 EXPECT_TRUE(Wait()) << "Timed out while waiting for ramp-up to complete.";
stefan4fbd1452015-09-28 03:57:14 -0700406 TriggerTestDone();
tommi0f8b4032017-02-22 11:22:05 -0800407 stop_event_.Set();
Peter Boström8c38e8b2015-11-26 17:45:47 +0100408 poller_thread_.Stop();
stefan4fbd1452015-09-28 03:57:14 -0700409}
410
Stefan Holmerff2a6352016-01-14 10:00:21 +0100411RampUpDownUpTester::RampUpDownUpTester(size_t num_video_streams,
412 size_t num_audio_streams,
philipel5ef2bc12017-02-21 07:28:31 -0800413 size_t num_flexfec_streams,
stefan4fbd1452015-09-28 03:57:14 -0700414 unsigned int start_bitrate_bps,
415 const std::string& extension_type,
416 bool rtx,
philipel5ef2bc12017-02-21 07:28:31 -0800417 bool red,
stefan45b5fe52017-03-09 06:27:02 -0800418 const std::vector<int>& loss_rates,
419 bool report_perf_stats)
Stefan Holmerff2a6352016-01-14 10:00:21 +0100420 : RampUpTester(num_video_streams,
421 num_audio_streams,
philipel5ef2bc12017-02-21 07:28:31 -0800422 num_flexfec_streams,
Stefan Holmerff2a6352016-01-14 10:00:21 +0100423 start_bitrate_bps,
stefan5a2c5062017-01-27 06:43:18 -0800424 0,
Stefan Holmerff2a6352016-01-14 10:00:21 +0100425 extension_type,
426 rtx,
stefan5a2c5062017-01-27 06:43:18 -0800427 red,
stefan45b5fe52017-03-09 06:27:02 -0800428 report_perf_stats),
stefan76d9c9c2017-04-01 06:51:09 -0700429 link_rates_({4 * GetExpectedHighBitrate() / (3 * 1000),
430 kLowBandwidthLimitBps / 1000,
431 4 * GetExpectedHighBitrate() / (3 * 1000), 0}),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000432 test_state_(kFirstRampup),
philipel5ef2bc12017-02-21 07:28:31 -0800433 next_state_(kTransitionToNextState),
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000434 state_start_ms_(clock_->TimeInMilliseconds()),
stefan4fbd1452015-09-28 03:57:14 -0700435 interval_start_ms_(clock_->TimeInMilliseconds()),
philipel5ef2bc12017-02-21 07:28:31 -0800436 sent_bytes_(0),
437 loss_rates_(loss_rates) {
438 forward_transport_config_.link_capacity_kbps = link_rates_[test_state_];
439 forward_transport_config_.queue_delay_ms = 100;
440 forward_transport_config_.loss_percent = loss_rates_[test_state_];
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000441}
442
stefan4fbd1452015-09-28 03:57:14 -0700443RampUpDownUpTester::~RampUpDownUpTester() {}
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000444
tommi0f8b4032017-02-22 11:22:05 -0800445void RampUpDownUpTester::PollStats() {
446 do {
Alex Narest78609d52017-10-20 10:37:47 +0200447 int transmit_bitrate_bps = 0;
448 bool suspended = false;
449 if (num_video_streams_ > 0) {
tommi0f8b4032017-02-22 11:22:05 -0800450 webrtc::VideoSendStream::Stats stats = send_stream_->GetStats();
Mirko Bonadei739baf02019-01-27 17:29:42 +0100451 for (const auto& it : stats.substreams) {
tommi0f8b4032017-02-22 11:22:05 -0800452 transmit_bitrate_bps += it.second.total_bitrate_bps;
453 }
Alex Narest78609d52017-10-20 10:37:47 +0200454 suspended = stats.suspended;
455 }
456 if (num_audio_streams_ > 0 && sender_call_ != nullptr) {
tommi0f8b4032017-02-22 11:22:05 -0800457 // An audio send stream doesn't have bitrate stats, so the call send BW is
458 // currently used instead.
Alex Narest78609d52017-10-20 10:37:47 +0200459 transmit_bitrate_bps = sender_call_->GetStats().send_bandwidth_bps;
mflodman@webrtc.orgeb16b812014-06-16 08:57:39 +0000460 }
Alex Narest78609d52017-10-20 10:37:47 +0200461 EvolveTestState(transmit_bitrate_bps, suspended);
tommi0f8b4032017-02-22 11:22:05 -0800462 } while (!stop_event_.Wait(kPollIntervalMs));
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000463}
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000464
Niels Möllerde8e6e62018-11-13 15:10:33 +0100465void RampUpDownUpTester::ModifyReceiverBitrateConfig(
466 BitrateConstraints* bitrate_config) {
467 bitrate_config->min_bitrate_bps = 10000;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000468}
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000469
stefan4fbd1452015-09-28 03:57:14 -0700470std::string RampUpDownUpTester::GetModifierString() const {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000471 std::string str("_");
stefanff483612015-12-21 03:14:00 -0800472 if (num_video_streams_ > 0) {
Jonas Olsson0a713b62018-04-04 15:49:32 +0200473 str += rtc::ToString(num_video_streams_);
stefanff483612015-12-21 03:14:00 -0800474 str += "stream";
475 str += (num_video_streams_ > 1 ? "s" : "");
476 str += "_";
477 }
478 if (num_audio_streams_ > 0) {
Jonas Olsson0a713b62018-04-04 15:49:32 +0200479 str += rtc::ToString(num_audio_streams_);
stefanff483612015-12-21 03:14:00 -0800480 str += "stream";
481 str += (num_audio_streams_ > 1 ? "s" : "");
482 str += "_";
483 }
stefan4fbd1452015-09-28 03:57:14 -0700484 str += (rtx_ ? "" : "no");
Edward Lemurdd3987f2018-01-04 19:44:54 +0100485 str += "rtx_";
486 str += (red_ ? "" : "no");
487 str += "red";
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000488 return str;
489}
andresp@webrtc.orgc1480792014-03-20 03:23:55 +0000490
stefandb752f92016-12-05 08:23:40 -0800491int RampUpDownUpTester::GetExpectedHighBitrate() const {
stefan38d8b3c2017-01-09 04:19:24 -0800492 int expected_bitrate_bps = 0;
493 if (num_audio_streams_ > 0)
494 expected_bitrate_bps += kExpectedHighAudioBitrateBps;
495 if (num_video_streams_ > 0)
496 expected_bitrate_bps += kExpectedHighVideoBitrateBps;
497 return expected_bitrate_bps;
498}
499
philipel5ef2bc12017-02-21 07:28:31 -0800500size_t RampUpDownUpTester::GetFecBytes() const {
501 size_t flex_fec_bytes = 0;
502 if (num_flexfec_streams_ > 0) {
503 webrtc::VideoSendStream::Stats stats = send_stream_->GetStats();
504 for (const auto& kv : stats.substreams)
505 flex_fec_bytes += kv.second.rtp_stats.fec.TotalBytes();
506 }
507 return flex_fec_bytes;
508}
509
510bool RampUpDownUpTester::ExpectingFec() const {
511 return num_flexfec_streams_ > 0 && forward_transport_config_.loss_percent > 0;
512}
513
stefan4fbd1452015-09-28 03:57:14 -0700514void RampUpDownUpTester::EvolveTestState(int bitrate_bps, bool suspended) {
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000515 int64_t now = clock_->TimeInMilliseconds();
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000516 switch (test_state_) {
philipel5ef2bc12017-02-21 07:28:31 -0800517 case kFirstRampup:
stefan4fbd1452015-09-28 03:57:14 -0700518 EXPECT_FALSE(suspended);
stefandb752f92016-12-05 08:23:40 -0800519 if (bitrate_bps >= GetExpectedHighBitrate()) {
stefan45b5fe52017-03-09 06:27:02 -0800520 if (report_perf_stats_) {
521 webrtc::test::PrintResult("ramp_up_down_up", GetModifierString(),
522 "first_rampup", now - state_start_ms_, "ms",
523 false);
524 }
philipel5ef2bc12017-02-21 07:28:31 -0800525 // Apply loss during the transition between states if FEC is enabled.
526 forward_transport_config_.loss_percent = loss_rates_[test_state_];
527 test_state_ = kTransitionToNextState;
528 next_state_ = kLowRate;
andresp@webrtc.orgc1480792014-03-20 03:23:55 +0000529 }
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000530 break;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000531 case kLowRate: {
mflodman86cc6ff2016-07-26 04:44:06 -0700532 // Audio streams are never suspended.
533 bool check_suspend_state = num_video_streams_ > 0;
Sebastian Jansson12fb1702018-02-23 11:34:18 +0100534 if (bitrate_bps < kLowBandwidthLimitBps + kLowBitrateMarginBps &&
mflodman86cc6ff2016-07-26 04:44:06 -0700535 suspended == check_suspend_state) {
stefan45b5fe52017-03-09 06:27:02 -0800536 if (report_perf_stats_) {
537 webrtc::test::PrintResult("ramp_up_down_up", GetModifierString(),
538 "rampdown", now - state_start_ms_, "ms",
539 false);
540 }
philipel5ef2bc12017-02-21 07:28:31 -0800541 // Apply loss during the transition between states if FEC is enabled.
542 forward_transport_config_.loss_percent = loss_rates_[test_state_];
543 test_state_ = kTransitionToNextState;
544 next_state_ = kSecondRampup;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000545 }
546 break;
547 }
philipel5ef2bc12017-02-21 07:28:31 -0800548 case kSecondRampup:
stefandb752f92016-12-05 08:23:40 -0800549 if (bitrate_bps >= GetExpectedHighBitrate() && !suspended) {
stefan45b5fe52017-03-09 06:27:02 -0800550 if (report_perf_stats_) {
551 webrtc::test::PrintResult("ramp_up_down_up", GetModifierString(),
552 "second_rampup", now - state_start_ms_,
553 "ms", false);
554 ReportResult("ramp-up-down-up-average-network-latency",
555 send_transport_->GetAverageDelayMs(), "milliseconds");
556 }
philipel5ef2bc12017-02-21 07:28:31 -0800557 // Apply loss during the transition between states if FEC is enabled.
558 forward_transport_config_.loss_percent = loss_rates_[test_state_];
559 test_state_ = kTransitionToNextState;
560 next_state_ = kTestEnd;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000561 }
562 break;
philipel5ef2bc12017-02-21 07:28:31 -0800563 case kTestEnd:
564 observation_complete_.Set();
565 break;
566 case kTransitionToNextState:
567 if (!ExpectingFec() || GetFecBytes() > 0) {
568 test_state_ = next_state_;
569 forward_transport_config_.link_capacity_kbps = link_rates_[test_state_];
570 // No loss while ramping up and down as it may affect the BWE
571 // negatively, making the test flaky.
572 forward_transport_config_.loss_percent = 0;
573 state_start_ms_ = now;
574 interval_start_ms_ = now;
575 sent_bytes_ = 0;
Artem Titov631cafa2018-08-21 21:01:00 +0200576 send_simulated_network_->SetConfig(forward_transport_config_);
philipel5ef2bc12017-02-21 07:28:31 -0800577 }
578 break;
stefan@webrtc.org3d7da882014-07-08 13:59:46 +0000579 }
580}
pbos@webrtc.orgf577ae92014-03-19 08:43:57 +0000581
stefan4fbd1452015-09-28 03:57:14 -0700582class RampUpTest : public test::CallTest {
Erik Språng6b8d3552015-09-24 15:06:57 +0200583 public:
Danil Chapovalov304ea5f2019-04-11 15:18:18 +0200584 RampUpTest()
585 : task_queue_factory_(CreateDefaultTaskQueueFactory()),
586 rtc_event_log_factory_(task_queue_factory_.get()) {
Mirko Bonadei2ab97f62019-07-18 13:44:12 +0200587 std::string dump_name(absl::GetFlag(FLAGS_ramp_dump_name));
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200588 if (!dump_name.empty()) {
Danil Chapovalov304ea5f2019-04-11 15:18:18 +0200589 send_event_log_ = rtc_event_log_factory_.CreateRtcEventLog(
590 RtcEventLog::EncodingType::Legacy);
591 recv_event_log_ = rtc_event_log_factory_.CreateRtcEventLog(
592 RtcEventLog::EncodingType::Legacy);
Sebastian Janssonf5e767d2018-10-15 13:24:31 +0200593 bool event_log_started =
594 send_event_log_->StartLogging(
595 absl::make_unique<RtcEventLogOutputFile>(
596 dump_name + ".send.rtc.dat", RtcEventLog::kUnlimitedOutput),
597 RtcEventLog::kImmediateOutput) &&
598 recv_event_log_->StartLogging(
599 absl::make_unique<RtcEventLogOutputFile>(
600 dump_name + ".recv.rtc.dat", RtcEventLog::kUnlimitedOutput),
601 RtcEventLog::kImmediateOutput);
602 RTC_DCHECK(event_log_started);
603 }
604 }
Danil Chapovalov304ea5f2019-04-11 15:18:18 +0200605
606 private:
607 const std::unique_ptr<TaskQueueFactory> task_queue_factory_;
608 RtcEventLogFactory rtc_event_log_factory_;
Erik Språng6b8d3552015-09-24 15:06:57 +0200609};
610
Stefan Holmerff2a6352016-01-14 10:00:21 +0100611static const uint32_t kStartBitrateBps = 60000;
612
stefan38d8b3c2017-01-09 04:19:24 -0800613TEST_F(RampUpTest, UpDownUpAbsSendTimeSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800614 std::vector<int> loss_rates = {0, 0, 0, 0};
615 RampUpDownUpTester test(3, 0, 0, kStartBitrateBps,
stefan45b5fe52017-03-09 06:27:02 -0800616 RtpExtension::kAbsSendTimeUri, true, true, loss_rates,
617 true);
stefane74eef12016-01-08 06:47:13 -0800618 RunBaseTest(&test);
Shao Changbine62202f2015-04-21 20:24:50 +0800619}
Stefan Holmerff2a6352016-01-14 10:00:21 +0100620
Taylor Brandstetterba6b5032018-02-16 09:59:56 -0800621// TODO(bugs.webrtc.org/8878)
622#if defined(WEBRTC_MAC)
623#define MAYBE_UpDownUpTransportSequenceNumberRtx \
624 DISABLED_UpDownUpTransportSequenceNumberRtx
625#else
626#define MAYBE_UpDownUpTransportSequenceNumberRtx \
627 UpDownUpTransportSequenceNumberRtx
628#endif
629TEST_F(RampUpTest, MAYBE_UpDownUpTransportSequenceNumberRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800630 std::vector<int> loss_rates = {0, 0, 0, 0};
631 RampUpDownUpTester test(3, 0, 0, kStartBitrateBps,
isheriff6f8d6862016-05-26 11:24:55 -0700632 RtpExtension::kTransportSequenceNumberUri, true,
stefan45b5fe52017-03-09 06:27:02 -0800633 false, loss_rates, true);
philipel5ef2bc12017-02-21 07:28:31 -0800634 RunBaseTest(&test);
635}
636
stefan45b5fe52017-03-09 06:27:02 -0800637// TODO(holmer): Tests which don't report perf stats should be moved to a
638// different executable since they per definition are not perf tests.
Taylor Brandstetter05d98222017-10-10 12:12:53 -0700639// This test is disabled because it crashes on Linux, and is flaky on other
640// platforms. See: crbug.com/webrtc/7919
641TEST_F(RampUpTest, DISABLED_UpDownUpTransportSequenceNumberPacketLoss) {
philipel5ef2bc12017-02-21 07:28:31 -0800642 std::vector<int> loss_rates = {20, 0, 0, 0};
643 RampUpDownUpTester test(1, 0, 1, kStartBitrateBps,
644 RtpExtension::kTransportSequenceNumberUri, true,
stefan45b5fe52017-03-09 06:27:02 -0800645 false, loss_rates, false);
Stefan Holmerff2a6352016-01-14 10:00:21 +0100646 RunBaseTest(&test);
647}
648
Taylor Brandstetterab86e7f2018-02-12 15:16:02 -0800649// TODO(bugs.webrtc.org/8878)
650#if defined(WEBRTC_MAC)
651#define MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx \
652 DISABLED_UpDownUpAudioVideoTransportSequenceNumberRtx
653#else
654#define MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx \
655 UpDownUpAudioVideoTransportSequenceNumberRtx
656#endif
657TEST_F(RampUpTest, MAYBE_UpDownUpAudioVideoTransportSequenceNumberRtx) {
Per Kjellander914351d2019-02-15 10:54:55 +0100658 test::ScopedFieldTrials field_trials("WebRTC-Audio-SendSideBwe/Enabled/");
philipel5ef2bc12017-02-21 07:28:31 -0800659 std::vector<int> loss_rates = {0, 0, 0, 0};
660 RampUpDownUpTester test(3, 1, 0, kStartBitrateBps,
isheriff6f8d6862016-05-26 11:24:55 -0700661 RtpExtension::kTransportSequenceNumberUri, true,
stefanff2ebf52017-03-13 01:27:03 -0700662 false, loss_rates, false);
Stefan Holmerff2a6352016-01-14 10:00:21 +0100663 RunBaseTest(&test);
664}
665
stefan38d8b3c2017-01-09 04:19:24 -0800666TEST_F(RampUpTest, UpDownUpAudioTransportSequenceNumberRtx) {
Per Kjellander914351d2019-02-15 10:54:55 +0100667 test::ScopedFieldTrials field_trials("WebRTC-Audio-SendSideBwe/Enabled/");
philipel5ef2bc12017-02-21 07:28:31 -0800668 std::vector<int> loss_rates = {0, 0, 0, 0};
669 RampUpDownUpTester test(0, 1, 0, kStartBitrateBps,
mflodman86cc6ff2016-07-26 04:44:06 -0700670 RtpExtension::kTransportSequenceNumberUri, true,
stefanff2ebf52017-03-13 01:27:03 -0700671 false, loss_rates, false);
mflodman86cc6ff2016-07-26 04:44:06 -0700672 RunBaseTest(&test);
673}
674
stefan38d8b3c2017-01-09 04:19:24 -0800675TEST_F(RampUpTest, TOffsetSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800676 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kTimestampOffsetUri, true,
677 true, true);
stefan38d8b3c2017-01-09 04:19:24 -0800678 RunBaseTest(&test);
679}
680
681TEST_F(RampUpTest, AbsSendTime) {
philipel5ef2bc12017-02-21 07:28:31 -0800682 RampUpTester test(1, 0, 0, 0, 0, RtpExtension::kAbsSendTimeUri, false, false,
stefanff2ebf52017-03-13 01:27:03 -0700683 false);
stefane74eef12016-01-08 06:47:13 -0800684 RunBaseTest(&test);
pbos@webrtc.org85bd53e2014-12-10 10:36:20 +0000685}
686
stefan38d8b3c2017-01-09 04:19:24 -0800687TEST_F(RampUpTest, AbsSendTimeSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800688 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kAbsSendTimeUri, true, true,
stefan5a2c5062017-01-27 06:43:18 -0800689 true);
stefane74eef12016-01-08 06:47:13 -0800690 RunBaseTest(&test);
pbos@webrtc.org85bd53e2014-12-10 10:36:20 +0000691}
692
stefan38d8b3c2017-01-09 04:19:24 -0800693TEST_F(RampUpTest, TransportSequenceNumber) {
philipel5ef2bc12017-02-21 07:28:31 -0800694 RampUpTester test(1, 0, 0, 0, 0, RtpExtension::kTransportSequenceNumberUri,
stefanff2ebf52017-03-13 01:27:03 -0700695 false, false, false);
stefane74eef12016-01-08 06:47:13 -0800696 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200697}
698
699TEST_F(RampUpTest, TransportSequenceNumberSimulcast) {
philipel5ef2bc12017-02-21 07:28:31 -0800700 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kTransportSequenceNumberUri,
stefanff2ebf52017-03-13 01:27:03 -0700701 false, false, false);
stefane74eef12016-01-08 06:47:13 -0800702 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200703}
704
stefan38d8b3c2017-01-09 04:19:24 -0800705TEST_F(RampUpTest, TransportSequenceNumberSimulcastRedRtx) {
philipel5ef2bc12017-02-21 07:28:31 -0800706 RampUpTester test(3, 0, 0, 0, 0, RtpExtension::kTransportSequenceNumberUri,
stefan5a2c5062017-01-27 06:43:18 -0800707 true, true, true);
708 RunBaseTest(&test);
709}
710
Niels Möllercd2e1052018-11-08 10:23:13 +0100711TEST_F(RampUpTest, AudioTransportSequenceNumber) {
philipel5ef2bc12017-02-21 07:28:31 -0800712 RampUpTester test(0, 1, 0, 300000, 10000,
stefan5a2c5062017-01-27 06:43:18 -0800713 RtpExtension::kTransportSequenceNumberUri, false, false,
714 false);
stefane74eef12016-01-08 06:47:13 -0800715 RunBaseTest(&test);
Erik Språng6b8d3552015-09-24 15:06:57 +0200716}
pbos@webrtc.org744fbc72013-09-10 09:26:25 +0000717} // namespace webrtc