Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(115)

Side by Side Diff: content/browser/renderer_host/resource_queue_unittest.cc

Issue 8205001: (Owner approval for) Delay network requests on startup if any webRequest ... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "base/memory/scoped_ptr.h" 5 #include "base/memory/scoped_ptr.h"
6 #include "base/message_loop.h" 6 #include "base/message_loop.h"
7 #include "content/browser/browser_thread.h" 7 #include "content/browser/browser_thread.h"
8 #include "content/browser/mock_resource_context.h" 8 #include "content/browser/mock_resource_context.h"
9 #include "content/browser/renderer_host/dummy_resource_handler.h" 9 #include "content/browser/renderer_host/dummy_resource_handler.h"
10 #include "content/browser/renderer_host/global_request_id.h" 10 #include "content/browser/renderer_host/global_request_id.h"
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after
70 } 70 }
71 71
72 virtual void Initialize(ResourceQueue* resource_queue) { 72 virtual void Initialize(ResourceQueue* resource_queue) {
73 resource_queue_ = resource_queue; 73 resource_queue_ = resource_queue;
74 } 74 }
75 75
76 virtual bool ShouldDelayRequest( 76 virtual bool ShouldDelayRequest(
77 net::URLRequest* request, 77 net::URLRequest* request,
78 const ResourceDispatcherHostRequestInfo& request_info, 78 const ResourceDispatcherHostRequestInfo& request_info,
79 const GlobalRequestID& request_id) { 79 const GlobalRequestID& request_id) {
80 delayed_requests_.push_back(request_id);
81 return true; 80 return true;
82 } 81 }
83 82
84 virtual void WillShutdownResourceQueue() { 83 virtual void WillShutdownResourceQueue() {
85 resource_queue_ = NULL; 84 resource_queue_ = NULL;
86 } 85 }
87 86
88 void StartDelayedRequests() { 87 void StartDelayedRequests() {
89 if (!resource_queue_) 88 if (resource_queue_)
90 return; 89 resource_queue_->StartDelayedRequests(this);
91
92 for (RequestList::iterator i = delayed_requests_.begin();
93 i != delayed_requests_.end(); ++i) {
94 resource_queue_->StartDelayedRequest(this, *i);
95 }
96 } 90 }
97 91
98 private: 92 private:
99 typedef std::vector<GlobalRequestID> RequestList; 93 typedef std::vector<GlobalRequestID> RequestList;
100 94
101 ResourceQueue* resource_queue_; 95 ResourceQueue* resource_queue_;
102 96
103 RequestList delayed_requests_;
104
105 DISALLOW_COPY_AND_ASSIGN(AlwaysDelayingDelegate); 97 DISALLOW_COPY_AND_ASSIGN(AlwaysDelayingDelegate);
106 }; 98 };
107 99
108 class ResourceQueueTest : public testing::Test, 100 class ResourceQueueTest : public testing::Test,
109 public net::URLRequest::Delegate { 101 public net::URLRequest::Delegate {
110 public: 102 public:
111 ResourceQueueTest() 103 ResourceQueueTest()
112 : response_started_count_(0), 104 : response_started_count_(0),
113 message_loop_(MessageLoop::TYPE_IO), 105 message_loop_(MessageLoop::TYPE_IO),
114 ui_thread_(BrowserThread::UI, &message_loop_), 106 ui_thread_(BrowserThread::UI, &message_loop_),
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after
209 queue.AddRequest(&request, *request_info.get()); 201 queue.AddRequest(&request, *request_info.get());
210 MessageLoop::current()->RunAllPending(); 202 MessageLoop::current()->RunAllPending();
211 EXPECT_EQ(0, response_started_count_); 203 EXPECT_EQ(0, response_started_count_);
212 always_delaying_delegate.StartDelayedRequests(); 204 always_delaying_delegate.StartDelayedRequests();
213 MessageLoop::current()->RunAllPending(); 205 MessageLoop::current()->RunAllPending();
214 EXPECT_EQ(1, response_started_count_); 206 EXPECT_EQ(1, response_started_count_);
215 207
216 queue.Shutdown(); 208 queue.Shutdown();
217 } 209 }
218 210
211 TEST_F(ResourceQueueTest, TwoDelayingDelegates) {
212 ResourceQueue queue;
213
214 AlwaysDelayingDelegate always_delaying_delegate1;
215 AlwaysDelayingDelegate always_delaying_delegate2;
216 InitializeQueue(
217 &queue, &always_delaying_delegate1, &always_delaying_delegate2);
218
219 net::URLRequest request(GURL(kTestUrl), this);
220 scoped_ptr<ResourceDispatcherHostRequestInfo> request_info(GetRequestInfo(0));
221 EXPECT_EQ(0, response_started_count_);
222 queue.AddRequest(&request, *request_info.get());
223 MessageLoop::current()->RunAllPending();
224 EXPECT_EQ(0, response_started_count_);
225
226 always_delaying_delegate1.StartDelayedRequests();
227 MessageLoop::current()->RunAllPending();
228 EXPECT_EQ(0, response_started_count_);
229
230 always_delaying_delegate2.StartDelayedRequests();
231 MessageLoop::current()->RunAllPending();
232 EXPECT_EQ(1, response_started_count_);
233
234 queue.Shutdown();
235 }
236
219 TEST_F(ResourceQueueTest, RemoveRequest) { 237 TEST_F(ResourceQueueTest, RemoveRequest) {
220 ResourceQueue queue; 238 ResourceQueue queue;
221 239
222 AlwaysDelayingDelegate delegate; 240 AlwaysDelayingDelegate delegate;
223 InitializeQueue(&queue, &delegate); 241 InitializeQueue(&queue, &delegate);
224 242
225 net::URLRequest request(GURL(kTestUrl), this); 243 net::URLRequest request(GURL(kTestUrl), this);
226 scoped_ptr<ResourceDispatcherHostRequestInfo> request_info(GetRequestInfo(0)); 244 scoped_ptr<ResourceDispatcherHostRequestInfo> request_info(GetRequestInfo(0));
227 GlobalRequestID request_id(request_info->child_id(), 245 GlobalRequestID request_id(request_info->child_id(),
228 request_info->request_id()); 246 request_info->request_id());
229 EXPECT_EQ(0, response_started_count_); 247 EXPECT_EQ(0, response_started_count_);
230 queue.AddRequest(&request, *request_info.get()); 248 queue.AddRequest(&request, *request_info.get());
231 MessageLoop::current()->RunAllPending(); 249 MessageLoop::current()->RunAllPending();
232 EXPECT_EQ(0, response_started_count_); 250 EXPECT_EQ(0, response_started_count_);
233 queue.RemoveRequest(request_id); 251 queue.RemoveRequest(request_id);
234 delegate.StartDelayedRequests(); 252 delegate.StartDelayedRequests();
235 MessageLoop::current()->RunAllPending(); 253 MessageLoop::current()->RunAllPending();
236 EXPECT_EQ(0, response_started_count_); 254 EXPECT_EQ(0, response_started_count_);
237 255
238 queue.Shutdown(); 256 queue.Shutdown();
239 257
240 MessageLoop::current()->RunAllPending(); 258 MessageLoop::current()->RunAllPending();
241 EXPECT_EQ(0, response_started_count_); 259 EXPECT_EQ(0, response_started_count_);
242 } 260 }
243 261
244 } // namespace 262 } // namespace
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698