blob: a0688ffbbed8aff9eeced7cb3ce10439652772d2 [file] [log] [blame]
Stefan Holmere5904162015-03-26 11:11:06 +01001/*
2 * Copyright (c) 2015 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 */
10
11#include <list>
kwiberg22feaa32016-03-17 09:17:43 -070012#include <memory>
Stefan Holmere5904162015-03-26 11:11:06 +010013
14#include "webrtc/base/checks.h"
Henrik Kjellander0b9e29c2015-11-16 11:12:24 +010015#include "webrtc/modules/pacing/packet_router.h"
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010016#include "webrtc/modules/rtp_rtcp/include/rtp_rtcp.h"
Stefan Holmere5904162015-03-26 11:11:06 +010017#include "webrtc/modules/rtp_rtcp/mocks/mock_rtp_rtcp.h"
stefanbba9dec2016-02-01 04:39:55 -080018#include "webrtc/modules/rtp_rtcp/source/rtcp_packet/transport_feedback.h"
kwibergac9f8762016-09-30 22:29:43 -070019#include "webrtc/test/gmock.h"
20#include "webrtc/test/gtest.h"
Stefan Holmere5904162015-03-26 11:11:06 +010021
22using ::testing::_;
23using ::testing::AnyNumber;
24using ::testing::NiceMock;
25using ::testing::Return;
26
27namespace webrtc {
28
29class PacketRouterTest : public ::testing::Test {
30 public:
31 PacketRouterTest() : packet_router_(new PacketRouter()) {}
32 protected:
kwiberg22feaa32016-03-17 09:17:43 -070033 const std::unique_ptr<PacketRouter> packet_router_;
Stefan Holmere5904162015-03-26 11:11:06 +010034};
35
36TEST_F(PacketRouterTest, TimeToSendPacket) {
37 MockRtpRtcp rtp_1;
38 MockRtpRtcp rtp_2;
Peter Boström3dd5d1d2016-02-25 16:56:48 +010039 packet_router_->AddRtpModule(&rtp_1);
40 packet_router_->AddRtpModule(&rtp_2);
Stefan Holmere5904162015-03-26 11:11:06 +010041
42 const uint16_t kSsrc1 = 1234;
43 uint16_t sequence_number = 17;
44 uint64_t timestamp = 7890;
45 bool retransmission = false;
46
47 // Send on the first module by letting rtp_1 be sending with correct ssrc.
48 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
49 EXPECT_CALL(rtp_1, SSRC()).Times(1).WillOnce(Return(kSsrc1));
50 EXPECT_CALL(rtp_1, TimeToSendPacket(kSsrc1, sequence_number, timestamp,
philipela1ed0b32016-06-01 06:31:17 -070051 retransmission, 1))
Stefan Holmere5904162015-03-26 11:11:06 +010052 .Times(1)
53 .WillOnce(Return(true));
philipela1ed0b32016-06-01 06:31:17 -070054 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _, _)).Times(0);
Stefan Holmere5904162015-03-26 11:11:06 +010055 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number,
philipela1ed0b32016-06-01 06:31:17 -070056 timestamp, retransmission, 1));
Stefan Holmere5904162015-03-26 11:11:06 +010057
58 // Send on the second module by letting rtp_2 be sending, but not rtp_1.
59 ++sequence_number;
60 timestamp += 30;
61 retransmission = true;
62 const uint16_t kSsrc2 = 4567;
63 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
64 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
65 EXPECT_CALL(rtp_2, SSRC()).Times(1).WillOnce(Return(kSsrc2));
philipela1ed0b32016-06-01 06:31:17 -070066 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _, _)).Times(0);
Stefan Holmere5904162015-03-26 11:11:06 +010067 EXPECT_CALL(rtp_2, TimeToSendPacket(kSsrc2, sequence_number, timestamp,
philipela1ed0b32016-06-01 06:31:17 -070068 retransmission, 2))
Stefan Holmere5904162015-03-26 11:11:06 +010069 .Times(1)
70 .WillOnce(Return(true));
71 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc2, sequence_number,
philipela1ed0b32016-06-01 06:31:17 -070072 timestamp, retransmission, 2));
Stefan Holmere5904162015-03-26 11:11:06 +010073
74 // No module is sending, hence no packet should be sent.
75 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
philipela1ed0b32016-06-01 06:31:17 -070076 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _, _)).Times(0);
Stefan Holmere5904162015-03-26 11:11:06 +010077 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false));
philipela1ed0b32016-06-01 06:31:17 -070078 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _, _)).Times(0);
Stefan Holmere5904162015-03-26 11:11:06 +010079 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number,
philipela1ed0b32016-06-01 06:31:17 -070080 timestamp, retransmission, 1));
Stefan Holmere5904162015-03-26 11:11:06 +010081
82 // Add a packet with incorrect ssrc and test it's dropped in the router.
83 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
84 EXPECT_CALL(rtp_1, SSRC()).Times(1).WillOnce(Return(kSsrc1));
85 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
86 EXPECT_CALL(rtp_2, SSRC()).Times(1).WillOnce(Return(kSsrc2));
philipela1ed0b32016-06-01 06:31:17 -070087 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _, _)).Times(0);
88 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _, _)).Times(0);
Stefan Holmere5904162015-03-26 11:11:06 +010089 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1 + kSsrc2, sequence_number,
philipela1ed0b32016-06-01 06:31:17 -070090 timestamp, retransmission, 1));
Stefan Holmere5904162015-03-26 11:11:06 +010091
Peter Boström3dd5d1d2016-02-25 16:56:48 +010092 packet_router_->RemoveRtpModule(&rtp_1);
Stefan Holmere5904162015-03-26 11:11:06 +010093
94 // rtp_1 has been removed, try sending a packet on that ssrc and make sure
95 // it is dropped as expected by not expecting any calls to rtp_1.
96 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
97 EXPECT_CALL(rtp_2, SSRC()).Times(1).WillOnce(Return(kSsrc2));
philipela1ed0b32016-06-01 06:31:17 -070098 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _, _)).Times(0);
Stefan Holmere5904162015-03-26 11:11:06 +010099 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number,
philipela1ed0b32016-06-01 06:31:17 -0700100 timestamp, retransmission,
101 PacketInfo::kNotAProbe));
Stefan Holmere5904162015-03-26 11:11:06 +0100102
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100103 packet_router_->RemoveRtpModule(&rtp_2);
Stefan Holmere5904162015-03-26 11:11:06 +0100104}
105
106TEST_F(PacketRouterTest, TimeToSendPadding) {
sprang867fb522015-08-03 04:38:41 -0700107 const uint16_t kSsrc1 = 1234;
108 const uint16_t kSsrc2 = 4567;
109
Stefan Holmere5904162015-03-26 11:11:06 +0100110 MockRtpRtcp rtp_1;
stefan16b02212017-01-27 07:12:16 -0800111 EXPECT_CALL(rtp_1, RtxSendStatus()).WillOnce(Return(kRtxOff));
sprang867fb522015-08-03 04:38:41 -0700112 EXPECT_CALL(rtp_1, SSRC()).WillRepeatedly(Return(kSsrc1));
Stefan Holmere5904162015-03-26 11:11:06 +0100113 MockRtpRtcp rtp_2;
stefan16b02212017-01-27 07:12:16 -0800114 // rtp_2 will be prioritized for padding.
115 EXPECT_CALL(rtp_2, RtxSendStatus()).WillOnce(Return(kRtxRedundantPayloads));
sprang867fb522015-08-03 04:38:41 -0700116 EXPECT_CALL(rtp_2, SSRC()).WillRepeatedly(Return(kSsrc2));
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100117 packet_router_->AddRtpModule(&rtp_1);
118 packet_router_->AddRtpModule(&rtp_2);
Stefan Holmere5904162015-03-26 11:11:06 +0100119
sprang867fb522015-08-03 04:38:41 -0700120 // Default configuration, sending padding on all modules sending media,
stefan16b02212017-01-27 07:12:16 -0800121 // ordered by priority (based on rtx mode).
Stefan Holmere5904162015-03-26 11:11:06 +0100122 const size_t requested_padding_bytes = 1000;
123 const size_t sent_padding_bytes = 890;
stefan16b02212017-01-27 07:12:16 -0800124 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
stefan53b6cc32017-02-03 08:13:57 -0800125 EXPECT_CALL(rtp_2, HasBweExtensions()).Times(1).WillOnce(Return(true));
stefan16b02212017-01-27 07:12:16 -0800126 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes, 111))
Stefan Holmere5904162015-03-26 11:11:06 +0100127 .Times(1)
128 .WillOnce(Return(sent_padding_bytes));
stefan16b02212017-01-27 07:12:16 -0800129 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
stefan53b6cc32017-02-03 08:13:57 -0800130 EXPECT_CALL(rtp_1, HasBweExtensions()).Times(1).WillOnce(Return(true));
stefan16b02212017-01-27 07:12:16 -0800131 EXPECT_CALL(rtp_1, TimeToSendPadding(
philipela1ed0b32016-06-01 06:31:17 -0700132 requested_padding_bytes - sent_padding_bytes, 111))
sprang867fb522015-08-03 04:38:41 -0700133 .Times(1)
134 .WillOnce(Return(requested_padding_bytes - sent_padding_bytes));
135 EXPECT_EQ(requested_padding_bytes,
philipela1ed0b32016-06-01 06:31:17 -0700136 packet_router_->TimeToSendPadding(requested_padding_bytes, 111));
Stefan Holmere5904162015-03-26 11:11:06 +0100137
stefan16b02212017-01-27 07:12:16 -0800138 // Let only the lower priority module be sending and verify the padding
139 // request is routed there.
140 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false));
141 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes, _)).Times(0);
142 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
stefan53b6cc32017-02-03 08:13:57 -0800143 EXPECT_CALL(rtp_1, HasBweExtensions()).Times(1).WillOnce(Return(true));
stefan16b02212017-01-27 07:12:16 -0800144 EXPECT_CALL(rtp_1, TimeToSendPadding(_, _))
Stefan Holmere5904162015-03-26 11:11:06 +0100145 .Times(1)
146 .WillOnce(Return(sent_padding_bytes));
147 EXPECT_EQ(sent_padding_bytes,
philipela1ed0b32016-06-01 06:31:17 -0700148 packet_router_->TimeToSendPadding(requested_padding_bytes,
149 PacketInfo::kNotAProbe));
Stefan Holmere5904162015-03-26 11:11:06 +0100150
151 // No sending module at all.
152 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
philipela1ed0b32016-06-01 06:31:17 -0700153 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes, _)).Times(0);
Stefan Holmere5904162015-03-26 11:11:06 +0100154 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false));
philipela1ed0b32016-06-01 06:31:17 -0700155 EXPECT_CALL(rtp_2, TimeToSendPadding(_, _)).Times(0);
156 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes,
157 PacketInfo::kNotAProbe));
Stefan Holmere5904162015-03-26 11:11:06 +0100158
stefan53b6cc32017-02-03 08:13:57 -0800159 // Only one module has BWE extensions.
160 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
161 EXPECT_CALL(rtp_1, HasBweExtensions()).Times(1).WillOnce(Return(false));
162 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes, _)).Times(0);
163 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
164 EXPECT_CALL(rtp_2, HasBweExtensions()).Times(1).WillOnce(Return(true));
165 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes, _))
166 .Times(1)
167 .WillOnce(Return(sent_padding_bytes));
168 EXPECT_EQ(sent_padding_bytes,
169 packet_router_->TimeToSendPadding(requested_padding_bytes,
170 PacketInfo::kNotAProbe));
171
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100172 packet_router_->RemoveRtpModule(&rtp_1);
Stefan Holmere5904162015-03-26 11:11:06 +0100173
174 // rtp_1 has been removed, try sending padding and make sure rtp_1 isn't asked
175 // to send by not expecting any calls. Instead verify rtp_2 is called.
176 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
stefan53b6cc32017-02-03 08:13:57 -0800177 EXPECT_CALL(rtp_2, HasBweExtensions()).Times(1).WillOnce(Return(true));
philipela1ed0b32016-06-01 06:31:17 -0700178 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes, _)).Times(1);
179 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes,
180 PacketInfo::kNotAProbe));
Stefan Holmere5904162015-03-26 11:11:06 +0100181
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100182 packet_router_->RemoveRtpModule(&rtp_2);
183}
184
185TEST_F(PacketRouterTest, SenderOnlyFunctionsRespectSendingMedia) {
186 MockRtpRtcp rtp;
187 packet_router_->AddRtpModule(&rtp);
188 static const uint16_t kSsrc = 1234;
189 EXPECT_CALL(rtp, SSRC()).WillRepeatedly(Return(kSsrc));
190 EXPECT_CALL(rtp, SendingMedia()).WillRepeatedly(Return(false));
191
192 // Verify that TimeToSendPacket does not end up in a receiver.
philipela1ed0b32016-06-01 06:31:17 -0700193 EXPECT_CALL(rtp, TimeToSendPacket(_, _, _, _, _)).Times(0);
194 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc, 1, 1, false,
195 PacketInfo::kNotAProbe));
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100196 // Verify that TimeToSendPadding does not end up in a receiver.
philipela1ed0b32016-06-01 06:31:17 -0700197 EXPECT_CALL(rtp, TimeToSendPadding(_, _)).Times(0);
198 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(200, PacketInfo::kNotAProbe));
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100199
200 packet_router_->RemoveRtpModule(&rtp);
Stefan Holmere5904162015-03-26 11:11:06 +0100201}
sprang867fb522015-08-03 04:38:41 -0700202
203TEST_F(PacketRouterTest, AllocateSequenceNumbers) {
204 const uint16_t kStartSeq = 0xFFF0;
205 const size_t kNumPackets = 32;
206
207 packet_router_->SetTransportWideSequenceNumber(kStartSeq - 1);
208
209 for (size_t i = 0; i < kNumPackets; ++i) {
210 uint16_t seq = packet_router_->AllocateSequenceNumber();
211 uint32_t expected_unwrapped_seq = static_cast<uint32_t>(kStartSeq) + i;
212 EXPECT_EQ(static_cast<uint16_t>(expected_unwrapped_seq & 0xFFFF), seq);
213 }
214}
stefanbba9dec2016-02-01 04:39:55 -0800215
216TEST_F(PacketRouterTest, SendFeedback) {
217 MockRtpRtcp rtp_1;
218 MockRtpRtcp rtp_2;
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100219 packet_router_->AddRtpModule(&rtp_1);
220 packet_router_->AddRtpModule(&rtp_2);
stefanbba9dec2016-02-01 04:39:55 -0800221
222 rtcp::TransportFeedback feedback;
223 EXPECT_CALL(rtp_1, SendFeedbackPacket(_)).Times(1);
224 packet_router_->SendFeedback(&feedback);
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100225 packet_router_->RemoveRtpModule(&rtp_1);
stefanbba9dec2016-02-01 04:39:55 -0800226 EXPECT_CALL(rtp_2, SendFeedbackPacket(_)).Times(1);
227 packet_router_->SendFeedback(&feedback);
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100228 packet_router_->RemoveRtpModule(&rtp_2);
stefanbba9dec2016-02-01 04:39:55 -0800229}
Stefan Holmere5904162015-03-26 11:11:06 +0100230} // namespace webrtc