 Chromium Code Reviews
 Chromium Code Reviews Issue 1381153004:
  Service Worker: Change the criteria for bumping the last update check time  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master
    
  
    Issue 1381153004:
  Service Worker: Change the criteria for bumping the last update check time  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master| Index: content/browser/service_worker/service_worker_register_job.cc | 
| diff --git a/content/browser/service_worker/service_worker_register_job.cc b/content/browser/service_worker/service_worker_register_job.cc | 
| index 244905ef69c213e2d69d80e35acbdb899aa413a2..f3a121e66337cd3d9cb85d24461410551fe575f4 100644 | 
| --- a/content/browser/service_worker/service_worker_register_job.cc | 
| +++ b/content/browser/service_worker/service_worker_register_job.cc | 
| @@ -350,6 +350,18 @@ void ServiceWorkerRegisterJob::UpdateAndContinue() { | 
| void ServiceWorkerRegisterJob::OnStartWorkerFinished( | 
| ServiceWorkerStatusCode status) { | 
| + // Bump the last update check time only when the register/update job fetched | 
| + // the version having bypassed the network cache. As bypassing the network | 
| + // cache will evict an existing cache entry, it is okay to bump the update | 
| + // check time. | 
| 
falken
2015/12/16 08:27:48
I think the second sentence of this comment would
 
jungkees
2015/12/16 08:59:20
Thanks for the comment. I used the words as-is exc
 | 
| + if (new_version()->embedded_worker()->network_accessed_for_script() || | 
| + new_version()->force_bypass_cache_for_scripts()) { | 
| + registration()->set_last_update_check(base::Time::Now()); | 
| + | 
| + if (job_type_ == UPDATE_JOB) | 
| + context_->storage()->UpdateLastUpdateCheckTime(registration()); | 
| + } | 
| + | 
| if (status == SERVICE_WORKER_OK) { | 
| InstallAndContinue(); | 
| return; | 
| @@ -357,16 +369,6 @@ void ServiceWorkerRegisterJob::OnStartWorkerFinished( | 
| // The updated worker is identical to the incumbent. | 
| if (status == SERVICE_WORKER_ERROR_EXISTS) { | 
| - // Only bump the last check time when we've bypassed the browser cache. | 
| - base::TimeDelta time_since_last_check = | 
| - base::Time::Now() - registration()->last_update_check(); | 
| - if (time_since_last_check > base::TimeDelta::FromHours( | 
| - kServiceWorkerScriptMaxCacheAgeInHours) || | 
| - new_version()->force_bypass_cache_for_scripts()) { | 
| - registration()->set_last_update_check(base::Time::Now()); | 
| - context_->storage()->UpdateLastUpdateCheckTime(registration()); | 
| - } | 
| - | 
| ResolvePromise(SERVICE_WORKER_OK, std::string(), registration()); | 
| Complete(status, "The updated worker is identical to the incumbent."); | 
| return; | 
| @@ -431,7 +433,6 @@ void ServiceWorkerRegisterJob::OnInstallFinished( | 
| } | 
| SetPhase(STORE); | 
| - registration()->set_last_update_check(base::Time::Now()); | 
| context_->storage()->StoreRegistration( | 
| registration(), | 
| new_version(), |