summaryrefslogtreecommitdiffstats
path: root/webkit/appcache
diff options
context:
space:
mode:
Diffstat (limited to 'webkit/appcache')
-rw-r--r--webkit/appcache/appcache_frontend_impl.cc12
-rw-r--r--webkit/appcache/appcache_frontend_impl.h2
-rw-r--r--webkit/appcache/appcache_group_unittest.cc4
-rw-r--r--webkit/appcache/appcache_host.cc6
-rw-r--r--webkit/appcache/appcache_host_unittest.cc5
-rw-r--r--webkit/appcache/appcache_interfaces.h2
-rw-r--r--webkit/appcache/appcache_request_handler_unittest.cc3
-rw-r--r--webkit/appcache/appcache_update_job.cc150
-rw-r--r--webkit/appcache/appcache_update_job.h10
-rw-r--r--webkit/appcache/appcache_update_job_unittest.cc5
-rw-r--r--webkit/appcache/web_application_cache_host_impl.cc37
-rw-r--r--webkit/appcache/web_application_cache_host_impl.h1
12 files changed, 156 insertions, 81 deletions
diff --git a/webkit/appcache/appcache_frontend_impl.cc b/webkit/appcache/appcache_frontend_impl.cc
index 5f490f3..812ae69 100644
--- a/webkit/appcache/appcache_frontend_impl.cc
+++ b/webkit/appcache/appcache_frontend_impl.cc
@@ -34,6 +34,7 @@ void AppCacheFrontendImpl::OnStatusChanged(const std::vector<int>& host_ids,
void AppCacheFrontendImpl::OnEventRaised(const std::vector<int>& host_ids,
EventID event_id) {
DCHECK(event_id != PROGRESS_EVENT); // See OnProgressEventRaised.
+ DCHECK(event_id != ERROR_EVENT); // See OnErrorEventRaised.
for (std::vector<int>::const_iterator i = host_ids.begin();
i != host_ids.end(); ++i) {
WebApplicationCacheHostImpl* host = GetHost(*i);
@@ -53,6 +54,17 @@ void AppCacheFrontendImpl::OnProgressEventRaised(
}
}
+void AppCacheFrontendImpl::OnErrorEventRaised(
+ const std::vector<int>& host_ids,
+ const std::string& message) {
+ for (std::vector<int>::const_iterator i = host_ids.begin();
+ i != host_ids.end(); ++i) {
+ WebApplicationCacheHostImpl* host = GetHost(*i);
+ if (host)
+ host->OnErrorEventRaised(message);
+ }
+}
+
void AppCacheFrontendImpl::OnLogMessage(int host_id, LogLevel log_level,
const std::string& message) {
WebApplicationCacheHostImpl* host = GetHost(host_id);
diff --git a/webkit/appcache/appcache_frontend_impl.h b/webkit/appcache/appcache_frontend_impl.h
index e5852c7..e05dcb7 100644
--- a/webkit/appcache/appcache_frontend_impl.h
+++ b/webkit/appcache/appcache_frontend_impl.h
@@ -21,6 +21,8 @@ class AppCacheFrontendImpl : public AppCacheFrontend {
virtual void OnProgressEventRaised(const std::vector<int>& host_ids,
const GURL& url,
int num_total, int num_complete);
+ virtual void OnErrorEventRaised(const std::vector<int>& host_ids,
+ const std::string& message);
virtual void OnLogMessage(int host_id, LogLevel log_level,
const std::string& message);
virtual void OnContentBlocked(int host_id, const GURL& manifest_url);
diff --git a/webkit/appcache/appcache_group_unittest.cc b/webkit/appcache/appcache_group_unittest.cc
index 0f3f0b7..2c6ed14 100644
--- a/webkit/appcache/appcache_group_unittest.cc
+++ b/webkit/appcache/appcache_group_unittest.cc
@@ -33,6 +33,10 @@ class TestAppCacheFrontend : public appcache::AppCacheFrontend {
appcache::EventID event_id) {
}
+ virtual void OnErrorEventRaised(const std::vector<int>& host_ids,
+ const std::string& message) {
+ }
+
virtual void OnProgressEventRaised(const std::vector<int>& host_ids,
const GURL& url,
int num_total, int num_complete) {
diff --git a/webkit/appcache/appcache_host.cc b/webkit/appcache/appcache_host.cc
index 7b9e58d..c4e8b62 100644
--- a/webkit/appcache/appcache_host.cc
+++ b/webkit/appcache/appcache_host.cc
@@ -317,7 +317,7 @@ void AppCacheHost::FinishCacheSelection(
DCHECK(new_master_entry_url_.is_empty());
AppCacheGroup* owing_group = cache->owning_group();
const char* kFormatString =
- "Document was loaded from appcache with manifest %s";
+ "Document was loaded from Application Cache with manifest %s";
frontend_->OnLogMessage(
host_id_, LOG_INFO,
StringPrintf(
@@ -336,8 +336,8 @@ void AppCacheHost::FinishCacheSelection(
DCHECK(!group->is_obsolete());
DCHECK(new_master_entry_url_.is_valid());
const char* kFormatString = group->HasCache() ?
- "Adding master entry to appcache with manifest %s" :
- "Creating appcache with manifest %s";
+ "Adding master entry to Application Cache with manifest %s" :
+ "Creating Application Cache with manifest %s";
frontend_->OnLogMessage(
host_id_, LOG_INFO,
StringPrintf(kFormatString, group->manifest_url().spec().c_str()));
diff --git a/webkit/appcache/appcache_host_unittest.cc b/webkit/appcache/appcache_host_unittest.cc
index b3dc951..0671eb7 100644
--- a/webkit/appcache/appcache_host_unittest.cc
+++ b/webkit/appcache/appcache_host_unittest.cc
@@ -51,6 +51,11 @@ class AppCacheHostTest : public testing::Test {
last_event_id_ = event_id;
}
+ virtual void OnErrorEventRaised(const std::vector<int>& host_ids,
+ const std::string& message) {
+ last_event_id_ = ERROR_EVENT;
+ }
+
virtual void OnProgressEventRaised(const std::vector<int>& host_ids,
const GURL& url,
int num_total, int num_complete) {
diff --git a/webkit/appcache/appcache_interfaces.h b/webkit/appcache/appcache_interfaces.h
index 2ff2da7..1956135 100644
--- a/webkit/appcache/appcache_interfaces.h
+++ b/webkit/appcache/appcache_interfaces.h
@@ -63,6 +63,8 @@ class AppCacheFrontend {
virtual void OnProgressEventRaised(const std::vector<int>& host_ids,
const GURL& url,
int num_total, int num_complete) = 0;
+ virtual void OnErrorEventRaised(const std::vector<int>& host_ids,
+ const std::string& message) = 0;
virtual void OnContentBlocked(int host_id,
const GURL& manifest_url) = 0;
virtual void OnLogMessage(int host_id, LogLevel log_level,
diff --git a/webkit/appcache/appcache_request_handler_unittest.cc b/webkit/appcache/appcache_request_handler_unittest.cc
index db1eda7..d2c7c9e 100644
--- a/webkit/appcache/appcache_request_handler_unittest.cc
+++ b/webkit/appcache/appcache_request_handler_unittest.cc
@@ -32,6 +32,9 @@ class AppCacheRequestHandlerTest : public testing::Test {
virtual void OnEventRaised(const std::vector<int>& host_ids,
appcache::EventID event_id) {}
+ virtual void OnErrorEventRaised(const std::vector<int>& host_ids,
+ const std::string& message) {}
+
virtual void OnProgressEventRaised(const std::vector<int>& host_ids,
const GURL& url,
int num_total, int num_complete) {}
diff --git a/webkit/appcache/appcache_update_job.cc b/webkit/appcache/appcache_update_job.cc
index 5bd7d42..9a2d729 100644
--- a/webkit/appcache/appcache_update_job.cc
+++ b/webkit/appcache/appcache_update_job.cc
@@ -106,6 +106,15 @@ class HostNotifier {
}
}
+ void SendErrorNotifications(const std::string& error_message) {
+ DCHECK(!error_message.empty());
+ for (NotifyHostMap::iterator it = hosts_to_notify.begin();
+ it != hosts_to_notify.end(); ++it) {
+ AppCacheFrontend* frontend = it->first;
+ frontend->OnErrorEventRaised(it->second, error_message);
+ }
+ }
+
private:
NotifyHostMap hosts_to_notify;
};
@@ -236,20 +245,25 @@ void AppCacheUpdateJob::OnPolicyCheckComplete(int rv) {
group_->NotifyContentBlocked();
+ const char* kErrorMessage =
+ "Cache creation was blocked by the content policy";
MessageLoop::current()->PostTask(FROM_HERE,
method_factory_.NewRunnableMethod(
- &AppCacheUpdateJob::HandleCacheFailure));
+ &AppCacheUpdateJob::HandleCacheFailure,
+ kErrorMessage));
}
-void AppCacheUpdateJob::HandleCacheFailure() {
- // TODO(michaeln): For now this is only invoked from one point
- // of failure. Overtime, attempt the migrate the various places
- // where we can detect a failure condition to use this same
- // method to enter the cache_failure state.
+void AppCacheUpdateJob::HandleCacheFailure(const std::string& error_message) {
+ // 6.9.4 cache failure steps 2-8.
+ DCHECK(internal_state_ != CACHE_FAILURE);
+ DCHECK(!error_message.empty());
internal_state_ = CACHE_FAILURE;
CancelAllUrlFetches();
- CancelAllMasterEntryFetches();
- MaybeCompleteUpdate();
+ CancelAllMasterEntryFetches(error_message);
+ NotifyAllError(error_message);
+ DiscardInprogressCache();
+ internal_state_ = COMPLETED;
+ DeleteSoon(); // To unwind the stack prior to deletion.
}
void AppCacheUpdateJob::FetchManifest(bool is_first_fetch) {
@@ -512,25 +526,26 @@ void AppCacheUpdateJob::HandleManifestFetchCompleted(URLRequest* request) {
} else if (response_code == 404 || response_code == 410) {
service_->storage()->MakeGroupObsolete(group_, this); // async
} else {
- internal_state_ = CACHE_FAILURE;
- CancelAllMasterEntryFetches();
- MaybeCompleteUpdate(); // if not done, run async cache failure steps
+ const char* kFormatString = "Manifest fetch failed (%d) %s";
+ const std::string message = StringPrintf(kFormatString, response_code,
+ manifest_url_.spec().c_str());
+ HandleCacheFailure(message);
}
}
void AppCacheUpdateJob::OnGroupMadeObsolete(AppCacheGroup* group,
bool success) {
DCHECK(master_entry_fetches_.empty());
- CancelAllMasterEntryFetches();
+ CancelAllMasterEntryFetches("The group has been made obsolete");
if (success) {
DCHECK(group->is_obsolete());
NotifyAllAssociatedHosts(OBSOLETE_EVENT);
internal_state_ = COMPLETED;
+ MaybeCompleteUpdate();
} else {
// Treat failure to mark group obsolete as a cache failure.
- internal_state_ = CACHE_FAILURE;
+ HandleCacheFailure("Failed to make the group as obsolete");
}
- MaybeCompleteUpdate();
}
void AppCacheUpdateJob::ContinueHandleManifestFetchCompleted(bool changed) {
@@ -549,10 +564,11 @@ void AppCacheUpdateJob::ContinueHandleManifestFetchCompleted(bool changed) {
Manifest manifest;
if (!ParseManifest(manifest_url_, manifest_data_.data(),
manifest_data_.length(), manifest)) {
- LOG(INFO) << "Failed to parse manifest: " << manifest_url_;
- internal_state_ = CACHE_FAILURE;
- CancelAllMasterEntryFetches();
- MaybeCompleteUpdate(); // if not done, run async cache failure steps
+ const char* kFormatString = "Failed to parse manifest %s";
+ const std::string message = StringPrintf(kFormatString,
+ manifest_url_.spec().c_str());
+ HandleCacheFailure(message);
+ LOG(INFO) << message;
return;
}
@@ -585,7 +601,7 @@ void AppCacheUpdateJob::HandleUrlFetchCompleted(URLRequest* request) {
const GURL& url = request->original_url();
pending_url_fetches_.erase(url);
- NotifyProgress(url);
+ NotifyAllProgress(url);
++url_fetches_completed_;
int response_code = request->status().is_success()
@@ -613,9 +629,11 @@ void AppCacheUpdateJob::HandleUrlFetchCompleted(URLRequest* request) {
<< " os_error: " << request->status().os_error()
<< " response code: " << response_code;
if (entry.IsExplicit() || entry.IsFallback()) {
- internal_state_ = CACHE_FAILURE;
- CancelAllUrlFetches();
- CancelAllMasterEntryFetches();
+ const char* kFormatString = "Resource fetch failed (%d) %s";
+ const std::string message = StringPrintf(kFormatString, response_code,
+ request->url().spec().c_str());
+ HandleCacheFailure(message);
+ return;
} else if (response_code == 404 || response_code == 410) {
// Entry is skipped. They are dropped from the cache.
} else if (update_type_ == UPGRADE_ATTEMPT) {
@@ -631,9 +649,8 @@ void AppCacheUpdateJob::HandleUrlFetchCompleted(URLRequest* request) {
}
// Fetch another URL now that one request has completed.
- if (internal_state_ != CACHE_FAILURE)
- FetchUrls();
-
+ DCHECK(internal_state_ != CACHE_FAILURE);
+ FetchUrls();
MaybeCompleteUpdate();
}
@@ -693,7 +710,11 @@ void AppCacheUpdateJob::HandleMasterEntryFetchCompleted(URLRequest* request) {
host->RemoveObserver(this);
}
hosts.clear();
- host_notifier.SendNotifications(ERROR_EVENT);
+
+ const char* kFormatString = "Master entry fetch failed (%d) %s";
+ const std::string message = StringPrintf(kFormatString, response_code,
+ request->url().spec().c_str());
+ host_notifier.SendErrorNotifications(message);
// In downloading case, update result is different if all master entries
// failed vs. only some failing.
@@ -704,15 +725,14 @@ void AppCacheUpdateJob::HandleMasterEntryFetchCompleted(URLRequest* request) {
// Section 6.9.4, step 22.3.
if (update_type_ == CACHE_ATTEMPT && pending_master_entries_.empty()) {
- CancelAllUrlFetches();
- internal_state_ = CACHE_FAILURE;
+ HandleCacheFailure(message);
+ return;
}
}
}
- if (internal_state_ != CACHE_FAILURE)
- FetchMasterEntries();
-
+ DCHECK(internal_state_ != CACHE_FAILURE);
+ FetchMasterEntries();
MaybeCompleteUpdate();
}
@@ -743,8 +763,7 @@ void AppCacheUpdateJob::HandleManifestRefetchCompleted(URLRequest* request) {
<< " os_error: " << request->status().os_error()
<< " response code: " << response_code;
ScheduleUpdateRetry(kRerunDelayMs);
- internal_state_ = CACHE_FAILURE;
- MaybeCompleteUpdate(); // will definitely complete
+ HandleCacheFailure("Manifest changed during update, scheduling retry");
}
}
@@ -755,8 +774,7 @@ void AppCacheUpdateJob::OnManifestInfoWriteComplete(int result) {
manifest_response_writer_->WriteData(io_buffer, manifest_data_.length(),
&manifest_data_write_callback_);
} else {
- internal_state_ = CACHE_FAILURE;
- MaybeCompleteUpdate(); // will definitely complete
+ HandleCacheFailure("Failed to write the manifest headers to storage");
}
}
@@ -769,8 +787,7 @@ void AppCacheUpdateJob::OnManifestDataWriteComplete(int result) {
duplicate_response_ids_.push_back(entry.response_id());
StoreGroupAndCache();
} else {
- internal_state_ = CACHE_FAILURE;
- MaybeCompleteUpdate(); // will definitely complete
+ HandleCacheFailure("Failed to write the manifest data to storage");
}
}
@@ -793,15 +810,15 @@ void AppCacheUpdateJob::OnGroupAndNewestCacheStored(AppCacheGroup* group,
DCHECK(stored_state_ == STORING);
if (success) {
stored_state_ = STORED;
+ MaybeCompleteUpdate(); // will definitely complete
} else {
- internal_state_ = CACHE_FAILURE;
-
// Restore inprogress_cache_ to get the proper events delivered
// and the proper cleanup to occur.
if (newest_cache != group->newest_complete_cache())
inprogress_cache_ = newest_cache;
+
+ HandleCacheFailure("Failed to commit new cache to storage");
}
- MaybeCompleteUpdate(); // will definitely complete
}
void AppCacheUpdateJob::NotifySingleHost(AppCacheHost* host,
@@ -810,39 +827,28 @@ void AppCacheUpdateJob::NotifySingleHost(AppCacheHost* host,
host->frontend()->OnEventRaised(ids, event_id);
}
-void AppCacheUpdateJob::NotifyAllPendingMasterHosts(EventID event_id) {
- // Collect hosts so we only send one notification per frontend.
- // A host can only be associated with a single pending master entry
- // so no need to worry about duplicate hosts being added to the notifier.
- HostNotifier host_notifier;
- for (PendingMasters::iterator it = pending_master_entries_.begin();
- it != pending_master_entries_.end(); ++it) {
- PendingHosts& hosts = it->second;
- for (PendingHosts::iterator host_it = hosts.begin();
- host_it != hosts.end(); ++host_it) {
- host_notifier.AddHost(*host_it);
- }
- }
-
- host_notifier.SendNotifications(event_id);
-}
-
void AppCacheUpdateJob::NotifyAllAssociatedHosts(EventID event_id) {
HostNotifier host_notifier;
AddAllAssociatedHostsToNotifier(&host_notifier);
host_notifier.SendNotifications(event_id);
}
-void AppCacheUpdateJob::NotifyProgress(const GURL& url) {
+void AppCacheUpdateJob::NotifyAllProgress(const GURL& url) {
HostNotifier host_notifier;
AddAllAssociatedHostsToNotifier(&host_notifier);
host_notifier.SendProgressNotifications(
url, url_file_list_.size(), url_fetches_completed_);
}
-void AppCacheUpdateJob::NotifyFinalProgress() {
+void AppCacheUpdateJob::NotifyAllFinalProgress() {
DCHECK(url_file_list_.size() == url_fetches_completed_);
- NotifyProgress(GURL());
+ NotifyAllProgress(GURL());
+}
+
+void AppCacheUpdateJob::NotifyAllError(const std::string& error_message) {
+ HostNotifier host_notifier;
+ AddAllAssociatedHostsToNotifier(&host_notifier);
+ host_notifier.SendErrorNotifications(error_message);
}
void AppCacheUpdateJob::AddAllAssociatedHostsToNotifier(
@@ -958,10 +964,10 @@ void AppCacheUpdateJob::FetchUrls() {
DCHECK(it != url_file_list_.end());
AppCacheEntry& entry = it->second;
if (ShouldSkipUrlFetch(entry)) {
- NotifyProgress(url);
+ NotifyAllProgress(url);
++url_fetches_completed_;
} else if (AlreadyFetchedEntry(url, entry.types())) {
- NotifyProgress(url);
+ NotifyAllProgress(url);
++url_fetches_completed_; // saved a URL request
} else if (!storage_checked && MaybeLoadFromNewestCache(url, entry)) {
// Continues asynchronously after data is loaded from newest cache.
@@ -1089,7 +1095,8 @@ void AppCacheUpdateJob::FetchMasterEntries() {
}
}
-void AppCacheUpdateJob::CancelAllMasterEntryFetches() {
+void AppCacheUpdateJob::CancelAllMasterEntryFetches(
+ const std::string& error_message) {
// For now, cancel all in-progress fetches for master entries and pretend
// all master entries fetches have completed.
// TODO(jennb): Delete this when update no longer fetches master entries
@@ -1125,7 +1132,7 @@ void AppCacheUpdateJob::CancelAllMasterEntryFetches() {
master_entries_to_fetch_.erase(master_entries_to_fetch_.begin());
}
- host_notifier.SendNotifications(ERROR_EVENT);
+ host_notifier.SendErrorNotifications(error_message);
}
bool AppCacheUpdateJob::MaybeLoadFromNewestCache(const GURL& url,
@@ -1174,6 +1181,7 @@ void AppCacheUpdateJob::OnResponseInfoLoaded(
http_info->response_time,
base::Time::Now()) ||
http_info->headers->EnumerateHeader(&iter, name, &value)) {
+ // TODO(michaeln): Make a conditional request when we can in this case.
LoadFromNewestCacheFailed(url);
} else {
DCHECK(group_->newest_complete_cache());
@@ -1187,7 +1195,7 @@ void AppCacheUpdateJob::OnResponseInfoLoaded(
entry.set_response_id(response_id);
entry.set_response_size(copy_me->response_size());
inprogress_cache_->AddOrModifyEntry(url, entry);
- NotifyProgress(url);
+ NotifyAllProgress(url);
++url_fetches_completed_;
}
}
@@ -1206,6 +1214,8 @@ void AppCacheUpdateJob::LoadFromNewestCacheFailed(const GURL& url) {
}
void AppCacheUpdateJob::MaybeCompleteUpdate() {
+ DCHECK(internal_state_ != CACHE_FAILURE);
+
// Must wait for any pending master entries or url fetches to complete.
if (master_entries_completed_ != pending_master_entries_.size() ||
url_fetches_completed_ != url_file_list_.size()) {
@@ -1237,7 +1247,7 @@ void AppCacheUpdateJob::MaybeCompleteUpdate() {
break;
case REFETCH_MANIFEST:
DCHECK(stored_state_ == STORED);
- NotifyFinalProgress();
+ NotifyAllFinalProgress();
if (update_type_ == CACHE_ATTEMPT)
NotifyAllAssociatedHosts(CACHED_EVENT);
else
@@ -1246,13 +1256,7 @@ void AppCacheUpdateJob::MaybeCompleteUpdate() {
internal_state_ = COMPLETED;
break;
case CACHE_FAILURE:
- // 6.9.4 cache failure steps 2-8.
- NotifyAllAssociatedHosts(ERROR_EVENT);
- DiscardInprogressCache();
- // For a CACHE_ATTEMPT, group will be discarded when the host(s) that
- // started this update removes its reference to the group. Nothing more
- // to do here.
- internal_state_ = COMPLETED;
+ NOTREACHED(); // See HandleCacheFailure
break;
default:
break;
diff --git a/webkit/appcache/appcache_update_job.h b/webkit/appcache/appcache_update_job.h
index 8dc7fb3..d9c1669 100644
--- a/webkit/appcache/appcache_update_job.h
+++ b/webkit/appcache/appcache_update_job.h
@@ -104,7 +104,7 @@ class AppCacheUpdateJob : public URLRequest::Delegate,
void CheckPolicy();
void OnPolicyCheckComplete(int rv);
- void HandleCacheFailure();
+ void HandleCacheFailure(const std::string& error_message);
void FetchManifest(bool is_first_fetch);
@@ -143,10 +143,10 @@ class AppCacheUpdateJob : public URLRequest::Delegate,
void StoreGroupAndCache();
void NotifySingleHost(AppCacheHost* host, EventID event_id);
- void NotifyAllPendingMasterHosts(EventID event_id);
void NotifyAllAssociatedHosts(EventID event_id);
- void NotifyProgress(const GURL& url);
- void NotifyFinalProgress();
+ void NotifyAllProgress(const GURL& url);
+ void NotifyAllFinalProgress();
+ void NotifyAllError(const std::string& error_message);
void AddAllAssociatedHostsToNotifier(HostNotifier* notifier);
// Checks if manifest is byte for byte identical with the manifest
@@ -173,7 +173,7 @@ class AppCacheUpdateJob : public URLRequest::Delegate,
void AddMasterEntryToFetchList(AppCacheHost* host, const GURL& url,
bool is_new);
void FetchMasterEntries();
- void CancelAllMasterEntryFetches();
+ void CancelAllMasterEntryFetches(const std::string& error_message);
// Asynchronously loads the entry from the newest complete cache if the
// HTTP caching semantics allow.
diff --git a/webkit/appcache/appcache_update_job_unittest.cc b/webkit/appcache/appcache_update_job_unittest.cc
index e75175d..f90eb87 100644
--- a/webkit/appcache/appcache_update_job_unittest.cc
+++ b/webkit/appcache/appcache_update_job_unittest.cc
@@ -186,6 +186,11 @@ class MockFrontend : public AppCacheFrontend {
}
}
+ virtual void OnErrorEventRaised(const std::vector<int>& host_ids,
+ const std::string& message) {
+ OnEventRaised(host_ids, ERROR_EVENT);
+ }
+
virtual void OnProgressEventRaised(const std::vector<int>& host_ids,
const GURL& url,
int num_total, int num_complete) {
diff --git a/webkit/appcache/web_application_cache_host_impl.cc b/webkit/appcache/web_application_cache_host_impl.cc
index 8e7d37d..5b2dead 100644
--- a/webkit/appcache/web_application_cache_host_impl.cc
+++ b/webkit/appcache/web_application_cache_host_impl.cc
@@ -26,6 +26,13 @@ namespace appcache {
typedef IDMap<WebApplicationCacheHostImpl> HostsMap;
+// Note: the order of the elements in this array must match those
+// of the EventID enum in appcache_interfaces.h.
+static const char* kEventNames[] = {
+ "Checking", "Error", "NoUpdate", "Downloading", "Progress",
+ "UpdateReady", "Cached", "Obsolete"
+};
+
static HostsMap* all_hosts() {
return Singleton<HostsMap>::get();
}
@@ -81,6 +88,14 @@ void WebApplicationCacheHostImpl::OnStatusChanged(appcache::Status status) {
void WebApplicationCacheHostImpl::OnEventRaised(appcache::EventID event_id) {
DCHECK(event_id != PROGRESS_EVENT); // See OnProgressEventRaised.
+ DCHECK(event_id != ERROR_EVENT); // See OnErrorEventRaised.
+
+ // Emit logging output prior to calling out to script as we can get
+ // deleted within the script event handler.
+ const char* kFormatString = "Application Cache %s event";
+ std::string message = StringPrintf(kFormatString, 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;
@@ -90,9 +105,31 @@ void WebApplicationCacheHostImpl::OnEventRaised(appcache::EventID event_id) {
void WebApplicationCacheHostImpl::OnProgressEventRaised(
const GURL& url, int num_total, int num_complete) {
+ // Emit logging output prior to calling out to script as we can get
+ // deleted within the script event handler.
+ const char* kFormatString = "Application Cache Progress event (%d of %d) %s";
+ std::string message = StringPrintf(kFormatString, num_complete,
+ num_total, url.spec().c_str());
+ OnLogMessage(LOG_INFO, message);
+
client_->notifyProgressEventListener(url, num_total, num_complete);
}
+void WebApplicationCacheHostImpl::OnErrorEventRaised(
+ const std::string& message) {
+ // Emit logging output prior to calling out to script as we can get
+ // deleted within the script event handler.
+ const char* kFormatString = "Application Cache Error event: %s";
+ std::string full_message = StringPrintf(kFormatString, 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;
+ client_->notifyEventListener(static_cast<EventID>(ERROR_EVENT));
+}
+
void WebApplicationCacheHostImpl::willStartMainResourceRequest(
WebURLRequest& request) {
request.setAppCacheHostID(host_id_);
diff --git a/webkit/appcache/web_application_cache_host_impl.h b/webkit/appcache/web_application_cache_host_impl.h
index 17d66d7..be088b1 100644
--- a/webkit/appcache/web_application_cache_host_impl.h
+++ b/webkit/appcache/web_application_cache_host_impl.h
@@ -35,6 +35,7 @@ class WebApplicationCacheHostImpl : public WebKit::WebApplicationCacheHost {
void OnStatusChanged(appcache::Status);
void OnEventRaised(appcache::EventID);
void OnProgressEventRaised(const GURL& url, int num_total, int num_complete);
+ void OnErrorEventRaised(const std::string& message);
virtual void OnLogMessage(LogLevel log_level, const std::string& message) {}
virtual void OnContentBlocked(const GURL& manifest_url) {}
virtual void OnCacheSelected(int64 selected_cache_id,