OLD | NEW |
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 <map> | 7 #include <map> |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/debug/trace_event.h" | 10 #include "base/debug/trace_event.h" |
(...skipping 162 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
173 worker_task_runner_ = new WorkerThreadTaskRunner( | 173 worker_task_runner_ = new WorkerThreadTaskRunner( |
174 WorkerTaskRunner::Instance()->CurrentWorkerId()); | 174 WorkerTaskRunner::Instance()->CurrentWorkerId()); |
175 DCHECK_NE(0, WorkerTaskRunner::Instance()->CurrentWorkerId()); | 175 DCHECK_NE(0, WorkerTaskRunner::Instance()->CurrentWorkerId()); |
176 // g_worker_client_tls.Pointer()->Get() could return NULL if this context | 176 // g_worker_client_tls.Pointer()->Get() could return NULL if this context |
177 // gets deleted before workerContextStarted() is called. | 177 // gets deleted before workerContextStarted() is called. |
178 DCHECK(g_worker_client_tls.Pointer()->Get() == NULL); | 178 DCHECK(g_worker_client_tls.Pointer()->Get() == NULL); |
179 DCHECK(!script_context_); | 179 DCHECK(!script_context_); |
180 g_worker_client_tls.Pointer()->Set(this); | 180 g_worker_client_tls.Pointer()->Set(this); |
181 script_context_.reset(new ServiceWorkerScriptContext(this, proxy)); | 181 script_context_.reset(new ServiceWorkerScriptContext(this, proxy)); |
182 | 182 |
183 // This can be nullptr on EmbeddedWorkerBrowserTests. | 183 SetRegistrationInServiceWorkerGlobalScope(); |
184 // TODO(nhiroki): Remove this workaround. |registration()| should always be | |
185 // valid other than the test because the registration association message | |
186 // arrives before starting the worker context. | |
187 if (provider_context_->registration()) | |
188 SetRegistrationInServiceWorkerGlobalScope(); | |
189 | 184 |
190 Send(new EmbeddedWorkerHostMsg_WorkerScriptLoaded( | 185 Send(new EmbeddedWorkerHostMsg_WorkerScriptLoaded( |
191 embedded_worker_id_, | 186 embedded_worker_id_, |
192 WorkerTaskRunner::Instance()->CurrentWorkerId())); | 187 WorkerTaskRunner::Instance()->CurrentWorkerId())); |
193 | 188 |
194 // Schedule a task to send back WorkerStarted asynchronously, | 189 // Schedule a task to send back WorkerStarted asynchronously, |
195 // so that at the time we send it we can be sure that the worker | 190 // so that at the time we send it we can be sure that the worker |
196 // script has been evaluated and worker run loop has been started. | 191 // script has been evaluated and worker run loop has been started. |
197 worker_task_runner_->PostTask( | 192 worker_task_runner_->PostTask( |
198 FROM_HERE, | 193 FROM_HERE, |
(...skipping 213 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
412 "EmbeddedWorkerContextClient::StartingWorkerContext", | 407 "EmbeddedWorkerContextClient::StartingWorkerContext", |
413 this); | 408 this); |
414 Send(new EmbeddedWorkerHostMsg_WorkerStarted(embedded_worker_id_)); | 409 Send(new EmbeddedWorkerHostMsg_WorkerStarted(embedded_worker_id_)); |
415 } | 410 } |
416 | 411 |
417 void EmbeddedWorkerContextClient::SetRegistrationInServiceWorkerGlobalScope() { | 412 void EmbeddedWorkerContextClient::SetRegistrationInServiceWorkerGlobalScope() { |
418 DCHECK(worker_task_runner_->RunsTasksOnCurrentThread()); | 413 DCHECK(worker_task_runner_->RunsTasksOnCurrentThread()); |
419 DCHECK(provider_context_); | 414 DCHECK(provider_context_); |
420 DCHECK(script_context_); | 415 DCHECK(script_context_); |
421 | 416 |
| 417 ServiceWorkerRegistrationObjectInfo info; |
| 418 ServiceWorkerVersionAttributes attrs; |
| 419 bool found = |
| 420 provider_context_->GetRegistrationInfoAndVersionAttributes(&info, &attrs); |
| 421 if (!found) |
| 422 return; // Cannot be associated with a registration in some tests. |
| 423 |
422 ServiceWorkerDispatcher* dispatcher = | 424 ServiceWorkerDispatcher* dispatcher = |
423 ServiceWorkerDispatcher::GetOrCreateThreadSpecificInstance( | 425 ServiceWorkerDispatcher::GetOrCreateThreadSpecificInstance( |
424 thread_safe_sender()); | 426 thread_safe_sender()); |
425 | 427 |
426 // Register a registration with the dispatcher living on the worker thread. | 428 // Register a registration and its version attributes with the dispatcher |
427 DCHECK(provider_context_->registration()); | 429 // living on the worker thread. |
428 scoped_ptr<WebServiceWorkerRegistrationImpl> registration( | 430 scoped_ptr<WebServiceWorkerRegistrationImpl> registration( |
429 dispatcher->CreateServiceWorkerRegistration( | 431 dispatcher->CreateServiceWorkerRegistration(info, false)); |
430 provider_context_->registration()->info(), false)); | |
431 | |
432 // Register workers with the dispatcher living on the worker thread. | |
433 ServiceWorkerVersionAttributes attrs = | |
434 provider_context_->GetVersionAttributes(); | |
435 registration->SetInstalling( | 432 registration->SetInstalling( |
436 dispatcher->GetServiceWorker(attrs.installing, false)); | 433 dispatcher->GetServiceWorker(attrs.installing, false)); |
437 registration->SetWaiting( | 434 registration->SetWaiting( |
438 dispatcher->GetServiceWorker(attrs.waiting, false)); | 435 dispatcher->GetServiceWorker(attrs.waiting, false)); |
439 registration->SetActive( | 436 registration->SetActive( |
440 dispatcher->GetServiceWorker(attrs.active, false)); | 437 dispatcher->GetServiceWorker(attrs.active, false)); |
441 | 438 |
442 script_context_->SetRegistrationInServiceWorkerGlobalScope( | 439 script_context_->SetRegistrationInServiceWorkerGlobalScope( |
443 registration.Pass()); | 440 registration.Pass()); |
444 } | 441 } |
445 | 442 |
446 } // namespace content | 443 } // namespace content |
OLD | NEW |