| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2014 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 |
| 11 #include <algorithm> | 11 #include <algorithm> |
| 12 #include <vector> | 12 #include <vector> |
| 13 | 13 |
| 14 #include "testing/gtest/include/gtest/gtest.h" | 14 #include "testing/gtest/include/gtest/gtest.h" |
| 15 #include "webrtc/modules/bitrate_controller/send_side_bandwidth_estimation.h" | 15 #include "webrtc/modules/bitrate_controller/send_side_bandwidth_estimation.h" |
| 16 | 16 |
| 17 namespace webrtc { | 17 namespace webrtc { |
| 18 | 18 |
| 19 void TestProbing(bool use_delay_based) { | 19 void TestProbing(bool use_delay_based) { |
| 20 SendSideBandwidthEstimation bwe; | 20 SendSideBandwidthEstimation bwe(nullptr); |
| 21 bwe.SetMinMaxBitrate(100000, 1500000); | 21 bwe.SetMinMaxBitrate(100000, 1500000); |
| 22 bwe.SetSendBitrate(200000); | 22 bwe.SetSendBitrate(200000); |
| 23 | 23 |
| 24 const int kRembBps = 1000000; | 24 const int kRembBps = 1000000; |
| 25 const int kSecondRembBps = kRembBps + 500000; | 25 const int kSecondRembBps = kRembBps + 500000; |
| 26 int64_t now_ms = 0; | 26 int64_t now_ms = 0; |
| 27 | 27 |
| 28 bwe.UpdateReceiverBlock(0, 50, 1, now_ms); | 28 bwe.UpdateReceiverBlock(0, 50, 1, now_ms); |
| 29 | 29 |
| 30 // Initial REMB applies immediately. | 30 // Initial REMB applies immediately. |
| (...skipping 24 matching lines...) Expand all Loading... |
| 55 | 55 |
| 56 TEST(SendSideBweTest, InitialRembWithProbing) { | 56 TEST(SendSideBweTest, InitialRembWithProbing) { |
| 57 TestProbing(false); | 57 TestProbing(false); |
| 58 } | 58 } |
| 59 | 59 |
| 60 TEST(SendSideBweTest, InitialDelayBasedBweWithProbing) { | 60 TEST(SendSideBweTest, InitialDelayBasedBweWithProbing) { |
| 61 TestProbing(true); | 61 TestProbing(true); |
| 62 } | 62 } |
| 63 | 63 |
| 64 TEST(SendSideBweTest, DoesntReapplyBitrateDecreaseWithoutFollowingRemb) { | 64 TEST(SendSideBweTest, DoesntReapplyBitrateDecreaseWithoutFollowingRemb) { |
| 65 SendSideBandwidthEstimation bwe; | 65 SendSideBandwidthEstimation bwe(nullptr); |
| 66 static const int kMinBitrateBps = 100000; | 66 static const int kMinBitrateBps = 100000; |
| 67 static const int kInitialBitrateBps = 1000000; | 67 static const int kInitialBitrateBps = 1000000; |
| 68 bwe.SetMinMaxBitrate(kMinBitrateBps, 1500000); | 68 bwe.SetMinMaxBitrate(kMinBitrateBps, 1500000); |
| 69 bwe.SetSendBitrate(kInitialBitrateBps); | 69 bwe.SetSendBitrate(kInitialBitrateBps); |
| 70 | 70 |
| 71 static const uint8_t kFractionLoss = 128; | 71 static const uint8_t kFractionLoss = 128; |
| 72 static const int64_t kRttMs = 50; | 72 static const int64_t kRttMs = 50; |
| 73 | 73 |
| 74 int64_t now_ms = 0; | 74 int64_t now_ms = 0; |
| 75 int bitrate_bps; | 75 int bitrate_bps; |
| (...skipping 29 matching lines...) Expand all Loading... |
| 105 bwe.UpdateEstimate(now_ms); | 105 bwe.UpdateEstimate(now_ms); |
| 106 bwe.CurrentEstimate(&bitrate_bps, &fraction_loss, &rtt_ms); | 106 bwe.CurrentEstimate(&bitrate_bps, &fraction_loss, &rtt_ms); |
| 107 | 107 |
| 108 EXPECT_EQ(last_bitrate_bps, bitrate_bps); | 108 EXPECT_EQ(last_bitrate_bps, bitrate_bps); |
| 109 // The old loss rate should still be applied though. | 109 // The old loss rate should still be applied though. |
| 110 EXPECT_EQ(kFractionLoss, fraction_loss); | 110 EXPECT_EQ(kFractionLoss, fraction_loss); |
| 111 EXPECT_EQ(kRttMs, rtt_ms); | 111 EXPECT_EQ(kRttMs, rtt_ms); |
| 112 } | 112 } |
| 113 | 113 |
| 114 } // namespace webrtc | 114 } // namespace webrtc |
| OLD | NEW |