| /* |
| * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| #include "testing/gtest/include/gtest/gtest.h" |
| #include "webrtc/modules/remote_bitrate_estimator/rate_statistics.h" |
| |
| namespace { |
| |
| using webrtc::RateStatistics; |
| |
| class RateStatisticsTest : public ::testing::Test { |
| protected: |
| RateStatisticsTest() : stats_(500, 8000) {} |
| RateStatistics stats_; |
| }; |
| |
| TEST_F(RateStatisticsTest, TestStrictMode) { |
| int64_t now_ms = 0; |
| // Should be initialized to 0. |
| EXPECT_EQ(0u, stats_.Rate(now_ms)); |
| stats_.Update(1500, now_ms); |
| // Expecting 24 kbps given a 500 ms window with one 1500 bytes packet. |
| EXPECT_EQ(24000u, stats_.Rate(now_ms)); |
| stats_.Reset(); |
| // Expecting 0 after init. |
| EXPECT_EQ(0u, stats_.Rate(now_ms)); |
| for (int i = 0; i < 100000; ++i) { |
| if (now_ms % 10 == 0) { |
| stats_.Update(1500, now_ms); |
| } |
| // Approximately 1200 kbps expected. Not exact since when packets |
| // are removed we will jump 10 ms to the next packet. |
| if (now_ms > 0 && now_ms % 500 == 0) { |
| EXPECT_NEAR(1200000u, stats_.Rate(now_ms), 24000u); |
| } |
| now_ms += 1; |
| } |
| now_ms += 500; |
| // The window is 2 seconds. If nothing has been received for that time |
| // the estimate should be 0. |
| EXPECT_EQ(0u, stats_.Rate(now_ms)); |
| } |
| |
| TEST_F(RateStatisticsTest, IncreasingThenDecreasingBitrate) { |
| int64_t now_ms = 0; |
| stats_.Reset(); |
| // Expecting 0 after init. |
| uint32_t bitrate = stats_.Rate(now_ms); |
| EXPECT_EQ(0u, bitrate); |
| // 1000 bytes per millisecond until plateau is reached. |
| while (++now_ms < 10000) { |
| stats_.Update(1000, now_ms); |
| uint32_t new_bitrate = stats_.Rate(now_ms); |
| if (new_bitrate != bitrate) { |
| // New bitrate must be higher than previous one. |
| EXPECT_GT(new_bitrate, bitrate); |
| } else { |
| // Plateau reached, 8000 kbps expected. |
| EXPECT_NEAR(8000000u, bitrate, 80000u); |
| break; |
| } |
| bitrate = new_bitrate; |
| } |
| // 1000 bytes per millisecond until 10-second mark, 8000 kbps expected. |
| while (++now_ms < 10000) { |
| stats_.Update(1000, now_ms); |
| bitrate = stats_.Rate(now_ms); |
| EXPECT_NEAR(8000000u, bitrate, 80000u); |
| } |
| // Zero bytes per millisecond until 0 is reached. |
| while (++now_ms < 20000) { |
| stats_.Update(0, now_ms); |
| uint32_t new_bitrate = stats_.Rate(now_ms); |
| if (new_bitrate != bitrate) { |
| // New bitrate must be lower than previous one. |
| EXPECT_LT(new_bitrate, bitrate); |
| } else { |
| // 0 kbps expected. |
| EXPECT_EQ(0u, bitrate); |
| break; |
| } |
| bitrate = new_bitrate; |
| } |
| // Zero bytes per millisecond until 20-second mark, 0 kbps expected. |
| while (++now_ms < 20000) { |
| stats_.Update(0, now_ms); |
| EXPECT_EQ(0u, stats_.Rate(now_ms)); |
| } |
| } |
| } // namespace |