| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 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 <string> | 5 #include <string> |
| 6 #include <vector> | 6 #include <vector> |
| 7 | 7 |
| 8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
| 9 #include "base/message_loop.h" | 9 #include "base/message_loop.h" |
| 10 #include "base/process.h" | 10 #include "base/process.h" |
| (...skipping 23 matching lines...) Expand all Loading... |
| 34 | 34 |
| 35 static const char kShmemSegmentName[] = "DeferredResourceLoaderTest"; | 35 static const char kShmemSegmentName[] = "DeferredResourceLoaderTest"; |
| 36 | 36 |
| 37 // Listens for request response data and stores it so that it can be compared | 37 // Listens for request response data and stores it so that it can be compared |
| 38 // to the reference data. | 38 // to the reference data. |
| 39 class TestRequestCallback : public ResourceLoaderBridge::Peer { | 39 class TestRequestCallback : public ResourceLoaderBridge::Peer { |
| 40 public: | 40 public: |
| 41 TestRequestCallback() : complete_(false) { | 41 TestRequestCallback() : complete_(false) { |
| 42 } | 42 } |
| 43 | 43 |
| 44 virtual void OnUploadProgress(uint64 position, uint64 size) { | 44 virtual void OnUploadProgress(uint64 position, uint64 size) OVERRIDE { |
| 45 } | 45 } |
| 46 | 46 |
| 47 virtual bool OnReceivedRedirect( | 47 virtual bool OnReceivedRedirect( |
| 48 const GURL& new_url, | 48 const GURL& new_url, |
| 49 const ResourceResponseInfo& info, | 49 const ResourceResponseInfo& info, |
| 50 bool* has_new_first_party_for_cookies, | 50 bool* has_new_first_party_for_cookies, |
| 51 GURL* new_first_party_for_cookies) { | 51 GURL* new_first_party_for_cookies) OVERRIDE { |
| 52 *has_new_first_party_for_cookies = false; | 52 *has_new_first_party_for_cookies = false; |
| 53 return true; | 53 return true; |
| 54 } | 54 } |
| 55 | 55 |
| 56 virtual void OnReceivedResponse(const ResourceResponseInfo& info) { | 56 virtual void OnReceivedResponse(const ResourceResponseInfo& info) OVERRIDE { |
| 57 } | 57 } |
| 58 | 58 |
| 59 virtual void OnDownloadedData(int len) { | 59 virtual void OnDownloadedData(int len) OVERRIDE { |
| 60 } | 60 } |
| 61 | 61 |
| 62 virtual void OnReceivedData(const char* data, | 62 virtual void OnReceivedData(const char* data, |
| 63 int data_length, | 63 int data_length, |
| 64 int encoded_data_length) { | 64 int encoded_data_length) OVERRIDE { |
| 65 EXPECT_FALSE(complete_); | 65 EXPECT_FALSE(complete_); |
| 66 data_.append(data, data_length); | 66 data_.append(data, data_length); |
| 67 total_encoded_data_length_ += encoded_data_length; | 67 total_encoded_data_length_ += encoded_data_length; |
| 68 } | 68 } |
| 69 | 69 |
| 70 virtual void OnCompletedRequest(const net::URLRequestStatus& status, | 70 virtual void OnCompletedRequest( |
| 71 const std::string& security_info, | 71 const net::URLRequestStatus& status, |
| 72 const base::TimeTicks& completion_time) { | 72 const std::string& security_info, |
| 73 const base::TimeTicks& completion_time) OVERRIDE { |
| 73 EXPECT_FALSE(complete_); | 74 EXPECT_FALSE(complete_); |
| 74 complete_ = true; | 75 complete_ = true; |
| 75 } | 76 } |
| 76 | 77 |
| 77 bool complete() const { | 78 bool complete() const { |
| 78 return complete_; | 79 return complete_; |
| 79 } | 80 } |
| 80 const std::string& data() const { | 81 const std::string& data() const { |
| 81 return data_; | 82 return data_; |
| 82 } | 83 } |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 146 &message_queue_[0], &request_ack)); | 147 &message_queue_[0], &request_ack)); |
| 147 | 148 |
| 148 ASSERT_EQ(request_ack.a, request_id); | 149 ASSERT_EQ(request_ack.a, request_id); |
| 149 | 150 |
| 150 message_queue_.erase(message_queue_.begin()); | 151 message_queue_.erase(message_queue_.begin()); |
| 151 } | 152 } |
| 152 } | 153 } |
| 153 | 154 |
| 154 protected: | 155 protected: |
| 155 // testing::Test | 156 // testing::Test |
| 156 virtual void SetUp() { | 157 virtual void SetUp() OVERRIDE { |
| 157 dispatcher_.reset(new ResourceDispatcher(this)); | 158 dispatcher_.reset(new ResourceDispatcher(this)); |
| 158 } | 159 } |
| 159 virtual void TearDown() { | 160 virtual void TearDown() OVERRIDE { |
| 160 dispatcher_.reset(); | 161 dispatcher_.reset(); |
| 161 } | 162 } |
| 162 | 163 |
| 163 ResourceLoaderBridge* CreateBridge() { | 164 ResourceLoaderBridge* CreateBridge() { |
| 164 webkit_glue::ResourceLoaderBridge::RequestInfo request_info; | 165 webkit_glue::ResourceLoaderBridge::RequestInfo request_info; |
| 165 request_info.method = "GET"; | 166 request_info.method = "GET"; |
| 166 request_info.url = GURL(test_page_url); | 167 request_info.url = GURL(test_page_url); |
| 167 request_info.first_party_for_cookies = GURL(test_page_url); | 168 request_info.first_party_for_cookies = GURL(test_page_url); |
| 168 request_info.referrer = GURL(); | 169 request_info.referrer = GURL(); |
| 169 request_info.headers = std::string(); | 170 request_info.headers = std::string(); |
| (...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 229 // loading is enabled it should queue up any responses received. If deferred | 230 // loading is enabled it should queue up any responses received. If deferred |
| 230 // loading is enabled/disabled in the context of a dispatched message, other | 231 // loading is enabled/disabled in the context of a dispatched message, other |
| 231 // queued messages should not be dispatched until deferred load is turned off. | 232 // queued messages should not be dispatched until deferred load is turned off. |
| 232 class DeferredResourceLoadingTest : public ResourceDispatcherTest, | 233 class DeferredResourceLoadingTest : public ResourceDispatcherTest, |
| 233 public ResourceLoaderBridge::Peer { | 234 public ResourceLoaderBridge::Peer { |
| 234 public: | 235 public: |
| 235 DeferredResourceLoadingTest() | 236 DeferredResourceLoadingTest() |
| 236 : defer_loading_(false) { | 237 : defer_loading_(false) { |
| 237 } | 238 } |
| 238 | 239 |
| 239 virtual bool Send(IPC::Message* msg) { | 240 virtual bool Send(IPC::Message* msg) OVERRIDE { |
| 240 delete msg; | 241 delete msg; |
| 241 return true; | 242 return true; |
| 242 } | 243 } |
| 243 | 244 |
| 244 void InitMessages() { | 245 void InitMessages() { |
| 245 set_defer_loading(true); | 246 set_defer_loading(true); |
| 246 | 247 |
| 247 ResourceResponseHead response_head; | 248 ResourceResponseHead response_head; |
| 248 response_head.status.set_status(net::URLRequestStatus::SUCCESS); | 249 response_head.status.set_status(net::URLRequestStatus::SUCCESS); |
| 249 | 250 |
| 250 IPC::Message* response_message = | 251 dispatcher_->OnMessageReceived( |
| 251 new ResourceMsg_ReceivedResponse(0, 0, response_head); | 252 ResourceMsg_ReceivedResponse(0, 0, response_head)); |
| 252 | |
| 253 dispatcher_->OnMessageReceived(*response_message); | |
| 254 | |
| 255 delete response_message; | |
| 256 | 253 |
| 257 // Duplicate the shared memory handle so both the test and the callee can | 254 // Duplicate the shared memory handle so both the test and the callee can |
| 258 // close their copy. | 255 // close their copy. |
| 259 base::SharedMemoryHandle duplicated_handle; | 256 base::SharedMemoryHandle duplicated_handle; |
| 260 EXPECT_TRUE(shared_handle_.ShareToProcess(base::GetCurrentProcessHandle(), | 257 EXPECT_TRUE(shared_handle_.ShareToProcess(base::GetCurrentProcessHandle(), |
| 261 &duplicated_handle)); | 258 &duplicated_handle)); |
| 262 | 259 |
| 263 response_message = | 260 dispatcher_->OnMessageReceived( |
| 264 new ResourceMsg_DataReceived(0, 0, duplicated_handle, 100, 100); | 261 ResourceMsg_DataReceived(0, 0, duplicated_handle, 100, 100)); |
| 265 | |
| 266 dispatcher_->OnMessageReceived(*response_message); | |
| 267 | |
| 268 delete response_message; | |
| 269 | 262 |
| 270 set_defer_loading(false); | 263 set_defer_loading(false); |
| 271 } | 264 } |
| 272 | 265 |
| 273 // ResourceLoaderBridge::Peer methods. | 266 // ResourceLoaderBridge::Peer methods. |
| 274 virtual void OnUploadProgress(uint64 position, uint64 size) { | 267 virtual void OnUploadProgress(uint64 position, uint64 size) OVERRIDE { |
| 275 } | 268 } |
| 276 | 269 |
| 277 virtual bool OnReceivedRedirect( | 270 virtual bool OnReceivedRedirect( |
| 278 const GURL& new_url, | 271 const GURL& new_url, |
| 279 const ResourceResponseInfo& info, | 272 const ResourceResponseInfo& info, |
| 280 bool* has_new_first_party_for_cookies, | 273 bool* has_new_first_party_for_cookies, |
| 281 GURL* new_first_party_for_cookies) { | 274 GURL* new_first_party_for_cookies) OVERRIDE { |
| 282 *has_new_first_party_for_cookies = false; | 275 *has_new_first_party_for_cookies = false; |
| 283 return true; | 276 return true; |
| 284 } | 277 } |
| 285 | 278 |
| 286 virtual void OnReceivedResponse(const ResourceResponseInfo& info) { | 279 virtual void OnReceivedResponse(const ResourceResponseInfo& info) OVERRIDE { |
| 287 EXPECT_EQ(defer_loading_, false); | 280 EXPECT_EQ(defer_loading_, false); |
| 288 set_defer_loading(true); | 281 set_defer_loading(true); |
| 289 } | 282 } |
| 290 | 283 |
| 291 virtual void OnDownloadedData(int len) { | 284 virtual void OnDownloadedData(int len) OVERRIDE { |
| 292 } | 285 } |
| 293 | 286 |
| 294 virtual void OnReceivedData(const char* data, | 287 virtual void OnReceivedData(const char* data, |
| 295 int data_length, | 288 int data_length, |
| 296 int encoded_data_length) { | 289 int encoded_data_length) OVERRIDE { |
| 297 EXPECT_EQ(defer_loading_, false); | 290 EXPECT_EQ(defer_loading_, false); |
| 298 set_defer_loading(false); | 291 set_defer_loading(false); |
| 299 } | 292 } |
| 300 | 293 |
| 301 virtual void OnCompletedRequest(const net::URLRequestStatus& status, | 294 virtual void OnCompletedRequest( |
| 302 const std::string& security_info, | 295 const net::URLRequestStatus& status, |
| 303 const base::TimeTicks& completion_time) { | 296 const std::string& security_info, |
| 297 const base::TimeTicks& completion_time) OVERRIDE { |
| 304 } | 298 } |
| 305 | 299 |
| 306 protected: | 300 protected: |
| 307 virtual void SetUp() { | 301 virtual void SetUp() OVERRIDE { |
| 308 ResourceDispatcherTest::SetUp(); | 302 ResourceDispatcherTest::SetUp(); |
| 309 shared_handle_.Delete(kShmemSegmentName); | 303 shared_handle_.Delete(kShmemSegmentName); |
| 310 EXPECT_TRUE(shared_handle_.CreateNamed(kShmemSegmentName, false, 100)); | 304 EXPECT_TRUE(shared_handle_.CreateNamed(kShmemSegmentName, false, 100)); |
| 311 } | 305 } |
| 312 | 306 |
| 313 virtual void TearDown() { | 307 virtual void TearDown() OVERRIDE { |
| 314 shared_handle_.Close(); | 308 shared_handle_.Close(); |
| 315 EXPECT_TRUE(shared_handle_.Delete(kShmemSegmentName)); | 309 EXPECT_TRUE(shared_handle_.Delete(kShmemSegmentName)); |
| 316 ResourceDispatcherTest::TearDown(); | 310 ResourceDispatcherTest::TearDown(); |
| 317 } | 311 } |
| 318 | 312 |
| 319 private: | 313 private: |
| 320 void set_defer_loading(bool defer) { | 314 void set_defer_loading(bool defer) { |
| 321 defer_loading_ = defer; | 315 defer_loading_ = defer; |
| 322 dispatcher_->SetDefersLoading(0, defer); | 316 dispatcher_->SetDefersLoading(0, defer); |
| 323 } | 317 } |
| (...skipping 12 matching lines...) Expand all Loading... |
| 336 ResourceLoaderBridge* bridge = CreateBridge(); | 330 ResourceLoaderBridge* bridge = CreateBridge(); |
| 337 | 331 |
| 338 bridge->Start(this); | 332 bridge->Start(this); |
| 339 InitMessages(); | 333 InitMessages(); |
| 340 | 334 |
| 341 // Dispatch deferred messages. | 335 // Dispatch deferred messages. |
| 342 message_loop.RunAllPending(); | 336 message_loop.RunAllPending(); |
| 343 delete bridge; | 337 delete bridge; |
| 344 } | 338 } |
| 345 | 339 |
| 340 class TimeConversionTest : public ResourceDispatcherTest, |
| 341 public ResourceLoaderBridge::Peer { |
| 342 public: |
| 343 virtual bool Send(IPC::Message* msg) OVERRIDE { |
| 344 delete msg; |
| 345 return true; |
| 346 } |
| 347 |
| 348 void PerformTest(const ResourceResponseHead& response_head) { |
| 349 scoped_ptr<ResourceLoaderBridge> bridge(CreateBridge()); |
| 350 bridge->Start(this); |
| 351 |
| 352 dispatcher_->OnMessageReceived( |
| 353 ResourceMsg_ReceivedResponse(0, 0, response_head)); |
| 354 } |
| 355 |
| 356 // ResourceLoaderBridge::Peer methods. |
| 357 virtual void OnUploadProgress(uint64 position, uint64 size) OVERRIDE { |
| 358 } |
| 359 |
| 360 virtual bool OnReceivedRedirect( |
| 361 const GURL& new_url, |
| 362 const ResourceResponseInfo& info, |
| 363 bool* has_new_first_party_for_cookies, |
| 364 GURL* new_first_party_for_cookies) { |
| 365 return true; |
| 366 } |
| 367 |
| 368 virtual void OnReceivedResponse(const ResourceResponseInfo& info) OVERRIDE { |
| 369 response_info_ = info; |
| 370 } |
| 371 |
| 372 virtual void OnDownloadedData(int len) OVERRIDE { |
| 373 } |
| 374 |
| 375 virtual void OnReceivedData(const char* data, |
| 376 int data_length, |
| 377 int encoded_data_length) OVERRIDE { |
| 378 } |
| 379 |
| 380 virtual void OnCompletedRequest( |
| 381 const net::URLRequestStatus& status, |
| 382 const std::string& security_info, |
| 383 const base::TimeTicks& completion_time) OVERRIDE { |
| 384 } |
| 385 |
| 386 const ResourceResponseInfo& response_info() const { return response_info_; } |
| 387 |
| 388 private: |
| 389 ResourceResponseInfo response_info_; |
| 390 }; |
| 391 |
| 392 // TODO(simonjam): Enable this when 10829031 lands. |
| 393 TEST_F(TimeConversionTest, DISABLED_ProperlyInitialized) { |
| 394 ResourceResponseHead response_head; |
| 395 response_head.status.set_status(net::URLRequestStatus::SUCCESS); |
| 396 response_head.request_start = base::TimeTicks::FromInternalValue(5); |
| 397 response_head.response_start = base::TimeTicks::FromInternalValue(15); |
| 398 response_head.load_timing.base_time = base::Time::Now(); |
| 399 response_head.load_timing.base_ticks = base::TimeTicks::FromInternalValue(10); |
| 400 response_head.load_timing.dns_start = -1; |
| 401 response_head.load_timing.connect_start = 3; |
| 402 |
| 403 PerformTest(response_head); |
| 404 |
| 405 EXPECT_LT(0, response_info().load_timing.base_ticks.ToInternalValue()); |
| 406 EXPECT_EQ(-1, response_info().load_timing.dns_start); |
| 407 EXPECT_LE(0, response_info().load_timing.connect_start); |
| 408 } |
| 409 |
| 410 TEST_F(TimeConversionTest, PartiallyInitialized) { |
| 411 ResourceResponseHead response_head; |
| 412 response_head.status.set_status(net::URLRequestStatus::SUCCESS); |
| 413 response_head.request_start = base::TimeTicks::FromInternalValue(5); |
| 414 response_head.response_start = base::TimeTicks::FromInternalValue(15); |
| 415 |
| 416 PerformTest(response_head); |
| 417 |
| 418 EXPECT_EQ(0, response_info().load_timing.base_ticks.ToInternalValue()); |
| 419 EXPECT_EQ(-1, response_info().load_timing.dns_start); |
| 420 } |
| 421 |
| 422 TEST_F(TimeConversionTest, NotInitialized) { |
| 423 ResourceResponseHead response_head; |
| 424 response_head.status.set_status(net::URLRequestStatus::SUCCESS); |
| 425 |
| 426 PerformTest(response_head); |
| 427 |
| 428 EXPECT_EQ(0, response_info().load_timing.base_ticks.ToInternalValue()); |
| 429 EXPECT_EQ(-1, response_info().load_timing.dns_start); |
| 430 } |
| 431 |
| 346 } // namespace content | 432 } // namespace content |
| OLD | NEW |