Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(284)

Side by Side Diff: webrtc/modules/pacing/packet_router_unittest.cc

Issue 2005313003: Propagate probing cluster id to SendTimeHistory. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Feedback fixes. Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 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 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 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
(...skipping 30 matching lines...) Expand all
41 41
42 const uint16_t kSsrc1 = 1234; 42 const uint16_t kSsrc1 = 1234;
43 uint16_t sequence_number = 17; 43 uint16_t sequence_number = 17;
44 uint64_t timestamp = 7890; 44 uint64_t timestamp = 7890;
45 bool retransmission = false; 45 bool retransmission = false;
46 46
47 // Send on the first module by letting rtp_1 be sending with correct ssrc. 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)); 48 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
49 EXPECT_CALL(rtp_1, SSRC()).Times(1).WillOnce(Return(kSsrc1)); 49 EXPECT_CALL(rtp_1, SSRC()).Times(1).WillOnce(Return(kSsrc1));
50 EXPECT_CALL(rtp_1, TimeToSendPacket(kSsrc1, sequence_number, timestamp, 50 EXPECT_CALL(rtp_1, TimeToSendPacket(kSsrc1, sequence_number, timestamp,
51 retransmission)) 51 retransmission, PacketInfo::kNotAProbe))
52 .Times(1) 52 .Times(1)
53 .WillOnce(Return(true)); 53 .WillOnce(Return(true));
54 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _)).Times(0); 54 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _, _)).Times(0);
55 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number, 55 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number,
56 timestamp, retransmission, -1)); 56 timestamp, retransmission,
57 PacketInfo::kNotAProbe));
57 58
58 // Send on the second module by letting rtp_2 be sending, but not rtp_1. 59 // Send on the second module by letting rtp_2 be sending, but not rtp_1.
59 ++sequence_number; 60 ++sequence_number;
60 timestamp += 30; 61 timestamp += 30;
61 retransmission = true; 62 retransmission = true;
62 const uint16_t kSsrc2 = 4567; 63 const uint16_t kSsrc2 = 4567;
63 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false)); 64 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, SendingMedia()).Times(1).WillOnce(Return(true));
65 EXPECT_CALL(rtp_2, SSRC()).Times(1).WillOnce(Return(kSsrc2)); 66 EXPECT_CALL(rtp_2, SSRC()).Times(1).WillOnce(Return(kSsrc2));
66 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _)).Times(0); 67 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _, _)).Times(0);
67 EXPECT_CALL(rtp_2, TimeToSendPacket(kSsrc2, sequence_number, timestamp, 68 EXPECT_CALL(rtp_2, TimeToSendPacket(kSsrc2, sequence_number, timestamp,
68 retransmission)) 69 retransmission, PacketInfo::kNotAProbe))
69 .Times(1) 70 .Times(1)
70 .WillOnce(Return(true)); 71 .WillOnce(Return(true));
71 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc2, sequence_number, 72 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc2, sequence_number,
72 timestamp, retransmission, -1)); 73 timestamp, retransmission,
74 PacketInfo::kNotAProbe));
73 75
74 // No module is sending, hence no packet should be sent. 76 // No module is sending, hence no packet should be sent.
75 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false)); 77 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
76 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _)).Times(0); 78 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _, _)).Times(0);
77 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false)); 79 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false));
78 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _)).Times(0); 80 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _, _)).Times(0);
79 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number, 81 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number,
80 timestamp, retransmission, -1)); 82 timestamp, retransmission,
83 PacketInfo::kNotAProbe));
81 84
82 // Add a packet with incorrect ssrc and test it's dropped in the router. 85 // 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)); 86 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
84 EXPECT_CALL(rtp_1, SSRC()).Times(1).WillOnce(Return(kSsrc1)); 87 EXPECT_CALL(rtp_1, SSRC()).Times(1).WillOnce(Return(kSsrc1));
85 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true)); 88 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
86 EXPECT_CALL(rtp_2, SSRC()).Times(1).WillOnce(Return(kSsrc2)); 89 EXPECT_CALL(rtp_2, SSRC()).Times(1).WillOnce(Return(kSsrc2));
87 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _)).Times(0); 90 EXPECT_CALL(rtp_1, TimeToSendPacket(_, _, _, _, _)).Times(0);
88 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _)).Times(0); 91 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _, _)).Times(0);
89 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1 + kSsrc2, sequence_number, 92 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1 + kSsrc2, sequence_number,
90 timestamp, retransmission, -1)); 93 timestamp, retransmission,
94 PacketInfo::kNotAProbe));
91 95
92 packet_router_->RemoveRtpModule(&rtp_1); 96 packet_router_->RemoveRtpModule(&rtp_1);
93 97
94 // rtp_1 has been removed, try sending a packet on that ssrc and make sure 98 // 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. 99 // it is dropped as expected by not expecting any calls to rtp_1.
96 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true)); 100 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
97 EXPECT_CALL(rtp_2, SSRC()).Times(1).WillOnce(Return(kSsrc2)); 101 EXPECT_CALL(rtp_2, SSRC()).Times(1).WillOnce(Return(kSsrc2));
98 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _)).Times(0); 102 EXPECT_CALL(rtp_2, TimeToSendPacket(_, _, _, _, _)).Times(0);
99 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number, 103 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc1, sequence_number,
100 timestamp, retransmission, -1)); 104 timestamp, retransmission,
105 PacketInfo::kNotAProbe));
101 106
102 packet_router_->RemoveRtpModule(&rtp_2); 107 packet_router_->RemoveRtpModule(&rtp_2);
103 } 108 }
104 109
105 TEST_F(PacketRouterTest, TimeToSendPadding) { 110 TEST_F(PacketRouterTest, TimeToSendPadding) {
106 const uint16_t kSsrc1 = 1234; 111 const uint16_t kSsrc1 = 1234;
107 const uint16_t kSsrc2 = 4567; 112 const uint16_t kSsrc2 = 4567;
108 113
109 MockRtpRtcp rtp_1; 114 MockRtpRtcp rtp_1;
110 EXPECT_CALL(rtp_1, SSRC()).WillRepeatedly(Return(kSsrc1)); 115 EXPECT_CALL(rtp_1, SSRC()).WillRepeatedly(Return(kSsrc1));
111 MockRtpRtcp rtp_2; 116 MockRtpRtcp rtp_2;
112 EXPECT_CALL(rtp_2, SSRC()).WillRepeatedly(Return(kSsrc2)); 117 EXPECT_CALL(rtp_2, SSRC()).WillRepeatedly(Return(kSsrc2));
113 packet_router_->AddRtpModule(&rtp_1); 118 packet_router_->AddRtpModule(&rtp_1);
114 packet_router_->AddRtpModule(&rtp_2); 119 packet_router_->AddRtpModule(&rtp_2);
115 120
116 // Default configuration, sending padding on all modules sending media, 121 // Default configuration, sending padding on all modules sending media,
117 // ordered by SSRC. 122 // ordered by SSRC.
118 const size_t requested_padding_bytes = 1000; 123 const size_t requested_padding_bytes = 1000;
119 const size_t sent_padding_bytes = 890; 124 const size_t sent_padding_bytes = 890;
120 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true)); 125 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(true));
121 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes)) 126 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes, _))
122 .Times(1) 127 .Times(1)
123 .WillOnce(Return(sent_padding_bytes)); 128 .WillOnce(Return(sent_padding_bytes));
124 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true)); 129 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
125 EXPECT_CALL(rtp_2, 130 EXPECT_CALL(
126 TimeToSendPadding(requested_padding_bytes - sent_padding_bytes)) 131 rtp_2, TimeToSendPadding(requested_padding_bytes - sent_padding_bytes, _))
127 .Times(1) 132 .Times(1)
128 .WillOnce(Return(requested_padding_bytes - sent_padding_bytes)); 133 .WillOnce(Return(requested_padding_bytes - sent_padding_bytes));
129 EXPECT_EQ(requested_padding_bytes, 134 EXPECT_EQ(requested_padding_bytes,
130 packet_router_->TimeToSendPadding(requested_padding_bytes)); 135 packet_router_->TimeToSendPadding(requested_padding_bytes,
136 PacketInfo::kNotAProbe));
131 137
132 // Let only the second module be sending and verify the padding request is 138 // Let only the second module be sending and verify the padding request is
133 // routed there. 139 // routed there.
134 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false)); 140 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
135 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes)).Times(0); 141 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes, _)).Times(0);
136 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true)); 142 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
137 EXPECT_CALL(rtp_2, TimeToSendPadding(_)) 143 EXPECT_CALL(rtp_2, TimeToSendPadding(_, _))
138 .Times(1) 144 .Times(1)
139 .WillOnce(Return(sent_padding_bytes)); 145 .WillOnce(Return(sent_padding_bytes));
140 EXPECT_EQ(sent_padding_bytes, 146 EXPECT_EQ(sent_padding_bytes,
141 packet_router_->TimeToSendPadding(requested_padding_bytes)); 147 packet_router_->TimeToSendPadding(requested_padding_bytes,
148 PacketInfo::kNotAProbe));
142 149
143 // No sending module at all. 150 // No sending module at all.
144 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false)); 151 EXPECT_CALL(rtp_1, SendingMedia()).Times(1).WillOnce(Return(false));
145 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes)).Times(0); 152 EXPECT_CALL(rtp_1, TimeToSendPadding(requested_padding_bytes, _)).Times(0);
146 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false)); 153 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(false));
147 EXPECT_CALL(rtp_2, TimeToSendPadding(_)).Times(0); 154 EXPECT_CALL(rtp_2, TimeToSendPadding(_, _)).Times(0);
148 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes)); 155 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes,
156 PacketInfo::kNotAProbe));
149 157
150 packet_router_->RemoveRtpModule(&rtp_1); 158 packet_router_->RemoveRtpModule(&rtp_1);
151 159
152 // rtp_1 has been removed, try sending padding and make sure rtp_1 isn't asked 160 // 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. 161 // to send by not expecting any calls. Instead verify rtp_2 is called.
154 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true)); 162 EXPECT_CALL(rtp_2, SendingMedia()).Times(1).WillOnce(Return(true));
155 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes)).Times(1); 163 EXPECT_CALL(rtp_2, TimeToSendPadding(requested_padding_bytes, _)).Times(1);
156 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes)); 164 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(requested_padding_bytes,
165 PacketInfo::kNotAProbe));
157 166
158 packet_router_->RemoveRtpModule(&rtp_2); 167 packet_router_->RemoveRtpModule(&rtp_2);
159 } 168 }
160 169
161 TEST_F(PacketRouterTest, SenderOnlyFunctionsRespectSendingMedia) { 170 TEST_F(PacketRouterTest, SenderOnlyFunctionsRespectSendingMedia) {
162 MockRtpRtcp rtp; 171 MockRtpRtcp rtp;
163 packet_router_->AddRtpModule(&rtp); 172 packet_router_->AddRtpModule(&rtp);
164 static const uint16_t kSsrc = 1234; 173 static const uint16_t kSsrc = 1234;
165 EXPECT_CALL(rtp, SSRC()).WillRepeatedly(Return(kSsrc)); 174 EXPECT_CALL(rtp, SSRC()).WillRepeatedly(Return(kSsrc));
166 EXPECT_CALL(rtp, SendingMedia()).WillRepeatedly(Return(false)); 175 EXPECT_CALL(rtp, SendingMedia()).WillRepeatedly(Return(false));
167 176
168 // Verify that TimeToSendPacket does not end up in a receiver. 177 // Verify that TimeToSendPacket does not end up in a receiver.
169 EXPECT_CALL(rtp, TimeToSendPacket(_, _, _, _)).Times(0); 178 EXPECT_CALL(rtp, TimeToSendPacket(_, _, _, _, _)).Times(0);
170 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc, 1, 1, false, -1)); 179 EXPECT_TRUE(packet_router_->TimeToSendPacket(kSsrc, 1, 1, false,
180 PacketInfo::kNotAProbe));
171 // Verify that TimeToSendPadding does not end up in a receiver. 181 // Verify that TimeToSendPadding does not end up in a receiver.
172 EXPECT_CALL(rtp, TimeToSendPadding(_)).Times(0); 182 EXPECT_CALL(rtp, TimeToSendPadding(_, _)).Times(0);
173 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(200)); 183 EXPECT_EQ(0u, packet_router_->TimeToSendPadding(200, PacketInfo::kNotAProbe));
174 184
175 packet_router_->RemoveRtpModule(&rtp); 185 packet_router_->RemoveRtpModule(&rtp);
176 } 186 }
177 187
178 TEST_F(PacketRouterTest, AllocateSequenceNumbers) { 188 TEST_F(PacketRouterTest, AllocateSequenceNumbers) {
179 const uint16_t kStartSeq = 0xFFF0; 189 const uint16_t kStartSeq = 0xFFF0;
180 const size_t kNumPackets = 32; 190 const size_t kNumPackets = 32;
181 191
182 packet_router_->SetTransportWideSequenceNumber(kStartSeq - 1); 192 packet_router_->SetTransportWideSequenceNumber(kStartSeq - 1);
183 193
(...skipping 12 matching lines...) Expand all
196 206
197 rtcp::TransportFeedback feedback; 207 rtcp::TransportFeedback feedback;
198 EXPECT_CALL(rtp_1, SendFeedbackPacket(_)).Times(1); 208 EXPECT_CALL(rtp_1, SendFeedbackPacket(_)).Times(1);
199 packet_router_->SendFeedback(&feedback); 209 packet_router_->SendFeedback(&feedback);
200 packet_router_->RemoveRtpModule(&rtp_1); 210 packet_router_->RemoveRtpModule(&rtp_1);
201 EXPECT_CALL(rtp_2, SendFeedbackPacket(_)).Times(1); 211 EXPECT_CALL(rtp_2, SendFeedbackPacket(_)).Times(1);
202 packet_router_->SendFeedback(&feedback); 212 packet_router_->SendFeedback(&feedback);
203 packet_router_->RemoveRtpModule(&rtp_2); 213 packet_router_->RemoveRtpModule(&rtp_2);
204 } 214 }
205 } // namespace webrtc 215 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698