blob: 0cbab30bc139ed30fa18277d36bc29427911c9ba [file] [log] [blame]
andrew@webrtc.orgb015cbe2012-10-22 18:19:23 +00001/*
2 * Copyright (c) 2012 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
pbos@webrtc.orgd5d709e2013-05-27 12:41:33 +000011#include "testing/gtest/include/gtest/gtest.h"
sprang@webrtc.org7374da32013-12-03 10:31:59 +000012#include "webrtc/modules/remote_bitrate_estimator/rate_statistics.h"
andrew@webrtc.orgb015cbe2012-10-22 18:19:23 +000013
14namespace {
15
sprang@webrtc.org7374da32013-12-03 10:31:59 +000016using webrtc::RateStatistics;
andrew@webrtc.orgb015cbe2012-10-22 18:19:23 +000017
sprang@webrtc.org7374da32013-12-03 10:31:59 +000018class RateStatisticsTest : public ::testing::Test {
solenberg@webrtc.orge5117e72013-04-18 12:25:32 +000019 protected:
sprang@webrtc.org7374da32013-12-03 10:31:59 +000020 RateStatisticsTest() : stats_(500, 8000) {}
21 RateStatistics stats_;
andrew@webrtc.orgb015cbe2012-10-22 18:19:23 +000022};
23
sprang@webrtc.org7374da32013-12-03 10:31:59 +000024TEST_F(RateStatisticsTest, TestStrictMode) {
solenberg@webrtc.orge5117e72013-04-18 12:25:32 +000025 int64_t now_ms = 0;
26 // Should be initialized to 0.
sprang@webrtc.org7374da32013-12-03 10:31:59 +000027 EXPECT_EQ(0u, stats_.Rate(now_ms));
solenberg@webrtc.orge5117e72013-04-18 12:25:32 +000028 stats_.Update(1500, now_ms);
29 // Expecting 24 kbps given a 500 ms window with one 1500 bytes packet.
sprang@webrtc.org7374da32013-12-03 10:31:59 +000030 EXPECT_EQ(24000u, stats_.Rate(now_ms));
31 stats_.Reset();
solenberg@webrtc.orge5117e72013-04-18 12:25:32 +000032 // Expecting 0 after init.
sprang@webrtc.org7374da32013-12-03 10:31:59 +000033 EXPECT_EQ(0u, stats_.Rate(now_ms));
solenberg@webrtc.orge5117e72013-04-18 12:25:32 +000034 for (int i = 0; i < 100000; ++i) {
35 if (now_ms % 10 == 0) {
36 stats_.Update(1500, now_ms);
andrew@webrtc.orgb015cbe2012-10-22 18:19:23 +000037 }
solenberg@webrtc.orge5117e72013-04-18 12:25:32 +000038 // Approximately 1200 kbps expected. Not exact since when packets
39 // are removed we will jump 10 ms to the next packet.
40 if (now_ms > 0 && now_ms % 500 == 0) {
sprang@webrtc.org7374da32013-12-03 10:31:59 +000041 EXPECT_NEAR(1200000u, stats_.Rate(now_ms), 24000u);
solenberg@webrtc.orge5117e72013-04-18 12:25:32 +000042 }
43 now_ms += 1;
44 }
45 now_ms += 500;
46 // The window is 2 seconds. If nothing has been received for that time
47 // the estimate should be 0.
sprang@webrtc.org7374da32013-12-03 10:31:59 +000048 EXPECT_EQ(0u, stats_.Rate(now_ms));
andrew@webrtc.orgb015cbe2012-10-22 18:19:23 +000049}
mikhal@webrtc.org66fba2b2013-11-25 17:49:28 +000050
sprang@webrtc.org7374da32013-12-03 10:31:59 +000051TEST_F(RateStatisticsTest, IncreasingThenDecreasingBitrate) {
mikhal@webrtc.org66fba2b2013-11-25 17:49:28 +000052 int64_t now_ms = 0;
sprang@webrtc.org7374da32013-12-03 10:31:59 +000053 stats_.Reset();
mikhal@webrtc.org66fba2b2013-11-25 17:49:28 +000054 // Expecting 0 after init.
sprang@webrtc.org7374da32013-12-03 10:31:59 +000055 uint32_t bitrate = stats_.Rate(now_ms);
mikhal@webrtc.org66fba2b2013-11-25 17:49:28 +000056 EXPECT_EQ(0u, bitrate);
57 // 1000 bytes per millisecond until plateau is reached.
58 while (++now_ms < 10000) {
59 stats_.Update(1000, now_ms);
sprang@webrtc.org7374da32013-12-03 10:31:59 +000060 uint32_t new_bitrate = stats_.Rate(now_ms);
mikhal@webrtc.org66fba2b2013-11-25 17:49:28 +000061 if (new_bitrate != bitrate) {
62 // New bitrate must be higher than previous one.
63 EXPECT_GT(new_bitrate, bitrate);
64 } else {
65 // Plateau reached, 8000 kbps expected.
66 EXPECT_NEAR(8000000u, bitrate, 80000u);
67 break;
68 }
69 bitrate = new_bitrate;
70 }
71 // 1000 bytes per millisecond until 10-second mark, 8000 kbps expected.
72 while (++now_ms < 10000) {
73 stats_.Update(1000, now_ms);
sprang@webrtc.org7374da32013-12-03 10:31:59 +000074 bitrate = stats_.Rate(now_ms);
mikhal@webrtc.org66fba2b2013-11-25 17:49:28 +000075 EXPECT_NEAR(8000000u, bitrate, 80000u);
76 }
77 // Zero bytes per millisecond until 0 is reached.
78 while (++now_ms < 20000) {
79 stats_.Update(0, now_ms);
sprang@webrtc.org7374da32013-12-03 10:31:59 +000080 uint32_t new_bitrate = stats_.Rate(now_ms);
mikhal@webrtc.org66fba2b2013-11-25 17:49:28 +000081 if (new_bitrate != bitrate) {
82 // New bitrate must be lower than previous one.
83 EXPECT_LT(new_bitrate, bitrate);
84 } else {
85 // 0 kbps expected.
86 EXPECT_EQ(0u, bitrate);
87 break;
88 }
89 bitrate = new_bitrate;
90 }
91 // Zero bytes per millisecond until 20-second mark, 0 kbps expected.
92 while (++now_ms < 20000) {
93 stats_.Update(0, now_ms);
sprang@webrtc.org7374da32013-12-03 10:31:59 +000094 EXPECT_EQ(0u, stats_.Rate(now_ms));
mikhal@webrtc.org66fba2b2013-11-25 17:49:28 +000095 }
96}
solenberg@webrtc.orge5117e72013-04-18 12:25:32 +000097} // namespace