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

Side by Side Diff: webrtc/modules/congestion_controller/delay_based_bwe_unittest.cc

Issue 2777333003: Enable trendline experiment and bayesian bitrate estimator experiment by default. (Closed)
Patch Set: Created 3 years, 8 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) 2016 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2016 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 114 matching lines...) Expand 10 before | Expand all | Expand 10 after
125 EXPECT_NE(interval_ms, default_interval_ms); 125 EXPECT_NE(interval_ms, default_interval_ms);
126 } 126 }
127 127
128 TEST_F(DelayBasedBweTest, InitialBehavior) { 128 TEST_F(DelayBasedBweTest, InitialBehavior) {
129 InitialBehaviorTestHelper(674840); 129 InitialBehaviorTestHelper(674840);
130 } 130 }
131 131
132 TEST_F(DelayBasedBweTest, RateIncreaseReordering) { 132 TEST_F(DelayBasedBweTest, RateIncreaseReordering) {
133 RateIncreaseReorderingTestHelper(674840); 133 RateIncreaseReorderingTestHelper(674840);
134 } 134 }
135
136 TEST_F(DelayBasedBweTest, RateIncreaseRtpTimestamps) { 135 TEST_F(DelayBasedBweTest, RateIncreaseRtpTimestamps) {
137 RateIncreaseRtpTimestampsTestHelper(1240); 136 RateIncreaseRtpTimestampsTestHelper(1240);
138 } 137 }
139 138
140 TEST_F(DelayBasedBweTest, CapacityDropOneStream) { 139 TEST_F(DelayBasedBweTest, CapacityDropOneStream) {
141 CapacityDropTestHelper(1, false, 567, 0); 140 CapacityDropTestHelper(1, false, 600, 0);
142 } 141 }
143 142
144 TEST_F(DelayBasedBweTest, CapacityDropPosOffsetChange) { 143 TEST_F(DelayBasedBweTest, CapacityDropPosOffsetChange) {
145 CapacityDropTestHelper(1, false, 200, 30000); 144 CapacityDropTestHelper(1, false, 767, 30000);
terelius 2017/03/28 12:18:21 Are you happy with the new values?
stefan-webrtc 2017/03/30 08:30:47 I think they are fine. They will change again once
146 } 145 }
147 146
148 TEST_F(DelayBasedBweTest, CapacityDropNegOffsetChange) { 147 TEST_F(DelayBasedBweTest, CapacityDropNegOffsetChange) {
149 CapacityDropTestHelper(1, false, 733, -30000); 148 CapacityDropTestHelper(1, false, 1400, -30000);
150 } 149 }
151 150
152 TEST_F(DelayBasedBweTest, CapacityDropOneStreamWrap) { 151 TEST_F(DelayBasedBweTest, CapacityDropOneStreamWrap) {
153 CapacityDropTestHelper(1, true, 567, 0); 152 CapacityDropTestHelper(1, true, 600, 0);
154 } 153 }
155
156 TEST_F(DelayBasedBweTest, TestTimestampGrouping) { 154 TEST_F(DelayBasedBweTest, TestTimestampGrouping) {
157 TestTimestampGroupingTestHelper(); 155 TestTimestampGroupingTestHelper();
158 } 156 }
159 157
160 TEST_F(DelayBasedBweTest, TestShortTimeoutAndWrap) { 158 TEST_F(DelayBasedBweTest, TestShortTimeoutAndWrap) {
161 // Simulate a client leaving and rejoining the call after 35 seconds. This 159 // Simulate a client leaving and rejoining the call after 35 seconds. This
162 // will make abs send time wrap, so if streams aren't timed out properly 160 // will make abs send time wrap, so if streams aren't timed out properly
163 // the next 30 seconds of packets will be out of order. 161 // the next 30 seconds of packets will be out of order.
164 TestWrappingHelper(35); 162 TestWrappingHelper(35);
165 } 163 }
166 164
167 TEST_F(DelayBasedBweTest, TestLongTimeoutAndWrap) { 165 TEST_F(DelayBasedBweTest, TestLongTimeoutAndWrap) {
168 // Simulate a client leaving and rejoining the call after some multiple of 166 // Simulate a client leaving and rejoining the call after some multiple of
169 // 64 seconds later. This will cause a zero difference in abs send times due 167 // 64 seconds later. This will cause a zero difference in abs send times due
170 // to the wrap, but a big difference in arrival time, if streams aren't 168 // to the wrap, but a big difference in arrival time, if streams aren't
171 // properly timed out. 169 // properly timed out.
172 TestWrappingHelper(10 * 64); 170 TestWrappingHelper(10 * 64);
173 } 171 }
174 172
175 class DelayBasedBweExperimentTest : public DelayBasedBweTest { 173 class DelayBasedBweExperimentTest : public DelayBasedBweTest {
terelius 2017/03/28 12:18:21 Shouldn't this be removed and ImprovedBitrateEstim
stefan-webrtc 2017/03/30 08:30:47 That ended up being a separate CL, but yes, both w
176 public: 174 public:
177 DelayBasedBweExperimentTest() 175 DelayBasedBweExperimentTest()
178 : override_field_trials_("WebRTC-ImprovedBitrateEstimate/Enabled/") { 176 : override_field_trials_("WebRTC-ImprovedBitrateEstimate/Enabled/") {
179 bitrate_estimator_.reset(new DelayBasedBwe(nullptr, &clock_)); 177 bitrate_estimator_.reset(new DelayBasedBwe(nullptr, &clock_));
180 } 178 }
181 179
182 private: 180 private:
183 test::ScopedFieldTrials override_field_trials_; 181 test::ScopedFieldTrials override_field_trials_;
184 }; 182 };
185 183
186 TEST_F(DelayBasedBweExperimentTest, RateIncreaseRtpTimestamps) { 184 TEST_F(DelayBasedBweExperimentTest, RateIncreaseRtpTimestamps) {
187 RateIncreaseRtpTimestampsTestHelper(1288); 185 RateIncreaseRtpTimestampsTestHelper(1288);
188 } 186 }
189 187
190 TEST_F(DelayBasedBweExperimentTest, CapacityDropOneStream) { 188 TEST_F(DelayBasedBweExperimentTest, CapacityDropOneStream) {
191 CapacityDropTestHelper(1, false, 333, 0); 189 CapacityDropTestHelper(1, false, 333, 0);
192 } 190 }
193 191
194 TEST_F(DelayBasedBweExperimentTest, CapacityDropPosOffsetChange) { 192 TEST_F(DelayBasedBweExperimentTest, CapacityDropPosOffsetChange) {
195 CapacityDropTestHelper(1, false, 300, 30000); 193 CapacityDropTestHelper(1, false, 867, 30000);
196 } 194 }
197 195
198 TEST_F(DelayBasedBweExperimentTest, CapacityDropNegOffsetChange) { 196 TEST_F(DelayBasedBweExperimentTest, CapacityDropNegOffsetChange) {
199 CapacityDropTestHelper(1, false, 300, -30000); 197 CapacityDropTestHelper(1, false, 867, -30000);
200 } 198 }
201 199
202 TEST_F(DelayBasedBweExperimentTest, CapacityDropOneStreamWrap) { 200 TEST_F(DelayBasedBweExperimentTest, CapacityDropOneStreamWrap) {
203 CapacityDropTestHelper(1, true, 333, 0); 201 CapacityDropTestHelper(1, true, 333, 0);
204 } 202 }
205 203
206 class DelayBasedBweTrendlineExperimentTest : public DelayBasedBweTest {
207 public:
208 DelayBasedBweTrendlineExperimentTest()
209 : override_field_trials_("WebRTC-BweTrendlineFilter/Enabled-15,0.9,4/") {
210 bitrate_estimator_.reset(new DelayBasedBwe(nullptr, &clock_));
211 }
212
213 private:
214 test::ScopedFieldTrials override_field_trials_;
215 };
216
217 TEST_F(DelayBasedBweTrendlineExperimentTest, RateIncreaseRtpTimestamps) {
218 RateIncreaseRtpTimestampsTestHelper(1240);
219 }
220
221 TEST_F(DelayBasedBweTrendlineExperimentTest, CapacityDropOneStream) {
222 CapacityDropTestHelper(1, false, 600, 0);
223 }
224
225 TEST_F(DelayBasedBweTrendlineExperimentTest, CapacityDropPosOffsetChange) {
226 CapacityDropTestHelper(1, false, 600, 30000);
227 }
228
229 TEST_F(DelayBasedBweTrendlineExperimentTest, CapacityDropNegOffsetChange) {
230 CapacityDropTestHelper(1, false, 1267, -30000);
231 }
232
233 TEST_F(DelayBasedBweTrendlineExperimentTest, CapacityDropOneStreamWrap) {
234 CapacityDropTestHelper(1, true, 600, 0);
235 }
236
237 class DelayBasedBweMedianSlopeExperimentTest : public DelayBasedBweTest { 204 class DelayBasedBweMedianSlopeExperimentTest : public DelayBasedBweTest {
238 public: 205 public:
239 DelayBasedBweMedianSlopeExperimentTest() 206 DelayBasedBweMedianSlopeExperimentTest()
240 : override_field_trials_("WebRTC-BweMedianSlopeFilter/Enabled-20,4/") { 207 : override_field_trials_("WebRTC-BweMedianSlopeFilter/Enabled-20,4/") {
241 bitrate_estimator_.reset(new DelayBasedBwe(nullptr, &clock_)); 208 bitrate_estimator_.reset(new DelayBasedBwe(nullptr, &clock_));
242 } 209 }
243 210
244 private: 211 private:
245 test::ScopedFieldTrials override_field_trials_; 212 test::ScopedFieldTrials override_field_trials_;
246 }; 213 };
(...skipping 12 matching lines...) Expand all
259 226
260 TEST_F(DelayBasedBweMedianSlopeExperimentTest, CapacityDropNegOffsetChange) { 227 TEST_F(DelayBasedBweMedianSlopeExperimentTest, CapacityDropNegOffsetChange) {
261 CapacityDropTestHelper(1, false, 1267, -30000); 228 CapacityDropTestHelper(1, false, 1267, -30000);
262 } 229 }
263 230
264 TEST_F(DelayBasedBweMedianSlopeExperimentTest, CapacityDropOneStreamWrap) { 231 TEST_F(DelayBasedBweMedianSlopeExperimentTest, CapacityDropOneStreamWrap) {
265 CapacityDropTestHelper(1, true, 600, 0); 232 CapacityDropTestHelper(1, true, 600, 0);
266 } 233 }
267 234
268 } // namespace webrtc 235 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698