| 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 |