1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "base/logging.h"
6 #include "base/memory/scoped_ptr.h"
7 #include "net/quic/congestion_control/leaky_bucket.h"
8 #include "net/quic/test_tools/mock_clock.h"
9 #include "testing/gtest/include/gtest/gtest.h"
14 class LeakyBucketTest
: public ::testing::Test
{
16 virtual void SetUp() {
17 leaky_bucket_
.reset(new LeakyBucket(QuicBandwidth::Zero()));
20 scoped_ptr
<LeakyBucket
> leaky_bucket_
;
23 TEST_F(LeakyBucketTest
, Basic
) {
24 QuicBandwidth draining_rate
= QuicBandwidth::FromBytesPerSecond(200000);
25 leaky_bucket_
->SetDrainingRate(clock_
.Now(), draining_rate
);
26 leaky_bucket_
->Add(clock_
.Now(), 2000);
27 EXPECT_EQ(2000u, leaky_bucket_
->BytesPending(clock_
.Now()));
28 EXPECT_EQ(QuicTime::Delta::FromMilliseconds(10),
29 leaky_bucket_
->TimeRemaining(clock_
.Now()));
30 clock_
.AdvanceTime(QuicTime::Delta::FromMilliseconds(5));
31 EXPECT_EQ(1000u, leaky_bucket_
->BytesPending(clock_
.Now()));
32 EXPECT_EQ(QuicTime::Delta::FromMilliseconds(5),
33 leaky_bucket_
->TimeRemaining(clock_
.Now()));
34 clock_
.AdvanceTime(QuicTime::Delta::FromMilliseconds(5));
35 EXPECT_EQ(0u, leaky_bucket_
->BytesPending(clock_
.Now()));
36 EXPECT_TRUE(leaky_bucket_
->TimeRemaining(clock_
.Now()).IsZero());
37 clock_
.AdvanceTime(QuicTime::Delta::FromMilliseconds(5));
38 EXPECT_EQ(0u, leaky_bucket_
->BytesPending(clock_
.Now()));
39 EXPECT_TRUE(leaky_bucket_
->TimeRemaining(clock_
.Now()).IsZero());
40 leaky_bucket_
->Add(clock_
.Now(), 2000);
41 clock_
.AdvanceTime(QuicTime::Delta::FromMilliseconds(11));
42 EXPECT_EQ(0u, leaky_bucket_
->BytesPending(clock_
.Now()));
43 EXPECT_TRUE(leaky_bucket_
->TimeRemaining(clock_
.Now()).IsZero());
44 leaky_bucket_
->Add(clock_
.Now(), 2000);
45 clock_
.AdvanceTime(QuicTime::Delta::FromMilliseconds(5));
46 leaky_bucket_
->Add(clock_
.Now(), 2000);
47 clock_
.AdvanceTime(QuicTime::Delta::FromMilliseconds(5));
48 EXPECT_EQ(2000u, leaky_bucket_
->BytesPending(clock_
.Now()));
49 EXPECT_EQ(QuicTime::Delta::FromMilliseconds(10),
50 leaky_bucket_
->TimeRemaining(clock_
.Now()));
51 clock_
.AdvanceTime(QuicTime::Delta::FromMilliseconds(10));
52 EXPECT_EQ(0u, leaky_bucket_
->BytesPending(clock_
.Now()));
53 EXPECT_TRUE(leaky_bucket_
->TimeRemaining(clock_
.Now()).IsZero());
56 TEST_F(LeakyBucketTest
, ChangeDrainRate
) {
57 QuicBandwidth draining_rate
= QuicBandwidth::FromBytesPerSecond(200000);
58 leaky_bucket_
->SetDrainingRate(clock_
.Now(), draining_rate
);
59 leaky_bucket_
->Add(clock_
.Now(), 2000);
60 EXPECT_EQ(2000u, leaky_bucket_
->BytesPending(clock_
.Now()));
61 EXPECT_EQ(QuicTime::Delta::FromMilliseconds(10),
62 leaky_bucket_
->TimeRemaining(clock_
.Now()));
63 clock_
.AdvanceTime(QuicTime::Delta::FromMilliseconds(5));
64 EXPECT_EQ(1000u, leaky_bucket_
->BytesPending(clock_
.Now()));
65 EXPECT_EQ(QuicTime::Delta::FromMilliseconds(5),
66 leaky_bucket_
->TimeRemaining(clock_
.Now()));
67 draining_rate
= draining_rate
.Scale(0.5f
); // Cut drain rate in half.
68 leaky_bucket_
->SetDrainingRate(clock_
.Now(), draining_rate
);
69 EXPECT_EQ(1000u, leaky_bucket_
->BytesPending(clock_
.Now()));
70 EXPECT_EQ(QuicTime::Delta::FromMilliseconds(10),
71 leaky_bucket_
->TimeRemaining(clock_
.Now()));