• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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.
4 
5 #include "extensions/browser/api/web_request/web_request_time_tracker.h"
6 
7 #include "testing/gmock/include/gmock/gmock.h"
8 #include "testing/gtest/include/gtest/gtest.h"
9 
10 namespace {
11 const base::TimeDelta kRequestDelta = base::TimeDelta::FromMilliseconds(100);
12 const base::TimeDelta kTinyDelay = base::TimeDelta::FromMilliseconds(1);
13 const base::TimeDelta kModerateDelay = base::TimeDelta::FromMilliseconds(25);
14 const base::TimeDelta kExcessiveDelay = base::TimeDelta::FromMilliseconds(75);
15 
16 class ExtensionWebRequestTimeTrackerDelegateMock
17     : public ExtensionWebRequestTimeTrackerDelegate {
18  public:
19   MOCK_METHOD4(NotifyExcessiveDelays,
20       void (void*, size_t, size_t, const std::set<std::string>&));
21   MOCK_METHOD4(NotifyModerateDelays,
22       void (void*, size_t, size_t, const std::set<std::string>&));
23 };
24 
25 }  // namespace
26 
27 //class ExtensionWebRequestTimeTrackerTest : public testing::Test {};
28 
TEST(ExtensionWebRequestTimeTrackerTest,Basic)29 TEST(ExtensionWebRequestTimeTrackerTest, Basic) {
30   ExtensionWebRequestTimeTracker tracker;
31   base::Time start;
32   void* profile = NULL;
33 
34   tracker.LogRequestStartTime(42, start, GURL(), profile);
35   EXPECT_EQ(1u, tracker.request_time_logs_.size());
36   ASSERT_EQ(1u, tracker.request_ids_.size());
37   EXPECT_EQ(42, tracker.request_ids_.front());
38   tracker.LogRequestEndTime(42, start + kRequestDelta);
39   EXPECT_EQ(1u, tracker.request_time_logs_.size());
40   EXPECT_EQ(0u, tracker.moderate_delays_.size());
41   EXPECT_EQ(0u, tracker.excessive_delays_.size());
42 }
43 
TEST(ExtensionWebRequestTimeTrackerTest,CancelOrRedirect)44 TEST(ExtensionWebRequestTimeTrackerTest, CancelOrRedirect) {
45   ExtensionWebRequestTimeTracker tracker;
46   base::Time start;
47   void* profile = NULL;
48 
49   tracker.LogRequestStartTime(1, start, GURL(), profile);
50   EXPECT_EQ(1u, tracker.request_time_logs_.size());
51   tracker.SetRequestCanceled(1);
52   tracker.LogRequestEndTime(1, start + kRequestDelta);
53   EXPECT_EQ(0u, tracker.request_time_logs_.size());
54 
55   tracker.LogRequestStartTime(2, start, GURL(), profile);
56   EXPECT_EQ(1u, tracker.request_time_logs_.size());
57   tracker.SetRequestRedirected(2);
58   tracker.LogRequestEndTime(2, start + kRequestDelta);
59   EXPECT_EQ(0u, tracker.request_time_logs_.size());
60 }
61 
TEST(ExtensionWebRequestTimeTrackerTest,Delays)62 TEST(ExtensionWebRequestTimeTrackerTest, Delays) {
63   ExtensionWebRequestTimeTracker tracker;
64   base::Time start;
65   std::string extension1_id("1");
66   std::string extension2_id("2");
67   void* profile = NULL;
68 
69   // Start 3 requests with different amounts of delay from 2 extensions.
70   tracker.LogRequestStartTime(1, start, GURL(), profile);
71   tracker.LogRequestStartTime(2, start, GURL(), profile);
72   tracker.LogRequestStartTime(3, start, GURL(), profile);
73   tracker.IncrementExtensionBlockTime(extension1_id, 1, kTinyDelay);
74   tracker.IncrementExtensionBlockTime(extension1_id, 2, kTinyDelay);
75   tracker.IncrementExtensionBlockTime(extension1_id, 3, kTinyDelay);
76   tracker.IncrementExtensionBlockTime(extension2_id, 2, kModerateDelay);
77   tracker.IncrementExtensionBlockTime(extension2_id, 3, kExcessiveDelay);
78   tracker.IncrementTotalBlockTime(1, kTinyDelay);
79   tracker.IncrementTotalBlockTime(2, kModerateDelay);
80   tracker.IncrementTotalBlockTime(3, kExcessiveDelay);
81   tracker.LogRequestEndTime(1, start + kRequestDelta);
82   tracker.LogRequestEndTime(2, start + kRequestDelta);
83   tracker.LogRequestEndTime(3, start + kRequestDelta);
84   EXPECT_EQ(3u, tracker.request_time_logs_.size());
85   EXPECT_EQ(1u, tracker.moderate_delays_.size());
86   EXPECT_EQ(1u, tracker.moderate_delays_.count(2));
87   EXPECT_EQ(1u, tracker.excessive_delays_.size());
88   EXPECT_EQ(1u, tracker.excessive_delays_.count(3));
89 
90   // Now issue a bunch more requests and ensure that the old delays are
91   // forgotten.
92   for (int64 i = 4; i < 500; ++i) {
93     tracker.LogRequestStartTime(i, start, GURL(), profile);
94     tracker.LogRequestEndTime(i, start + kRequestDelta);
95   }
96   EXPECT_EQ(0u, tracker.moderate_delays_.size());
97   EXPECT_EQ(0u, tracker.excessive_delays_.size());
98 }
99 
TEST(ExtensionWebRequestTimeTrackerTest,Delegate)100 TEST(ExtensionWebRequestTimeTrackerTest, Delegate) {
101   using testing::Mock;
102 
103   ExtensionWebRequestTimeTrackerDelegateMock* delegate(
104       new ExtensionWebRequestTimeTrackerDelegateMock);
105   ExtensionWebRequestTimeTracker tracker;
106   tracker.SetDelegate(delegate);
107   base::Time start;
108   std::string extension1_id("1");
109   void* profile = NULL;
110   // Set of all extensions that blocked network requests.
111   std::set<std::string> extensions;
112   extensions.insert(extension1_id);
113 
114   const int num_moderate_delays = 51;
115   const int num_excessive_delays = 11;
116   int request_nr = 0;
117 
118   // Check that (only) the last moderate delay triggers the delegate callback.
119   for (int64 i = 0; i < num_moderate_delays; ++i) {
120     request_nr++;
121     if (i == num_moderate_delays-1) {
122       EXPECT_CALL(*delegate,
123                   NotifyModerateDelays(profile , i+1, request_nr, extensions));
124     }
125     tracker.LogRequestStartTime(request_nr, start, GURL(), profile);
126     tracker.IncrementExtensionBlockTime(extension1_id, request_nr,
127                                         kModerateDelay);
128     tracker.IncrementTotalBlockTime(request_nr, kModerateDelay);
129     tracker.LogRequestEndTime(request_nr, start + kRequestDelta);
130     Mock::VerifyAndClearExpectations(delegate);
131   }
132 
133   // Check that (only) the last excessive delay triggers the delegate callback.
134   for (int64 i = 0; i < num_excessive_delays; ++i) {
135     request_nr++;
136     if (i == num_excessive_delays-1) {
137       EXPECT_CALL(*delegate,
138                   NotifyExcessiveDelays(profile, i+1, request_nr, extensions));
139     }
140     tracker.LogRequestStartTime(request_nr, start, GURL(), profile);
141     tracker.IncrementExtensionBlockTime(extension1_id, request_nr,
142                                         kExcessiveDelay);
143     tracker.IncrementTotalBlockTime(request_nr, kExcessiveDelay);
144     tracker.LogRequestEndTime(request_nr, start + kRequestDelta);
145     Mock::VerifyAndClearExpectations(delegate);
146   }
147 }
148