diff options
author | michaeln@google.com <michaeln@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-01-28 21:20:17 +0000 |
---|---|---|
committer | michaeln@google.com <michaeln@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-01-28 21:20:17 +0000 |
commit | 1290063b22632e0e615955e726e59204dd2bc7c0 (patch) | |
tree | 9f04c6e940586ff59dbf282eb9aec6227fa82a13 | |
parent | 90e888c657e928a56e4c67fa84f85354e0fc7748 (diff) | |
download | chromium_src-1290063b22632e0e615955e726e59204dd2bc7c0.zip chromium_src-1290063b22632e0e615955e726e59204dd2bc7c0.tar.gz chromium_src-1290063b22632e0e615955e726e59204dd2bc7c0.tar.bz2 |
Do a better job of caching appcache status values in the renderer based on the sequence of events seen.
BUG=none
TEST=existing tests apply
Review URL: http://codereview.chromium.org/4901002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@73021 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/appcache/appcache_ui_test.cc | 8 | ||||
-rw-r--r-- | webkit/appcache/web_application_cache_host_impl.cc | 162 | ||||
-rw-r--r-- | webkit/appcache/web_application_cache_host_impl.h | 3 |
3 files changed, 79 insertions, 94 deletions
diff --git a/chrome/browser/appcache/appcache_ui_test.cc b/chrome/browser/appcache/appcache_ui_test.cc index 521cfd6..58ca32b 100644 --- a/chrome/browser/appcache/appcache_ui_test.cc +++ b/chrome/browser/appcache/appcache_ui_test.cc @@ -80,16 +80,18 @@ TEST_F(AppCacheUITest, FLAKY_AppCacheLayoutTests_PHP) { "non-html.xhtml", "offline-access.html", "online-whitelist.html", + "remove-cache.html", "resource-redirect.html", "resource-redirect-2.html", "update-cache.html", }; - // These tests are racey due to status polling on timers. - // https://bugs.webkit.org/show_bug.cgi?id=49104 + // This tests loads a data url which calls notifyDone, this just + // doesn't work with the layoutTestController in this test harness. // "fail-on-update.html", + + // Flaky for reasons i don't yet see? // "fail-on-update2.html", - // "remove-cache.html", // TODO(michaeln): investigate these more closely // "crash-when-navigating-away-then-back.html", diff --git a/webkit/appcache/web_application_cache_host_impl.cc b/webkit/appcache/web_application_cache_host_impl.cc index 1da9680..3d9deb9 100644 --- a/webkit/appcache/web_application_cache_host_impl.cc +++ b/webkit/appcache/web_application_cache_host_impl.cc @@ -69,10 +69,7 @@ WebApplicationCacheHostImpl::WebApplicationCacheHostImpl( : client_(client), backend_(backend), ALLOW_THIS_IN_INITIALIZER_LIST(host_id_(g_hosts_map.Get().Add(this))), - has_status_(false), status_(UNCACHED), - has_cached_status_(false), - cached_status_(UNCACHED), is_scheme_supported_(false), is_get_method_(false), is_new_master_entry_(MAYBE) { @@ -88,15 +85,12 @@ WebApplicationCacheHostImpl::~WebApplicationCacheHostImpl() { void WebApplicationCacheHostImpl::OnCacheSelected( const appcache::AppCacheInfo& info) { - status_ = info.status; - has_status_ = true; cache_info_ = info; client_->didChangeCacheAssociation(); } void WebApplicationCacheHostImpl::OnStatusChanged(appcache::Status status) { - if (has_status_) - status_ = status; + // TODO(michaeln): delete me, not used } void WebApplicationCacheHostImpl::OnEventRaised(appcache::EventID event_id) { @@ -110,10 +104,28 @@ void WebApplicationCacheHostImpl::OnEventRaised(appcache::EventID event_id) { kEventNames[event_id]); OnLogMessage(LOG_INFO, message); - // Most events change the status. Clear out what we know so that the latest - // status will be obtained from the backend. - has_status_ = false; - has_cached_status_ = false; + switch (event_id) { + case CHECKING_EVENT: + status_ = CHECKING; + break; + case DOWNLOADING_EVENT: + status_ = DOWNLOADING; + break; + case UPDATE_READY_EVENT: + status_ = UPDATE_READY; + break; + case CACHED_EVENT: + case NO_UPDATE_EVENT: + status_ = IDLE; + break; + case OBSOLETE_EVENT: + status_ = OBSOLETE; + break; + default: + NOTREACHED(); + break; + } + client_->notifyEventListener(static_cast<EventID>(event_id)); } @@ -125,7 +137,7 @@ void WebApplicationCacheHostImpl::OnProgressEventRaised( std::string message = base::StringPrintf(kFormatString, num_complete, num_total, url.spec().c_str()); OnLogMessage(LOG_INFO, message); - + status_ = DOWNLOADING; client_->notifyProgressEventListener(url, num_total, num_complete); } @@ -138,10 +150,7 @@ void WebApplicationCacheHostImpl::OnErrorEventRaised( message.c_str()); OnLogMessage(LOG_ERROR, full_message); - // Most events change the status. Clear out what we know so that the latest - // status will be obtained from the backend. - has_status_ = false; - has_cached_status_ = false; + status_ = cache_info_.is_complete ? IDLE : UNCACHED; client_->notifyEventListener(static_cast<EventID>(ERROR_EVENT)); } @@ -162,55 +171,16 @@ void WebApplicationCacheHostImpl::willStartSubResourceRequest( } void WebApplicationCacheHostImpl::selectCacheWithoutManifest() { - // Reset any previous status values we've received from the backend - // since we're now selecting a new cache. - has_status_ = false; - has_cached_status_ = false; + status_ = (document_response_.appCacheID() == kNoCacheId) ? + UNCACHED : CHECKING; is_new_master_entry_ = NO; backend_->SelectCache(host_id_, document_url_, document_response_.appCacheID(), GURL()); } -void WebApplicationCacheHostImpl::getAssociatedCacheInfo( - WebApplicationCacheHost::CacheInfo* info) { - if (!cache_info_.is_complete) - return; - info->manifestURL = cache_info_.manifest_url; - info->creationTime = cache_info_.creation_time.ToDoubleT(); - info->updateTime = cache_info_.last_update_time.ToDoubleT(); - info->totalSize = cache_info_.size; -} - -void WebApplicationCacheHostImpl::getResourceList( - WebVector<ResourceInfo>* resources) { - if (!cache_info_.is_complete) - return; - std::vector<AppCacheResourceInfo> resource_infos; - backend_->GetResourceList(host_id_, &resource_infos); - - WebVector<ResourceInfo> web_resources(resource_infos.size()); - // Convert resource_infos to WebKit API. - for (size_t i = 0; i < resource_infos.size(); ++i) { - web_resources[i].size = resource_infos[i].size; - web_resources[i].isMaster = resource_infos[i].is_master; - web_resources[i].isExplicit = resource_infos[i].is_explicit; - web_resources[i].isManifest = resource_infos[i].is_manifest; - web_resources[i].isForeign = resource_infos[i].is_foreign; - web_resources[i].isFallback = resource_infos[i].is_fallback; - web_resources[i].url = resource_infos[i].url; - } - - resources->swap(web_resources); -} - bool WebApplicationCacheHostImpl::selectCacheWithManifest( const WebURL& manifest_url) { - // Reset any previous status values we've received from the backend - // since we're now selecting a new cache. - has_status_ = false; - has_cached_status_ = false; - GURL manifest_gurl(ClearUrlRef(manifest_url)); // 6.9.6 The application cache selection algorithm @@ -218,8 +188,10 @@ bool WebApplicationCacheHostImpl::selectCacheWithManifest( if (document_response_.appCacheID() == kNoCacheId) { if (is_scheme_supported_ && is_get_method_ && (manifest_gurl.GetOrigin() == document_url_.GetOrigin())) { + status_ = CHECKING; is_new_master_entry_ = YES; } else { + status_ = UNCACHED; is_new_master_entry_ = NO; manifest_gurl = GURL(); } @@ -236,11 +208,12 @@ bool WebApplicationCacheHostImpl::selectCacheWithManifest( if (document_manifest_gurl != manifest_gurl) { backend_->MarkAsForeignEntry(host_id_, document_url_, document_response_.appCacheID()); - has_cached_status_ = true; - cached_status_ = UNCACHED; + status_ = UNCACHED; return false; // the navigation will be restarted } + status_ = CHECKING; + // Its a 'master' entry thats already in the cache. backend_->SelectCache(host_id_, document_url_, document_response_.appCacheID(), @@ -276,41 +249,54 @@ void WebApplicationCacheHostImpl::didFinishLoadingMainResource(bool success) { } WebApplicationCacheHost::Status WebApplicationCacheHostImpl::status() { - // We're careful about the status value to avoid race conditions. - // - // Generally the webappcachehost sends an async stream of messages to the - // backend, and receives an asyncronous stream of events from the backend. - // In the backend, all operations are serialized and as state changes - // 'events' are streamed out to relevant parties. In particular the - // 'SelectCache' message is async. Regular page loading and navigation - // involves two non-blocking ipc calls: RegisterHost + SelectCache. - // - // However, the page can call the scriptable API in advance of a cache - // selection being complete (and/or in advance of the webappcachehost having - // received the event about completion). In that case, we force an end-to-end - // fetch of the 'status' value, and cache that value seperately from the - // value we receive via the async event stream. We'll use that cached value - // until cache selection is complete. - if (has_status_) - return static_cast<WebApplicationCacheHost::Status>(status_); - - if (!has_cached_status_) { - cached_status_ = backend_->GetStatus(host_id_); - has_cached_status_ = true; - } - return static_cast<WebApplicationCacheHost::Status>(cached_status_); + return static_cast<WebApplicationCacheHost::Status>(status_); } bool WebApplicationCacheHostImpl::startUpdate() { - return backend_->StartUpdate(host_id_); + if (!backend_->StartUpdate(host_id_)) + return false; + if (status_ == IDLE || status_ == UPDATE_READY) + status_ = CHECKING; + else + status_ = backend_->GetStatus(host_id_); + return true; } bool WebApplicationCacheHostImpl::swapCache() { - // Cache status will change when cache is swapped. Clear out any saved idea - // of status so that backend will be queried for actual status. - has_status_ = false; - has_cached_status_ = false; - return backend_->SwapCache(host_id_); + if (!backend_->SwapCache(host_id_)) + return false; + status_ = backend_->GetStatus(host_id_); + return true; +} + +void WebApplicationCacheHostImpl::getAssociatedCacheInfo( + WebApplicationCacheHost::CacheInfo* info) { + if (!cache_info_.is_complete) + return; + info->manifestURL = cache_info_.manifest_url; + info->creationTime = cache_info_.creation_time.ToDoubleT(); + info->updateTime = cache_info_.last_update_time.ToDoubleT(); + info->totalSize = cache_info_.size; +} + +void WebApplicationCacheHostImpl::getResourceList( + WebVector<ResourceInfo>* resources) { + if (!cache_info_.is_complete) + return; + std::vector<AppCacheResourceInfo> resource_infos; + backend_->GetResourceList(host_id_, &resource_infos); + + WebVector<ResourceInfo> web_resources(resource_infos.size()); + for (size_t i = 0; i < resource_infos.size(); ++i) { + web_resources[i].size = resource_infos[i].size; + web_resources[i].isMaster = resource_infos[i].is_master; + web_resources[i].isExplicit = resource_infos[i].is_explicit; + web_resources[i].isManifest = resource_infos[i].is_manifest; + web_resources[i].isForeign = resource_infos[i].is_foreign; + web_resources[i].isFallback = resource_infos[i].is_fallback; + web_resources[i].url = resource_infos[i].url; + } + resources->swap(web_resources); } } // appcache namespace diff --git a/webkit/appcache/web_application_cache_host_impl.h b/webkit/appcache/web_application_cache_host_impl.h index 6a9406a..4304783 100644 --- a/webkit/appcache/web_application_cache_host_impl.h +++ b/webkit/appcache/web_application_cache_host_impl.h @@ -67,10 +67,7 @@ class WebApplicationCacheHostImpl : public WebKit::WebApplicationCacheHost { WebKit::WebApplicationCacheHostClient* client_; AppCacheBackend* backend_; int host_id_; - bool has_status_; appcache::Status status_; - bool has_cached_status_; - appcache::Status cached_status_; WebKit::WebURLResponse document_response_; GURL document_url_; bool is_scheme_supported_; |