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

Side by Side Diff: content/renderer/service_worker/embedded_worker_context_client.cc

Issue 127573002: Add basic browser test for EmbeddedWorker/ServiceWorker (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: copyright fix Created 6 years, 11 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 | Annotate | Revision Log
« no previous file with comments | « content/public/browser/storage_partition.h ('k') | content/test/data/service_worker/index.html » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "content/renderer/service_worker/embedded_worker_context_client.h" 5 #include "content/renderer/service_worker/embedded_worker_context_client.h"
6 6
7 #include "base/lazy_instance.h" 7 #include "base/lazy_instance.h"
8 #include "base/message_loop/message_loop_proxy.h" 8 #include "base/message_loop/message_loop_proxy.h"
9 #include "base/pickle.h" 9 #include "base/pickle.h"
10 #include "base/threading/thread_local.h" 10 #include "base/threading/thread_local.h"
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
46 EmbeddedWorkerContextClient::EmbeddedWorkerContextClient( 46 EmbeddedWorkerContextClient::EmbeddedWorkerContextClient(
47 int embedded_worker_id, 47 int embedded_worker_id,
48 int64 service_worker_version_id, 48 int64 service_worker_version_id,
49 const GURL& script_url) 49 const GURL& script_url)
50 : embedded_worker_id_(embedded_worker_id), 50 : embedded_worker_id_(embedded_worker_id),
51 service_worker_version_id_(service_worker_version_id), 51 service_worker_version_id_(service_worker_version_id),
52 script_url_(script_url), 52 script_url_(script_url),
53 sender_(ChildThread::current()->thread_safe_sender()), 53 sender_(ChildThread::current()->thread_safe_sender()),
54 main_thread_proxy_(base::MessageLoopProxy::current()), 54 main_thread_proxy_(base::MessageLoopProxy::current()),
55 proxy_(NULL) { 55 proxy_(NULL) {
56 g_worker_client_tls.Pointer()->Set(this);
56 } 57 }
57 58
58 EmbeddedWorkerContextClient::~EmbeddedWorkerContextClient() { 59 EmbeddedWorkerContextClient::~EmbeddedWorkerContextClient() {
59 DCHECK(g_worker_client_tls.Pointer()->Get() != NULL); 60 DCHECK(g_worker_client_tls.Pointer()->Get() != NULL);
60 g_worker_client_tls.Pointer()->Set(NULL); 61 g_worker_client_tls.Pointer()->Set(NULL);
61 } 62 }
62 63
63 bool EmbeddedWorkerContextClient::OnMessageReceived( 64 bool EmbeddedWorkerContextClient::OnMessageReceived(
64 const IPC::Message& msg) { 65 const IPC::Message& msg) {
65 bool handled = true; 66 bool handled = true;
(...skipping 18 matching lines...) Expand all
84 DCHECK(g_worker_client_tls.Pointer()->Get() == NULL); 85 DCHECK(g_worker_client_tls.Pointer()->Get() == NULL);
85 g_worker_client_tls.Pointer()->Set(this); 86 g_worker_client_tls.Pointer()->Set(this);
86 proxy_ = proxy; 87 proxy_ = proxy;
87 88
88 sender_->Send(new EmbeddedWorkerHostMsg_WorkerStarted( 89 sender_->Send(new EmbeddedWorkerHostMsg_WorkerStarted(
89 WorkerTaskRunner::Instance()->CurrentWorkerId(), 90 WorkerTaskRunner::Instance()->CurrentWorkerId(),
90 embedded_worker_id_)); 91 embedded_worker_id_));
91 } 92 }
92 93
93 void EmbeddedWorkerContextClient::workerContextDestroyed() { 94 void EmbeddedWorkerContextClient::workerContextDestroyed() {
94 DCHECK_NE(0, WorkerTaskRunner::Instance()->CurrentWorkerId()); 95 // At this point OnWorkerRunLoopStopped is already called, so
96 // CurrentWorkerId() returns 0 (while we're still on the worker thread).
95 proxy_ = NULL; 97 proxy_ = NULL;
96 main_thread_proxy_->PostTask( 98 main_thread_proxy_->PostTask(
97 FROM_HERE, 99 FROM_HERE,
98 base::Bind(&CallWorkerContextDestroyedOnMainThread, 100 base::Bind(&CallWorkerContextDestroyedOnMainThread,
99 embedded_worker_id_)); 101 embedded_worker_id_));
100 } 102 }
101 103
102 void EmbeddedWorkerContextClient::OnFetchEvent( 104 void EmbeddedWorkerContextClient::OnFetchEvent(
103 int thread_id, 105 int thread_id,
104 int embedded_worker_id, 106 int embedded_worker_id,
105 const ServiceWorkerFetchRequest& request) { 107 const ServiceWorkerFetchRequest& request) {
106 // TODO(kinuko): Implement. 108 // TODO(kinuko): Implement.
107 // This is to call WebServiceWorkerContextProxy's dispatchFetchEvent method. 109 // This is to call WebServiceWorkerContextProxy's dispatchFetchEvent method.
108 NOTIMPLEMENTED(); 110 NOTIMPLEMENTED();
109 } 111 }
110 112
111 } // namespace content 113 } // namespace content
OLDNEW
« no previous file with comments | « content/public/browser/storage_partition.h ('k') | content/test/data/service_worker/index.html » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698