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 |
(...skipping 13 matching lines...) Expand all Loading... |
24 prober.CreateProbeCluster(900000, 6); | 24 prober.CreateProbeCluster(900000, 6); |
25 prober.CreateProbeCluster(1800000, 5); | 25 prober.CreateProbeCluster(1800000, 5); |
26 EXPECT_FALSE(prober.IsProbing()); | 26 EXPECT_FALSE(prober.IsProbing()); |
27 | 27 |
28 prober.OnIncomingPacket(1000); | 28 prober.OnIncomingPacket(1000); |
29 EXPECT_TRUE(prober.IsProbing()); | 29 EXPECT_TRUE(prober.IsProbing()); |
30 EXPECT_EQ(0, prober.CurrentClusterId()); | 30 EXPECT_EQ(0, prober.CurrentClusterId()); |
31 | 31 |
32 // First packet should probe as soon as possible. | 32 // First packet should probe as soon as possible. |
33 EXPECT_EQ(0, prober.TimeUntilNextProbe(now_ms)); | 33 EXPECT_EQ(0, prober.TimeUntilNextProbe(now_ms)); |
34 prober.PacketSent(now_ms, 1000); | 34 prober.ProbeSent(now_ms, 1000); |
35 | 35 |
36 for (int i = 0; i < 5; ++i) { | 36 for (int i = 0; i < 5; ++i) { |
37 EXPECT_EQ(8, prober.TimeUntilNextProbe(now_ms)); | 37 EXPECT_EQ(8, prober.TimeUntilNextProbe(now_ms)); |
38 now_ms += 4; | 38 now_ms += 4; |
39 EXPECT_EQ(4, prober.TimeUntilNextProbe(now_ms)); | 39 EXPECT_EQ(4, prober.TimeUntilNextProbe(now_ms)); |
40 now_ms += 4; | 40 now_ms += 4; |
41 EXPECT_EQ(0, prober.TimeUntilNextProbe(now_ms)); | 41 EXPECT_EQ(0, prober.TimeUntilNextProbe(now_ms)); |
42 EXPECT_EQ(0, prober.CurrentClusterId()); | 42 EXPECT_EQ(0, prober.CurrentClusterId()); |
43 prober.PacketSent(now_ms, 1000); | 43 prober.ProbeSent(now_ms, 1000); |
44 } | 44 } |
45 for (int i = 0; i < 5; ++i) { | 45 for (int i = 0; i < 5; ++i) { |
46 EXPECT_EQ(4, prober.TimeUntilNextProbe(now_ms)); | 46 EXPECT_EQ(4, prober.TimeUntilNextProbe(now_ms)); |
47 now_ms += 4; | 47 now_ms += 4; |
48 EXPECT_EQ(0, prober.TimeUntilNextProbe(now_ms)); | 48 EXPECT_EQ(0, prober.TimeUntilNextProbe(now_ms)); |
49 EXPECT_EQ(1, prober.CurrentClusterId()); | 49 EXPECT_EQ(1, prober.CurrentClusterId()); |
50 prober.PacketSent(now_ms, 1000); | 50 prober.ProbeSent(now_ms, 1000); |
51 } | 51 } |
52 | 52 |
53 EXPECT_EQ(-1, prober.TimeUntilNextProbe(now_ms)); | 53 EXPECT_EQ(-1, prober.TimeUntilNextProbe(now_ms)); |
54 EXPECT_FALSE(prober.IsProbing()); | 54 EXPECT_FALSE(prober.IsProbing()); |
55 } | 55 } |
56 | 56 |
57 TEST(BitrateProberTest, DoesntProbeWithoutRecentPackets) { | 57 TEST(BitrateProberTest, DoesntProbeWithoutRecentPackets) { |
58 BitrateProber prober; | 58 BitrateProber prober; |
59 EXPECT_FALSE(prober.IsProbing()); | 59 EXPECT_FALSE(prober.IsProbing()); |
60 int64_t now_ms = 0; | 60 int64_t now_ms = 0; |
61 EXPECT_EQ(-1, prober.TimeUntilNextProbe(now_ms)); | 61 EXPECT_EQ(-1, prober.TimeUntilNextProbe(now_ms)); |
62 | 62 |
63 prober.CreateProbeCluster(900000, 6); | 63 prober.CreateProbeCluster(900000, 6); |
64 EXPECT_FALSE(prober.IsProbing()); | 64 EXPECT_FALSE(prober.IsProbing()); |
65 | 65 |
66 prober.OnIncomingPacket(1000); | 66 prober.OnIncomingPacket(1000); |
67 EXPECT_TRUE(prober.IsProbing()); | 67 EXPECT_TRUE(prober.IsProbing()); |
68 EXPECT_EQ(0, prober.TimeUntilNextProbe(now_ms)); | 68 EXPECT_EQ(0, prober.TimeUntilNextProbe(now_ms)); |
69 prober.PacketSent(now_ms, 1000); | 69 prober.ProbeSent(now_ms, 1000); |
70 // Let time pass, no large enough packets put into prober. | 70 // Let time pass, no large enough packets put into prober. |
71 now_ms += 6000; | 71 now_ms += 6000; |
72 EXPECT_EQ(-1, prober.TimeUntilNextProbe(now_ms)); | 72 EXPECT_EQ(-1, prober.TimeUntilNextProbe(now_ms)); |
73 // Insert a small packet, not a candidate for probing. | 73 // Insert a small packet, not a candidate for probing. |
74 prober.OnIncomingPacket(100); | 74 prober.OnIncomingPacket(100); |
75 prober.PacketSent(now_ms, 100); | 75 EXPECT_FALSE(prober.IsProbing()); |
76 EXPECT_EQ(-1, prober.TimeUntilNextProbe(now_ms)); | 76 EXPECT_EQ(-1, prober.TimeUntilNextProbe(now_ms)); |
77 // Insert a large-enough packet after downtime while probing should reset to | 77 // Insert a large-enough packet after downtime while probing should reset to |
78 // perform a new probe since the requested one didn't finish. | 78 // perform a new probe since the requested one didn't finish. |
79 prober.OnIncomingPacket(1000); | 79 prober.OnIncomingPacket(1000); |
80 EXPECT_EQ(0, prober.TimeUntilNextProbe(now_ms)); | 80 EXPECT_EQ(0, prober.TimeUntilNextProbe(now_ms)); |
81 prober.PacketSent(now_ms, 1000); | 81 prober.ProbeSent(now_ms, 1000); |
82 // Next packet should be part of new probe and be sent with non-zero delay. | 82 // Next packet should be part of new probe and be sent with non-zero delay. |
83 prober.OnIncomingPacket(1000); | 83 prober.OnIncomingPacket(1000); |
84 EXPECT_GT(prober.TimeUntilNextProbe(now_ms), 0); | 84 EXPECT_GT(prober.TimeUntilNextProbe(now_ms), 0); |
85 } | 85 } |
86 | 86 |
87 TEST(BitrateProberTest, DoesntInitializeProbingForSmallPackets) { | 87 TEST(BitrateProberTest, DoesntInitializeProbingForSmallPackets) { |
88 BitrateProber prober; | 88 BitrateProber prober; |
89 prober.SetEnabled(true); | 89 prober.SetEnabled(true); |
90 EXPECT_FALSE(prober.IsProbing()); | 90 EXPECT_FALSE(prober.IsProbing()); |
91 | 91 |
92 prober.OnIncomingPacket(100); | 92 prober.OnIncomingPacket(100); |
93 EXPECT_FALSE(prober.IsProbing()); | 93 EXPECT_FALSE(prober.IsProbing()); |
94 } | 94 } |
95 | 95 |
96 } // namespace webrtc | 96 } // namespace webrtc |
OLD | NEW |