diff options
author | michaeln@chromium.org <michaeln@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-01-04 19:11:14 +0000 |
---|---|---|
committer | michaeln@chromium.org <michaeln@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-01-04 19:11:14 +0000 |
commit | 8d37b18c3c8c5258fd7a94460eb613df37a3155e (patch) | |
tree | d48745f0fbbd830d7b305277517aae3747bf6810 /webkit/appcache | |
parent | 3b467d84c402cb2bee271bda2f4babd5d60e648e (diff) | |
download | chromium_src-8d37b18c3c8c5258fd7a94460eb613df37a3155e.zip chromium_src-8d37b18c3c8c5258fd7a94460eb613df37a3155e.tar.gz chromium_src-8d37b18c3c8c5258fd7a94460eb613df37a3155e.tar.bz2 |
Fixes to address the failing appcache/remove-cache.html layout tests.
BUG=31300
TEST=yes, layout test
Review URL: http://codereview.chromium.org/524014
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@35465 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/appcache')
-rw-r--r-- | webkit/appcache/appcache_group.cc | 6 | ||||
-rw-r--r-- | webkit/appcache/appcache_host.cc | 7 | ||||
-rw-r--r-- | webkit/appcache/appcache_storage_impl.cc | 5 | ||||
-rw-r--r-- | webkit/appcache/appcache_update_job.cc | 1 | ||||
-rw-r--r-- | webkit/appcache/mock_appcache_storage.cc | 9 |
5 files changed, 20 insertions, 8 deletions
diff --git a/webkit/appcache/appcache_group.cc b/webkit/appcache/appcache_group.cc index a9ad808..e5511a6 100644 --- a/webkit/appcache/appcache_group.cc +++ b/webkit/appcache/appcache_group.cc @@ -171,7 +171,9 @@ void AppCacheGroup::RunQueuedUpdates() { queued_observers_.RemoveObserver(host); observers_.AddObserver(host); } - StartUpdateWithNewMasterEntry(host, it->second); + + if (!is_obsolete()) + StartUpdateWithNewMasterEntry(host, it->second); } } @@ -189,7 +191,7 @@ bool AppCacheGroup::FindObserver(UpdateObserver* find_me, void AppCacheGroup::ScheduleUpdateRestart(int delay_ms) { DCHECK(!restart_update_task_); restart_update_task_ = - NewRunnableMethod(this, &AppCacheGroup::RunQueuedUpdates); + NewRunnableMethod(this, &AppCacheGroup::RunQueuedUpdates); MessageLoop::current()->PostDelayedTask(FROM_HERE, restart_update_task_, delay_ms); } diff --git a/webkit/appcache/appcache_host.cc b/webkit/appcache/appcache_host.cc index 489d062..d35d61a 100644 --- a/webkit/appcache/appcache_host.cc +++ b/webkit/appcache/appcache_host.cc @@ -269,14 +269,17 @@ void AppCacheHost::FinishCacheSelection( DCHECK(cache->owning_group()); DCHECK(new_master_entry_url_.is_empty()); AssociateCache(cache); - cache->owning_group()->StartUpdateWithHost(this); - ObserveGroupBeingUpdated(cache->owning_group()); + if (!cache->owning_group()->is_obsolete()) { + cache->owning_group()->StartUpdateWithHost(this); + ObserveGroupBeingUpdated(cache->owning_group()); + } } else if (group) { // If document was loaded using HTTP GET or equivalent, and, there is a // manifest URL, and manifest URL has the same origin as document. // Invoke the application cache update process for manifest URL, with // the browsing context being navigated, and with document and the // resource from which document was loaded as the new master resourse. + DCHECK(!group->is_obsolete()); DCHECK(new_master_entry_url_.is_valid()); AssociateCache(NULL); // The UpdateJob may produce one for us later. group->StartUpdateWithNewMasterEntry(this, new_master_entry_url_); diff --git a/webkit/appcache/appcache_storage_impl.cc b/webkit/appcache/appcache_storage_impl.cc index 579a6bf..cfa3be9 100644 --- a/webkit/appcache/appcache_storage_impl.cc +++ b/webkit/appcache/appcache_storage_impl.cc @@ -583,6 +583,11 @@ void AppCacheStorageImpl::MakeGroupObsoleteTask::RunCompleted() { if (success_) { storage_->origins_with_groups_.swap(origins_with_groups_); group_->set_obsolete(true); + + // Also remove from the working set, caches for an 'obsolete' group + // may linger in use, but the group itself cannot be looked up by + // 'manifest_url' in the working set any longer. + storage_->working_set()->RemoveGroup(group_); } FOR_EACH_DELEGATE(delegates_, OnGroupMadeObsolete(group_, success_)); group_ = NULL; diff --git a/webkit/appcache/appcache_update_job.cc b/webkit/appcache/appcache_update_job.cc index dbd763f8..fbe79ff 100644 --- a/webkit/appcache/appcache_update_job.cc +++ b/webkit/appcache/appcache_update_job.cc @@ -133,6 +133,7 @@ AppCacheUpdateJob::~AppCacheUpdateJob() { void AppCacheUpdateJob::StartUpdate(AppCacheHost* host, const GURL& new_master_resource) { DCHECK(group_->update_job() == this); + DCHECK(!group_->is_obsolete()); bool is_new_pending_master_entry = false; if (!new_master_resource.is_empty()) { diff --git a/webkit/appcache/mock_appcache_storage.cc b/webkit/appcache/mock_appcache_storage.cc index 44bcd12..64a66a7 100644 --- a/webkit/appcache/mock_appcache_storage.cc +++ b/webkit/appcache/mock_appcache_storage.cc @@ -359,6 +359,11 @@ void MockAppCacheStorage::ProcessMakeGroupObsolete( group->set_obsolete(true); + // Also remove from the working set, caches for an 'obsolete' group + // may linger in use, but the group itself cannot be looked up by + // 'manifest_url' in the working set any longer. + working_set()->RemoveGroup(group); + if (delegate_ref->delegate) delegate_ref->delegate->OnGroupMadeObsolete(group, true); } @@ -406,10 +411,6 @@ void MockAppCacheStorage::AddStoredGroup(AppCacheGroup* group) { } void MockAppCacheStorage::RemoveStoredGroup(AppCacheGroup* group) { - // Also remove from the working set, caches for an 'obsolete' group - // may linger in use, but the group itself cannot be looked up by - // 'manifest_url' in the working set any longer. - working_set()->RemoveGroup(group); stored_groups_.erase(group->manifest_url()); } |