blob: 456e1def4f829b379133275761ed6f68164d88ab [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;
sprang867fb522015-08-03 04:38:41 -0700111 EXPECT_CALL(rtp_1, SSRC()).WillRepeatedly(Return(kSsrc1));
Stefan Holmere5904162015-03-26 11:11:06 +0100112 MockRtpRtcp rtp_2;
sprang867fb522015-08-03 04:38:41 -0700113 EXPECT_CALL(rtp_2, SSRC()).WillRepeatedly(Return(kSsrc2));
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100114 packet_router_->AddRtpModule(&rtp_1);
115 packet_router_->AddRtpModule(&rtp_2);
Stefan Holmere5904162015-03-26 11:11:06 +0100116
sprang867fb522015-08-03 04:38:41 -0700117 // Default configuration, sending padding on all modules sending media,
118 // ordered by SSRC.
Stefan Holmere5904162015-03-26 11:11:06 +0100119 const size_t requested_padding_bytes = 1000;
120 const size_t sent_padding_bytes = 890;
121 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
philipela1ed0b32016-06-01 06:31:17 -0700122 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes, 111))
Stefan Holmere5904162015-03-26 11:11:06 +0100123 .Times(1)
124 .WillOnce(Return(sent_padding_bytes));
sprang867fb522015-08-03 04:38:41 -0700125 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
philipela1ed0b32016-06-01 06:31:17 -0700126 EXPECT_CALL(rtp_2, TimeToSendPadding(
127 requested_padding_bytes - sent_padding_bytes, 111))
sprang867fb522015-08-03 04:38:41 -0700128 .Times(1)
129 .WillOnce(Return(requested_padding_bytes - sent_padding_bytes));
130 EXPECT_EQ(requested_padding_bytes,
philipela1ed0b32016-06-01 06:31:17 -0700131 packet_router_->TimeToSendPadding(requested_padding_bytes, 111));
Stefan Holmere5904162015-03-26 11:11:06 +0100132
133 // Let only the second module be sending and verify the padding request is
134 // routed there.
135 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
philipela1ed0b32016-06-01 06:31:17 -0700136 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes, _)).Times(0);
Stefan Holmere5904162015-03-26 11:11:06 +0100137 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
philipela1ed0b32016-06-01 06:31:17 -0700138 EXPECT_CALL(rtp_2, TimeToSendPadding(_, _))
Stefan Holmere5904162015-03-26 11:11:06 +0100139 .Times(1)
140 .WillOnce(Return(sent_padding_bytes));
141 EXPECT_EQ(sent_padding_bytes,
philipela1ed0b32016-06-01 06:31:17 -0700142 packet_router_->TimeToSendPadding(requested_padding_bytes,
143 PacketInfo::kNotAProbe));
Stefan Holmere5904162015-03-26 11:11:06 +0100144
145 // No sending module at all.
146 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
philipela1ed0b32016-06-01 06:31:17 -0700147 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes, _)).Times(0);
Stefan Holmere5904162015-03-26 11:11:06 +0100148 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false));
philipela1ed0b32016-06-01 06:31:17 -0700149 EXPECT_CALL(rtp_2, TimeToSendPadding(_, _)).Times(0);
150 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes,
151 PacketInfo::kNotAProbe));
Stefan Holmere5904162015-03-26 11:11:06 +0100152
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100153 packet_router_->RemoveRtpModule(&rtp_1);
Stefan Holmere5904162015-03-26 11:11:06 +0100154
155 // rtp_1 has been removed, try sending padding and make sure rtp_1 isn't asked
156 // to send by not expecting any calls. Instead verify rtp_2 is called.
157 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
philipela1ed0b32016-06-01 06:31:17 -0700158 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes, _)).Times(1);
159 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes,
160 PacketInfo::kNotAProbe));
Stefan Holmere5904162015-03-26 11:11:06 +0100161
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100162 packet_router_->RemoveRtpModule(&rtp_2);
163}
164
165TEST_F(PacketRouterTest, SenderOnlyFunctionsRespectSendingMedia) {
166 MockRtpRtcp rtp;
167 packet_router_->AddRtpModule(&rtp);
168 static const uint16_t kSsrc = 1234;
169 EXPECT_CALL(rtp, SSRC()).WillRepeatedly(Return(kSsrc));
170 EXPECT_CALL(rtp, SendingMedia()).WillRepeatedly(Return(false));
171
172 // Verify that TimeToSendPacket does not end up in a receiver.
philipela1ed0b32016-06-01 06:31:17 -0700173 EXPECT_CALL(rtp, TimeToSendPacket(_, _, _, _, _)).Times(0);
174 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc, 1, 1, false,
175 PacketInfo::kNotAProbe));
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100176 // Verify that TimeToSendPadding does not end up in a receiver.
philipela1ed0b32016-06-01 06:31:17 -0700177 EXPECT_CALL(rtp, TimeToSendPadding(_, _)).Times(0);
178 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(200, PacketInfo::kNotAProbe));
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100179
180 packet_router_->RemoveRtpModule(&rtp);
Stefan Holmere5904162015-03-26 11:11:06 +0100181}
sprang867fb522015-08-03 04:38:41 -0700182
183TEST_F(PacketRouterTest, AllocateSequenceNumbers) {
184 const uint16_t kStartSeq = 0xFFF0;
185 const size_t kNumPackets = 32;
186
187 packet_router_->SetTransportWideSequenceNumber(kStartSeq - 1);
188
189 for (size_t i = 0; i < kNumPackets; ++i) {
190 uint16_t seq = packet_router_->AllocateSequenceNumber();
191 uint32_t expected_unwrapped_seq = static_cast<uint32_t>(kStartSeq) + i;
192 EXPECT_EQ(static_cast<uint16_t>(expected_unwrapped_seq & 0xFFFF), seq);
193 }
194}
stefanbba9dec2016-02-01 04:39:55 -0800195
196TEST_F(PacketRouterTest, SendFeedback) {
197 MockRtpRtcp rtp_1;
198 MockRtpRtcp rtp_2;
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100199 packet_router_->AddRtpModule(&rtp_1);
200 packet_router_->AddRtpModule(&rtp_2);
stefanbba9dec2016-02-01 04:39:55 -0800201
202 rtcp::TransportFeedback feedback;
203 EXPECT_CALL(rtp_1, SendFeedbackPacket(_)).Times(1);
204 packet_router_->SendFeedback(&feedback);
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100205 packet_router_->RemoveRtpModule(&rtp_1);
stefanbba9dec2016-02-01 04:39:55 -0800206 EXPECT_CALL(rtp_2, SendFeedbackPacket(_)).Times(1);
207 packet_router_->SendFeedback(&feedback);
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100208 packet_router_->RemoveRtpModule(&rtp_2);
stefanbba9dec2016-02-01 04:39:55 -0800209}
Stefan Holmere5904162015-03-26 11:11:06 +0100210} // namespace webrtc