blob: 9011f81b36691347d34a9f48570d7755cd0bd341 [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));
125 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes, 111))
Stefan Holmere5904162015-03-26 11:11:06 +0100126 .Times(1)
127 .WillOnce(Return(sent_padding_bytes));
stefan16b02212017-01-27 07:12:16 -0800128 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
129 EXPECT_CALL(rtp_1, TimeToSendPadding(
philipela1ed0b32016-06-01 06:31:17 -0700130 requested_padding_bytes - sent_padding_bytes, 111))
sprang867fb522015-08-03 04:38:41 -0700131 .Times(1)
132 .WillOnce(Return(requested_padding_bytes - sent_padding_bytes));
133 EXPECT_EQ(requested_padding_bytes,
philipela1ed0b32016-06-01 06:31:17 -0700134 packet_router_->TimeToSendPadding(requested_padding_bytes, 111));
Stefan Holmere5904162015-03-26 11:11:06 +0100135
stefan16b02212017-01-27 07:12:16 -0800136 // Let only the lower priority module be sending and verify the padding
137 // request is routed there.
138 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false));
139 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes, _)).Times(0);
140 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
141 EXPECT_CALL(rtp_1, TimeToSendPadding(_, _))
Stefan Holmere5904162015-03-26 11:11:06 +0100142 .Times(1)
143 .WillOnce(Return(sent_padding_bytes));
144 EXPECT_EQ(sent_padding_bytes,
philipela1ed0b32016-06-01 06:31:17 -0700145 packet_router_->TimeToSendPadding(requested_padding_bytes,
146 PacketInfo::kNotAProbe));
Stefan Holmere5904162015-03-26 11:11:06 +0100147
148 // No sending module at all.
149 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
philipela1ed0b32016-06-01 06:31:17 -0700150 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes, _)).Times(0);
Stefan Holmere5904162015-03-26 11:11:06 +0100151 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false));
philipela1ed0b32016-06-01 06:31:17 -0700152 EXPECT_CALL(rtp_2, TimeToSendPadding(_, _)).Times(0);
153 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes,
154 PacketInfo::kNotAProbe));
Stefan Holmere5904162015-03-26 11:11:06 +0100155
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100156 packet_router_->RemoveRtpModule(&rtp_1);
Stefan Holmere5904162015-03-26 11:11:06 +0100157
158 // rtp_1 has been removed, try sending padding and make sure rtp_1 isn't asked
159 // to send by not expecting any calls. Instead verify rtp_2 is called.
160 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
philipela1ed0b32016-06-01 06:31:17 -0700161 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes, _)).Times(1);
162 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes,
163 PacketInfo::kNotAProbe));
Stefan Holmere5904162015-03-26 11:11:06 +0100164
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100165 packet_router_->RemoveRtpModule(&rtp_2);
166}
167
168TEST_F(PacketRouterTest, SenderOnlyFunctionsRespectSendingMedia) {
169 MockRtpRtcp rtp;
170 packet_router_->AddRtpModule(&rtp);
171 static const uint16_t kSsrc = 1234;
172 EXPECT_CALL(rtp, SSRC()).WillRepeatedly(Return(kSsrc));
173 EXPECT_CALL(rtp, SendingMedia()).WillRepeatedly(Return(false));
174
175 // Verify that TimeToSendPacket does not end up in a receiver.
philipela1ed0b32016-06-01 06:31:17 -0700176 EXPECT_CALL(rtp, TimeToSendPacket(_, _, _, _, _)).Times(0);
177 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc, 1, 1, false,
178 PacketInfo::kNotAProbe));
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100179 // Verify that TimeToSendPadding does not end up in a receiver.
philipela1ed0b32016-06-01 06:31:17 -0700180 EXPECT_CALL(rtp, TimeToSendPadding(_, _)).Times(0);
181 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(200, PacketInfo::kNotAProbe));
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100182
183 packet_router_->RemoveRtpModule(&rtp);
Stefan Holmere5904162015-03-26 11:11:06 +0100184}
sprang867fb522015-08-03 04:38:41 -0700185
186TEST_F(PacketRouterTest, AllocateSequenceNumbers) {
187 const uint16_t kStartSeq = 0xFFF0;
188 const size_t kNumPackets = 32;
189
190 packet_router_->SetTransportWideSequenceNumber(kStartSeq - 1);
191
192 for (size_t i = 0; i < kNumPackets; ++i) {
193 uint16_t seq = packet_router_->AllocateSequenceNumber();
194 uint32_t expected_unwrapped_seq = static_cast<uint32_t>(kStartSeq) + i;
195 EXPECT_EQ(static_cast<uint16_t>(expected_unwrapped_seq & 0xFFFF), seq);
196 }
197}
stefanbba9dec2016-02-01 04:39:55 -0800198
199TEST_F(PacketRouterTest, SendFeedback) {
200 MockRtpRtcp rtp_1;
201 MockRtpRtcp rtp_2;
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100202 packet_router_->AddRtpModule(&rtp_1);
203 packet_router_->AddRtpModule(&rtp_2);
stefanbba9dec2016-02-01 04:39:55 -0800204
205 rtcp::TransportFeedback feedback;
206 EXPECT_CALL(rtp_1, SendFeedbackPacket(_)).Times(1);
207 packet_router_->SendFeedback(&feedback);
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100208 packet_router_->RemoveRtpModule(&rtp_1);
stefanbba9dec2016-02-01 04:39:55 -0800209 EXPECT_CALL(rtp_2, SendFeedbackPacket(_)).Times(1);
210 packet_router_->SendFeedback(&feedback);
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100211 packet_router_->RemoveRtpModule(&rtp_2);
stefanbba9dec2016-02-01 04:39:55 -0800212}
Stefan Holmere5904162015-03-26 11:11:06 +0100213} // namespace webrtc