blob: 006b9f2bf48c2ed803e41a5e0e6ee615975dbd5b [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"
15#include "testing/gmock/include/gmock/gmock.h"
16#include "testing/gtest/include/gtest/gtest.h"
Henrik Kjellander0b9e29c2015-11-16 11:12:24 +010017#include "webrtc/modules/pacing/packet_router.h"
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010018#include "webrtc/modules/rtp_rtcp/include/rtp_rtcp.h"
Stefan Holmere5904162015-03-26 11:11:06 +010019#include "webrtc/modules/rtp_rtcp/mocks/mock_rtp_rtcp.h"
stefanbba9dec2016-02-01 04:39:55 -080020#include "webrtc/modules/rtp_rtcp/source/rtcp_packet/transport_feedback.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,
51 retransmission))
52 .Times(1)
53 .WillOnce(Return(true));
54 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _)).Times(0);
55 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number,
philipel29dca2c2016-05-13 11:13:05 +020056 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));
66 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _)).Times(0);
67 EXPECT_CALL(rtp_2, TimeToSendPacket(kSsrc2, sequence_number, timestamp,
68 retransmission))
69 .Times(1)
70 .WillOnce(Return(true));
71 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc2, sequence_number,
philipel29dca2c2016-05-13 11:13:05 +020072 timestamp, retransmission, -1));
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));
76 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _)).Times(0);
77 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false));
78 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _)).Times(0);
79 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number,
philipel29dca2c2016-05-13 11:13:05 +020080 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));
87 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _)).Times(0);
88 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _)).Times(0);
89 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1 + kSsrc2, sequence_number,
philipel29dca2c2016-05-13 11:13:05 +020090 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));
98 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _)).Times(0);
99 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number,
philipel29dca2c2016-05-13 11:13:05 +0200100 timestamp, retransmission, -1));
Stefan Holmere5904162015-03-26 11:11:06 +0100101
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100102 packet_router_->RemoveRtpModule(&rtp_2);
Stefan Holmere5904162015-03-26 11:11:06 +0100103}
104
105TEST_F(PacketRouterTest, TimeToSendPadding) {
sprang867fb522015-08-03 04:38:41 -0700106 const uint16_t kSsrc1 = 1234;
107 const uint16_t kSsrc2 = 4567;
108
Stefan Holmere5904162015-03-26 11:11:06 +0100109 MockRtpRtcp rtp_1;
sprang867fb522015-08-03 04:38:41 -0700110 EXPECT_CALL(rtp_1, SSRC()).WillRepeatedly(Return(kSsrc1));
Stefan Holmere5904162015-03-26 11:11:06 +0100111 MockRtpRtcp rtp_2;
sprang867fb522015-08-03 04:38:41 -0700112 EXPECT_CALL(rtp_2, SSRC()).WillRepeatedly(Return(kSsrc2));
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100113 packet_router_->AddRtpModule(&rtp_1);
114 packet_router_->AddRtpModule(&rtp_2);
Stefan Holmere5904162015-03-26 11:11:06 +0100115
sprang867fb522015-08-03 04:38:41 -0700116 // Default configuration, sending padding on all modules sending media,
117 // ordered by SSRC.
Stefan Holmere5904162015-03-26 11:11:06 +0100118 const size_t requested_padding_bytes = 1000;
119 const size_t sent_padding_bytes = 890;
120 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
121 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes))
122 .Times(1)
123 .WillOnce(Return(sent_padding_bytes));
sprang867fb522015-08-03 04:38:41 -0700124 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
125 EXPECT_CALL(rtp_2,
126 TimeToSendPadding(requested_padding_bytes - sent_padding_bytes))
127 .Times(1)
128 .WillOnce(Return(requested_padding_bytes - sent_padding_bytes));
129 EXPECT_EQ(requested_padding_bytes,
Stefan Holmere5904162015-03-26 11:11:06 +0100130 packet_router_->TimeToSendPadding(requested_padding_bytes));
131
132 // Let only the second module be sending and verify the padding request is
133 // routed there.
134 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
135 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes)).Times(0);
136 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
137 EXPECT_CALL(rtp_2, TimeToSendPadding(_))
138 .Times(1)
139 .WillOnce(Return(sent_padding_bytes));
140 EXPECT_EQ(sent_padding_bytes,
141 packet_router_->TimeToSendPadding(requested_padding_bytes));
142
143 // No sending module at all.
144 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
145 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes)).Times(0);
146 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false));
147 EXPECT_CALL(rtp_2, TimeToSendPadding(_)).Times(0);
sprang867fb522015-08-03 04:38:41 -0700148 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes));
Stefan Holmere5904162015-03-26 11:11:06 +0100149
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100150 packet_router_->RemoveRtpModule(&rtp_1);
Stefan Holmere5904162015-03-26 11:11:06 +0100151
152 // rtp_1 has been removed, try sending padding and make sure rtp_1 isn't asked
153 // to send by not expecting any calls. Instead verify rtp_2 is called.
154 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
155 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes)).Times(1);
sprang867fb522015-08-03 04:38:41 -0700156 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes));
Stefan Holmere5904162015-03-26 11:11:06 +0100157
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100158 packet_router_->RemoveRtpModule(&rtp_2);
159}
160
161TEST_F(PacketRouterTest, SenderOnlyFunctionsRespectSendingMedia) {
162 MockRtpRtcp rtp;
163 packet_router_->AddRtpModule(&rtp);
164 static const uint16_t kSsrc = 1234;
165 EXPECT_CALL(rtp, SSRC()).WillRepeatedly(Return(kSsrc));
166 EXPECT_CALL(rtp, SendingMedia()).WillRepeatedly(Return(false));
167
168 // Verify that TimeToSendPacket does not end up in a receiver.
169 EXPECT_CALL(rtp, TimeToSendPacket(_, _, _, _)).Times(0);
philipel29dca2c2016-05-13 11:13:05 +0200170 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc, 1, 1, false, -1));
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100171 // Verify that TimeToSendPadding does not end up in a receiver.
172 EXPECT_CALL(rtp, TimeToSendPadding(_)).Times(0);
173 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(200));
174
175 packet_router_->RemoveRtpModule(&rtp);
Stefan Holmere5904162015-03-26 11:11:06 +0100176}
sprang867fb522015-08-03 04:38:41 -0700177
178TEST_F(PacketRouterTest, AllocateSequenceNumbers) {
179 const uint16_t kStartSeq = 0xFFF0;
180 const size_t kNumPackets = 32;
181
182 packet_router_->SetTransportWideSequenceNumber(kStartSeq - 1);
183
184 for (size_t i = 0; i < kNumPackets; ++i) {
185 uint16_t seq = packet_router_->AllocateSequenceNumber();
186 uint32_t expected_unwrapped_seq = static_cast<uint32_t>(kStartSeq) + i;
187 EXPECT_EQ(static_cast<uint16_t>(expected_unwrapped_seq & 0xFFFF), seq);
188 }
189}
stefanbba9dec2016-02-01 04:39:55 -0800190
191TEST_F(PacketRouterTest, SendFeedback) {
192 MockRtpRtcp rtp_1;
193 MockRtpRtcp rtp_2;
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100194 packet_router_->AddRtpModule(&rtp_1);
195 packet_router_->AddRtpModule(&rtp_2);
stefanbba9dec2016-02-01 04:39:55 -0800196
197 rtcp::TransportFeedback feedback;
198 EXPECT_CALL(rtp_1, SendFeedbackPacket(_)).Times(1);
199 packet_router_->SendFeedback(&feedback);
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100200 packet_router_->RemoveRtpModule(&rtp_1);
stefanbba9dec2016-02-01 04:39:55 -0800201 EXPECT_CALL(rtp_2, SendFeedbackPacket(_)).Times(1);
202 packet_router_->SendFeedback(&feedback);
Peter Boström3dd5d1d2016-02-25 16:56:48 +0100203 packet_router_->RemoveRtpModule(&rtp_2);
stefanbba9dec2016-02-01 04:39:55 -0800204}
Stefan Holmere5904162015-03-26 11:11:06 +0100205} // namespace webrtc