OLD | NEW |
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 Loading... |
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 Loading... |
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 |
OLD | NEW |