OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/location.h" | 5 #include "base/location.h" |
6 #include "base/run_loop.h" | 6 #include "base/run_loop.h" |
7 #include "base/single_thread_task_runner.h" | 7 #include "base/single_thread_task_runner.h" |
8 #include "base/thread_task_runner_handle.h" | 8 #include "base/thread_task_runner_handle.h" |
9 #include "content/browser/fileapi/mock_url_request_delegate.h" | 9 #include "content/browser/fileapi/mock_url_request_delegate.h" |
10 #include "content/browser/service_worker/embedded_worker_test_helper.h" | 10 #include "content/browser/service_worker/embedded_worker_test_helper.h" |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
53 net::URLRequestJob* CreateNormalURLRequestJob( | 53 net::URLRequestJob* CreateNormalURLRequestJob( |
54 net::URLRequest* request, | 54 net::URLRequest* request, |
55 net::NetworkDelegate* network_delegate) { | 55 net::NetworkDelegate* network_delegate) { |
56 return new net::URLRequestTestJob(request, | 56 return new net::URLRequestTestJob(request, |
57 network_delegate, | 57 network_delegate, |
58 std::string(kHeaders, arraysize(kHeaders)), | 58 std::string(kHeaders, arraysize(kHeaders)), |
59 kScriptCode, | 59 kScriptCode, |
60 true); | 60 true); |
61 } | 61 } |
62 | 62 |
63 net::URLRequestJob* CreateResponseJob(const std::string& response_data, | 63 net::URLRequestJob* CreateCachedResponseJob( |
64 net::URLRequest* request, | 64 const std::string& response_data, |
65 net::NetworkDelegate* network_delegate) { | 65 net::URLRequest* request, |
66 net::NetworkDelegate* network_delegate) { | |
66 return new net::URLRequestTestJob(request, network_delegate, | 67 return new net::URLRequestTestJob(request, network_delegate, |
67 std::string(kHeaders, arraysize(kHeaders)), | 68 std::string(kHeaders, arraysize(kHeaders)), |
68 response_data, true); | 69 response_data, true); |
69 } | 70 } |
70 | 71 |
72 class NetworkResponseJob : public net::URLRequestTestJob { | |
73 public: | |
74 NetworkResponseJob(net::URLRequest* request, | |
75 net::NetworkDelegate* network_delegate, | |
76 const std::string& response_headers, | |
77 const std::string& response_data, | |
78 bool auto_advance) | |
79 : net::URLRequestTestJob(request, | |
80 network_delegate, | |
81 response_headers, | |
82 response_data, | |
83 auto_advance) {} | |
84 void GetResponseInfo(net::HttpResponseInfo* info) override { | |
85 URLRequestTestJob::GetResponseInfo(info); | |
86 info->network_accessed = true; | |
87 } | |
88 | |
89 protected: | |
90 ~NetworkResponseJob() override {} | |
91 }; | |
92 | |
93 net::URLRequestJob* CreateNetworkResponseJob( | |
94 const std::string& response_data, | |
95 net::URLRequest* request, | |
96 net::NetworkDelegate* network_delegate) { | |
97 return new NetworkResponseJob(request, network_delegate, | |
98 std::string(kHeaders, arraysize(kHeaders)), | |
99 response_data, true); | |
100 } | |
101 | |
71 net::URLRequestJob* CreateInvalidMimeTypeJob( | 102 net::URLRequestJob* CreateInvalidMimeTypeJob( |
72 net::URLRequest* request, | 103 net::URLRequest* request, |
73 net::NetworkDelegate* network_delegate) { | 104 net::NetworkDelegate* network_delegate) { |
74 const char kPlainTextHeaders[] = | 105 const char kPlainTextHeaders[] = |
75 "HTTP/1.1 200 OK\0" | 106 "HTTP/1.1 200 OK\0" |
76 "Content-Type: text/plain\0" | 107 "Content-Type: text/plain\0" |
77 "Expires: Thu, 1 Jan 2100 20:00:00 GMT\0" | 108 "Expires: Thu, 1 Jan 2100 20:00:00 GMT\0" |
78 "\0"; | 109 "\0"; |
79 return new net::URLRequestTestJob( | 110 return new net::URLRequestTestJob( |
80 request, | 111 request, |
81 network_delegate, | 112 network_delegate, |
82 std::string(kPlainTextHeaders, arraysize(kPlainTextHeaders)), | 113 std::string(kPlainTextHeaders, arraysize(kPlainTextHeaders)), |
83 kScriptCode, | 114 kScriptCode, |
84 true); | 115 true); |
85 } | 116 } |
86 | 117 |
118 net::URLRequestJob* CreateErrorReponseJob( | |
119 net::URLRequest* request, | |
120 net::NetworkDelegate* network_delegate) { | |
121 const char kErrorHeaders[] = "HTTP/1.1 404 Not Found\0\0"; | |
122 return new net::URLRequestTestJob( | |
123 request, network_delegate, | |
124 std::string(kErrorHeaders, arraysize(kErrorHeaders)), kScriptCode, true); | |
125 } | |
126 | |
87 class SSLCertificateErrorJob : public net::URLRequestTestJob { | 127 class SSLCertificateErrorJob : public net::URLRequestTestJob { |
88 public: | 128 public: |
89 SSLCertificateErrorJob(net::URLRequest* request, | 129 SSLCertificateErrorJob(net::URLRequest* request, |
90 net::NetworkDelegate* network_delegate, | 130 net::NetworkDelegate* network_delegate, |
91 const std::string& response_headers, | 131 const std::string& response_headers, |
92 const std::string& response_data, | 132 const std::string& response_data, |
93 bool auto_advance) | 133 bool auto_advance) |
94 : net::URLRequestTestJob(request, | 134 : net::URLRequestTestJob(request, |
95 network_delegate, | 135 network_delegate, |
96 response_headers, | 136 response_headers, |
(...skipping 229 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
326 mock_protocol_handler_ = nullptr; | 366 mock_protocol_handler_ = nullptr; |
327 version_ = nullptr; | 367 version_ = nullptr; |
328 registration_ = nullptr; | 368 registration_ = nullptr; |
329 helper_.reset(); | 369 helper_.reset(); |
330 // URLRequestJobs may post clean-up tasks on destruction. | 370 // URLRequestJobs may post clean-up tasks on destruction. |
331 base::RunLoop().RunUntilIdle(); | 371 base::RunLoop().RunUntilIdle(); |
332 } | 372 } |
333 | 373 |
334 int CreateIncumbent(const std::string& response) { | 374 int CreateIncumbent(const std::string& response) { |
335 mock_protocol_handler_->SetCreateJobCallback( | 375 mock_protocol_handler_->SetCreateJobCallback( |
336 base::Bind(&CreateResponseJob, response)); | 376 base::Bind(&CreateNetworkResponseJob, response)); |
337 request_->Start(); | 377 request_->Start(); |
338 base::RunLoop().RunUntilIdle(); | 378 base::RunLoop().RunUntilIdle(); |
339 EXPECT_EQ(net::URLRequestStatus::SUCCESS, request_->status().status()); | 379 EXPECT_EQ(net::URLRequestStatus::SUCCESS, request_->status().status()); |
340 int incumbent_resource_id = | 380 int incumbent_resource_id = |
341 version_->script_cache_map()->LookupResourceId(script_url_); | 381 version_->script_cache_map()->LookupResourceId(script_url_); |
342 EXPECT_NE(kInvalidServiceWorkerResponseId, incumbent_resource_id); | 382 EXPECT_NE(kInvalidServiceWorkerResponseId, incumbent_resource_id); |
343 | 383 |
344 registration_->SetActiveVersion(version_); | 384 registration_->SetActiveVersion(version_); |
345 | 385 |
346 // Teardown the request. | 386 // Teardown the request. |
347 request_.reset(); | 387 request_.reset(); |
348 url_request_context_.reset(); | 388 url_request_context_.reset(); |
349 url_request_job_factory_.reset(); | 389 url_request_job_factory_.reset(); |
350 mock_protocol_handler_ = nullptr; | 390 mock_protocol_handler_ = nullptr; |
351 base::RunLoop().RunUntilIdle(); | 391 base::RunLoop().RunUntilIdle(); |
352 | 392 |
353 return incumbent_resource_id; | 393 return incumbent_resource_id; |
354 } | 394 } |
355 | 395 |
356 int GetResourceId(ServiceWorkerVersion* version) { | 396 int GetResourceId(ServiceWorkerVersion* version) { |
357 return version->script_cache_map()->LookupResourceId(script_url_); | 397 return version->script_cache_map()->LookupResourceId(script_url_); |
358 } | 398 } |
359 | 399 |
360 // Performs the net request for an update of |registration_|'s incumbent | 400 // Performs the net request for an update of |registration_|'s incumbent |
361 // to the script |response|. Returns the new version. | 401 // to the script |response|. Returns the new version. |
362 scoped_refptr<ServiceWorkerVersion> UpdateScript( | 402 scoped_refptr<ServiceWorkerVersion> UpdateScript( |
363 const std::string& response) { | 403 const std::string& response, |
404 bool status_success = true, | |
405 bool network_accessed = true) { | |
nhiroki
2015/09/09 08:27:48
nit: Passing multiple booleans could be error-pron
jungkees
2015/09/09 13:13:37
Agreed. I did it with the passing a callback optio
| |
364 int render_process_id = NextRenderProcessId(); | 406 int render_process_id = NextRenderProcessId(); |
365 int provider_id = NextProviderId(); | 407 int provider_id = NextProviderId(); |
366 scoped_refptr<ServiceWorkerVersion> new_version = | 408 scoped_refptr<ServiceWorkerVersion> new_version = |
367 new ServiceWorkerVersion(registration_.get(), script_url_, | 409 new ServiceWorkerVersion(registration_.get(), script_url_, |
368 NextVersionId(), context()->AsWeakPtr()); | 410 NextVersionId(), context()->AsWeakPtr()); |
369 CreateHostForVersion(render_process_id, provider_id, new_version); | 411 CreateHostForVersion(render_process_id, provider_id, new_version); |
370 | 412 |
371 SetUpScriptRequest(render_process_id, provider_id); | 413 SetUpScriptRequest(render_process_id, provider_id); |
372 mock_protocol_handler_->SetCreateJobCallback( | 414 if (status_success) { |
373 base::Bind(&CreateResponseJob, response)); | 415 // Whether the script load request accessed the network or was served from |
416 // HTTPCache. | |
417 if (network_accessed) { | |
418 mock_protocol_handler_->SetCreateJobCallback( | |
419 base::Bind(&CreateNetworkResponseJob, response)); | |
420 } else { | |
421 mock_protocol_handler_->SetCreateJobCallback( | |
422 base::Bind(&CreateCachedResponseJob, response)); | |
423 } | |
424 } else { | |
425 mock_protocol_handler_->SetCreateJobCallback( | |
426 base::Bind(&CreateErrorReponseJob)); | |
427 } | |
374 request_->Start(); | 428 request_->Start(); |
375 base::RunLoop().RunUntilIdle(); | 429 base::RunLoop().RunUntilIdle(); |
376 return new_version; | 430 return new_version; |
377 } | 431 } |
378 | 432 |
379 void VerifyResource(int id, const std::string& expected) { | 433 void VerifyResource(int id, const std::string& expected) { |
380 ASSERT_NE(kInvalidServiceWorkerResourceId, id); | 434 ASSERT_NE(kInvalidServiceWorkerResourceId, id); |
381 bool is_equal = false; | 435 bool is_equal = false; |
382 scoped_ptr<ServiceWorkerResponseReader> reader = | 436 scoped_ptr<ServiceWorkerResponseReader> reader = |
383 context()->storage()->CreateResponseReader(id); | 437 context()->storage()->CreateResponseReader(id); |
(...skipping 182 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
566 // Update from non-empty to empty. | 620 // Update from non-empty to empty. |
567 version = UpdateScript(std::string()); | 621 version = UpdateScript(std::string()); |
568 VerifyResource(GetResourceId(version.get()), std::string()); | 622 VerifyResource(GetResourceId(version.get()), std::string()); |
569 registration_->SetWaitingVersion(version); | 623 registration_->SetWaitingVersion(version); |
570 | 624 |
571 // Update from empty to empty. | 625 // Update from empty to empty. |
572 version = UpdateScript(std::string()); | 626 version = UpdateScript(std::string()); |
573 EXPECT_EQ(kInvalidServiceWorkerResponseId, GetResourceId(version.get())); | 627 EXPECT_EQ(kInvalidServiceWorkerResponseId, GetResourceId(version.get())); |
574 } | 628 } |
575 | 629 |
630 TEST_F(ServiceWorkerWriteToCacheJobTest, Update_BumpLastUpdateCheckTime) { | |
631 std::string response = GenerateLongResponse(); | |
632 CreateIncumbent(response); | |
633 | |
634 // Script was served from HTTPCache. | |
635 base::Time current = base::Time::Now(); | |
636 registration_->set_last_update_check(current); | |
637 scoped_refptr<ServiceWorkerVersion> version = UpdateScript( | |
638 response, true /* status_success */, false /* network_accessed */); | |
639 EXPECT_EQ(current, registration_->last_update_check()); | |
640 | |
641 // Same script but the request accessed the network. | |
642 version = UpdateScript(response); | |
643 EXPECT_LT(current, registration_->last_update_check()); | |
644 | |
645 // Changed the first byte and the request accessed the network. | |
646 response[0] = 'x'; | |
647 current = base::Time::Now(); | |
648 registration_->set_last_update_check(current); | |
649 version = UpdateScript(response); | |
650 VerifyResource(GetResourceId(version.get()), response); | |
651 registration_->SetWaitingVersion(version); | |
652 EXPECT_LT(current, registration_->last_update_check()); | |
653 | |
654 // The request accessed the network but received a non-2xx error. | |
655 current = base::Time::Now(); | |
656 registration_->set_last_update_check(current); | |
657 version = UpdateScript(response, false /* status_success */); | |
658 EXPECT_EQ(current, registration_->last_update_check()); | |
659 } | |
660 | |
576 } // namespace content | 661 } // namespace content |
OLD | NEW |