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

Side by Side Diff: content/browser/service_worker/service_worker_write_to_cache_job_unittest.cc

Issue 1283273002: Service Worker: Change last update check location and HTTP cache bypass rule (2/2) (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Use |request->response_info().network_accessed| to check network access. Created 5 years, 3 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
« no previous file with comments | « content/browser/service_worker/service_worker_write_to_cache_job.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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
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
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
OLDNEW
« no previous file with comments | « content/browser/service_worker/service_worker_write_to_cache_job.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698