OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/browser/service_worker/embedded_worker_test_helper.h" | 5 #include "content/browser/service_worker/embedded_worker_test_helper.h" |
6 | 6 |
7 #include <map> | 7 #include <map> |
8 #include <memory> | 8 #include <memory> |
9 #include <string> | 9 #include <string> |
10 #include <utility> | 10 #include <utility> |
11 #include <vector> | 11 #include <vector> |
12 | 12 |
13 #include "base/atomic_sequence_num.h" | 13 #include "base/atomic_sequence_num.h" |
14 #include "base/bind.h" | 14 #include "base/bind.h" |
15 #include "base/memory/ptr_util.h" | 15 #include "base/memory/ptr_util.h" |
16 #include "base/message_loop/message_loop.h" | |
17 #include "base/run_loop.h" | |
16 #include "base/threading/thread_task_runner_handle.h" | 18 #include "base/threading/thread_task_runner_handle.h" |
17 #include "base/time/time.h" | 19 #include "base/time/time.h" |
18 #include "content/browser/service_worker/embedded_worker_instance.h" | 20 #include "content/browser/service_worker/embedded_worker_instance.h" |
19 #include "content/browser/service_worker/embedded_worker_registry.h" | 21 #include "content/browser/service_worker/embedded_worker_registry.h" |
20 #include "content/browser/service_worker/embedded_worker_status.h" | 22 #include "content/browser/service_worker/embedded_worker_status.h" |
21 #include "content/browser/service_worker/service_worker_context_core.h" | 23 #include "content/browser/service_worker/service_worker_context_core.h" |
22 #include "content/browser/service_worker/service_worker_context_wrapper.h" | 24 #include "content/browser/service_worker/service_worker_context_wrapper.h" |
23 #include "content/browser/service_worker/service_worker_dispatcher_host.h" | 25 #include "content/browser/service_worker/service_worker_dispatcher_host.h" |
26 #include "content/browser/service_worker/service_worker_test_utils.h" | |
24 #include "content/common/background_fetch/background_fetch_types.h" | 27 #include "content/common/background_fetch/background_fetch_types.h" |
25 #include "content/common/service_worker/embedded_worker_messages.h" | 28 #include "content/common/service_worker/embedded_worker_messages.h" |
26 #include "content/common/service_worker/embedded_worker_start_params.h" | 29 #include "content/common/service_worker/embedded_worker_start_params.h" |
27 #include "content/common/service_worker/service_worker_messages.h" | 30 #include "content/common/service_worker/service_worker_messages.h" |
28 #include "content/common/service_worker/service_worker_utils.h" | 31 #include "content/common/service_worker/service_worker_utils.h" |
29 #include "content/public/common/push_event_payload.h" | 32 #include "content/public/common/push_event_payload.h" |
30 #include "content/public/test/mock_render_process_host.h" | 33 #include "content/public/test/mock_render_process_host.h" |
31 #include "content/public/test/test_browser_context.h" | 34 #include "content/public/test/test_browser_context.h" |
32 #include "mojo/public/cpp/bindings/interface_request.h" | 35 #include "mojo/public/cpp/bindings/interface_request.h" |
33 #include "mojo/public/cpp/bindings/strong_binding.h" | 36 #include "mojo/public/cpp/bindings/strong_binding.h" |
(...skipping 30 matching lines...) Expand all Loading... | |
64 EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient:: | 67 EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient:: |
65 MockEmbeddedWorkerInstanceClient( | 68 MockEmbeddedWorkerInstanceClient( |
66 base::WeakPtr<EmbeddedWorkerTestHelper> helper) | 69 base::WeakPtr<EmbeddedWorkerTestHelper> helper) |
67 : helper_(helper), binding_(this) {} | 70 : helper_(helper), binding_(this) {} |
68 | 71 |
69 EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient:: | 72 EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient:: |
70 ~MockEmbeddedWorkerInstanceClient() {} | 73 ~MockEmbeddedWorkerInstanceClient() {} |
71 | 74 |
72 void EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient::StartWorker( | 75 void EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient::StartWorker( |
73 const EmbeddedWorkerStartParams& params, | 76 const EmbeddedWorkerStartParams& params, |
74 mojom::ServiceWorkerEventDispatcherRequest dispatcher_request) { | 77 mojom::ServiceWorkerEventDispatcherRequest dispatcher_request, |
78 mojom::EmbeddedWorkerInstanceHostAssociatedPtrInfo instance_host) { | |
75 if (!helper_) | 79 if (!helper_) |
76 return; | 80 return; |
77 | 81 |
78 embedded_worker_id_ = params.embedded_worker_id; | 82 embedded_worker_id_ = params.embedded_worker_id; |
79 | 83 |
80 EmbeddedWorkerInstance* worker = | 84 EmbeddedWorkerInstance* worker = |
81 helper_->registry()->GetWorker(params.embedded_worker_id); | 85 helper_->registry()->GetWorker(params.embedded_worker_id); |
82 ASSERT_TRUE(worker); | 86 ASSERT_TRUE(worker); |
83 EXPECT_EQ(EmbeddedWorkerStatus::STARTING, worker->status()); | 87 EXPECT_EQ(EmbeddedWorkerStatus::STARTING, worker->status()); |
84 | 88 |
85 helper_->OnStartWorkerStub(params, std::move(dispatcher_request)); | 89 helper_->OnStartWorkerStub(params, std::move(dispatcher_request), |
90 std::move(instance_host)); | |
86 } | 91 } |
87 | 92 |
88 void EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient::StopWorker( | 93 void EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient::StopWorker( |
89 const StopWorkerCallback& callback) { | 94 const StopWorkerCallback& callback) { |
90 if (!helper_) | 95 if (!helper_) |
91 return; | 96 return; |
92 | 97 |
93 ASSERT_TRUE(embedded_worker_id_); | 98 ASSERT_TRUE(embedded_worker_id_); |
94 EmbeddedWorkerInstance* worker = | 99 EmbeddedWorkerInstance* worker = |
95 helper_->registry()->GetWorker(embedded_worker_id_.value()); | 100 helper_->registry()->GetWorker(embedded_worker_id_.value()); |
(...skipping 171 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
267 | 272 |
268 EmbeddedWorkerTestHelper::EmbeddedWorkerTestHelper( | 273 EmbeddedWorkerTestHelper::EmbeddedWorkerTestHelper( |
269 const base::FilePath& user_data_directory) | 274 const base::FilePath& user_data_directory) |
270 : browser_context_(new TestBrowserContext), | 275 : browser_context_(new TestBrowserContext), |
271 render_process_host_(new MockRenderProcessHost(browser_context_.get())), | 276 render_process_host_(new MockRenderProcessHost(browser_context_.get())), |
272 new_render_process_host_( | 277 new_render_process_host_( |
273 new MockRenderProcessHost(browser_context_.get())), | 278 new MockRenderProcessHost(browser_context_.get())), |
274 wrapper_(new ServiceWorkerContextWrapper(browser_context_.get())), | 279 wrapper_(new ServiceWorkerContextWrapper(browser_context_.get())), |
275 mock_instance_clients_next_index_(0), | 280 mock_instance_clients_next_index_(0), |
276 next_thread_id_(0), | 281 next_thread_id_(0), |
282 next_provider_id_(1000), | |
shimazu
2017/04/06 05:01:36
Do you have any reason to use 1000 as the default?
leonhsl(Using Gerrit)
2017/04/06 09:58:55
It's possible that other test files create/add pro
| |
277 mock_render_process_id_(render_process_host_->GetID()), | 283 mock_render_process_id_(render_process_host_->GetID()), |
278 new_mock_render_process_id_(new_render_process_host_->GetID()), | 284 new_mock_render_process_id_(new_render_process_host_->GetID()), |
279 weak_factory_(this) { | 285 weak_factory_(this) { |
280 std::unique_ptr<MockServiceWorkerDatabaseTaskManager> database_task_manager( | 286 std::unique_ptr<MockServiceWorkerDatabaseTaskManager> database_task_manager( |
281 new MockServiceWorkerDatabaseTaskManager( | 287 new MockServiceWorkerDatabaseTaskManager( |
282 base::ThreadTaskRunnerHandle::Get())); | 288 base::ThreadTaskRunnerHandle::Get())); |
283 wrapper_->InitInternal(user_data_directory, std::move(database_task_manager), | 289 wrapper_->InitInternal(user_data_directory, std::move(database_task_manager), |
284 base::ThreadTaskRunnerHandle::Get(), nullptr, nullptr); | 290 base::ThreadTaskRunnerHandle::Get(), nullptr, nullptr); |
285 wrapper_->process_manager()->SetProcessIdForTest(mock_render_process_id()); | 291 wrapper_->process_manager()->SetProcessIdForTest(mock_render_process_id()); |
286 wrapper_->process_manager()->SetNewProcessIdForTest(new_render_process_id()); | 292 wrapper_->process_manager()->SetNewProcessIdForTest(new_render_process_id()); |
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
364 new net::HttpResponseHeaders(std::string(data, arraysize(data))); | 370 new net::HttpResponseHeaders(std::string(data, arraysize(data))); |
365 return info; | 371 return info; |
366 } | 372 } |
367 | 373 |
368 void EmbeddedWorkerTestHelper::OnStartWorker( | 374 void EmbeddedWorkerTestHelper::OnStartWorker( |
369 int embedded_worker_id, | 375 int embedded_worker_id, |
370 int64_t service_worker_version_id, | 376 int64_t service_worker_version_id, |
371 const GURL& scope, | 377 const GURL& scope, |
372 const GURL& script_url, | 378 const GURL& script_url, |
373 bool pause_after_download, | 379 bool pause_after_download, |
374 mojom::ServiceWorkerEventDispatcherRequest request) { | 380 mojom::ServiceWorkerEventDispatcherRequest request, |
381 mojom::EmbeddedWorkerInstanceHostAssociatedPtrInfo instance_host) { | |
375 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); | 382 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); |
376 ASSERT_TRUE(worker); | 383 ASSERT_TRUE(worker); |
377 MockServiceWorkerEventDispatcher::Create(AsWeakPtr(), worker->thread_id(), | 384 MockServiceWorkerEventDispatcher::Create(AsWeakPtr(), worker->thread_id(), |
378 std::move(request)); | 385 std::move(request)); |
379 | 386 |
380 embedded_worker_id_service_worker_version_id_map_[embedded_worker_id] = | 387 embedded_worker_id_service_worker_version_id_map_[embedded_worker_id] = |
381 service_worker_version_id; | 388 service_worker_version_id; |
389 embedded_worker_id_instance_host_ptr_map_[embedded_worker_id].Bind( | |
390 std::move(instance_host)); | |
391 | |
382 SimulateWorkerReadyForInspection(embedded_worker_id); | 392 SimulateWorkerReadyForInspection(embedded_worker_id); |
383 SimulateWorkerScriptCached(embedded_worker_id); | 393 SimulateWorkerScriptCached(embedded_worker_id); |
384 SimulateWorkerScriptLoaded(embedded_worker_id); | 394 SimulateWorkerScriptLoaded(embedded_worker_id); |
385 if (!pause_after_download) | 395 if (!pause_after_download) |
386 OnResumeAfterDownload(embedded_worker_id); | 396 OnResumeAfterDownload(embedded_worker_id); |
387 } | 397 } |
388 | 398 |
389 void EmbeddedWorkerTestHelper::OnResumeAfterDownload(int embedded_worker_id) { | 399 void EmbeddedWorkerTestHelper::OnResumeAfterDownload(int embedded_worker_id) { |
390 SimulateWorkerThreadStarted(GetNextThreadId(), embedded_worker_id); | 400 SimulateWorkerThreadStarted(GetNextThreadId(), embedded_worker_id, |
401 GetNextProviderId()); | |
391 SimulateWorkerScriptEvaluated(embedded_worker_id, true /* success */); | 402 SimulateWorkerScriptEvaluated(embedded_worker_id, true /* success */); |
392 SimulateWorkerStarted(embedded_worker_id); | 403 SimulateWorkerStarted(embedded_worker_id); |
393 } | 404 } |
394 | 405 |
395 void EmbeddedWorkerTestHelper::OnStopWorker( | 406 void EmbeddedWorkerTestHelper::OnStopWorker( |
396 const mojom::EmbeddedWorkerInstanceClient::StopWorkerCallback& callback) { | 407 const mojom::EmbeddedWorkerInstanceClient::StopWorkerCallback& callback) { |
397 // By default just notify the sender that the worker is stopped. | 408 // By default just notify the sender that the worker is stopped. |
398 callback.Run(); | 409 callback.Run(); |
399 } | 410 } |
400 | 411 |
(...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
521 DispatchPaymentRequestEventCallback& callback) { | 532 DispatchPaymentRequestEventCallback& callback) { |
522 response_callback->OnPaymentAppResponse( | 533 response_callback->OnPaymentAppResponse( |
523 payments::mojom::PaymentAppResponse::New(), base::Time::Now()); | 534 payments::mojom::PaymentAppResponse::New(), base::Time::Now()); |
524 callback.Run(SERVICE_WORKER_OK, base::Time::Now()); | 535 callback.Run(SERVICE_WORKER_OK, base::Time::Now()); |
525 } | 536 } |
526 | 537 |
527 void EmbeddedWorkerTestHelper::SimulateWorkerReadyForInspection( | 538 void EmbeddedWorkerTestHelper::SimulateWorkerReadyForInspection( |
528 int embedded_worker_id) { | 539 int embedded_worker_id) { |
529 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); | 540 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); |
530 ASSERT_TRUE(worker); | 541 ASSERT_TRUE(worker); |
531 registry()->OnWorkerReadyForInspection(worker->process_id(), | 542 ASSERT_TRUE(embedded_worker_id_instance_host_ptr_map_[embedded_worker_id]); |
532 embedded_worker_id); | 543 embedded_worker_id_instance_host_ptr_map_[embedded_worker_id] |
544 ->OnReadyForInspection(); | |
545 base::RunLoop().RunUntilIdle(); | |
leonhsl(Using Gerrit)
2017/04/06 02:49:52
Seems in such cases it's not necessary to let EWIn
shimazu
2017/04/06 05:01:36
It makes sense.
| |
533 } | 546 } |
534 | 547 |
535 void EmbeddedWorkerTestHelper::SimulateWorkerScriptCached( | 548 void EmbeddedWorkerTestHelper::SimulateWorkerScriptCached( |
536 int embedded_worker_id) { | 549 int embedded_worker_id) { |
537 int64_t version_id = | 550 int64_t version_id = |
538 embedded_worker_id_service_worker_version_id_map_[embedded_worker_id]; | 551 embedded_worker_id_service_worker_version_id_map_[embedded_worker_id]; |
539 ServiceWorkerVersion* version = context()->GetLiveVersion(version_id); | 552 ServiceWorkerVersion* version = context()->GetLiveVersion(version_id); |
540 if (!version) | 553 if (!version) |
541 return; | 554 return; |
542 if (!version->script_cache_map()->size()) { | 555 if (!version->script_cache_map()->size()) { |
543 std::vector<ServiceWorkerDatabase::ResourceRecord> records; | 556 std::vector<ServiceWorkerDatabase::ResourceRecord> records; |
544 // Add a dummy ResourceRecord for the main script to the script cache map of | 557 // Add a dummy ResourceRecord for the main script to the script cache map of |
545 // the ServiceWorkerVersion. We use embedded_worker_id for resource_id to | 558 // the ServiceWorkerVersion. We use embedded_worker_id for resource_id to |
546 // avoid ID collision. | 559 // avoid ID collision. |
547 records.push_back(ServiceWorkerDatabase::ResourceRecord( | 560 records.push_back(ServiceWorkerDatabase::ResourceRecord( |
548 embedded_worker_id, version->script_url(), 100)); | 561 embedded_worker_id, version->script_url(), 100)); |
549 version->script_cache_map()->SetResources(records); | 562 version->script_cache_map()->SetResources(records); |
550 } | 563 } |
551 if (!version->GetMainScriptHttpResponseInfo()) | 564 if (!version->GetMainScriptHttpResponseInfo()) |
552 version->SetMainScriptHttpResponseInfo(CreateHttpResponseInfo()); | 565 version->SetMainScriptHttpResponseInfo(CreateHttpResponseInfo()); |
553 } | 566 } |
554 | 567 |
555 void EmbeddedWorkerTestHelper::SimulateWorkerScriptLoaded( | 568 void EmbeddedWorkerTestHelper::SimulateWorkerScriptLoaded( |
556 int embedded_worker_id) { | 569 int embedded_worker_id) { |
557 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); | 570 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); |
558 ASSERT_TRUE(worker); | 571 ASSERT_TRUE(worker); |
559 registry()->OnWorkerScriptLoaded(worker->process_id(), embedded_worker_id); | 572 ASSERT_TRUE(embedded_worker_id_instance_host_ptr_map_[embedded_worker_id]); |
573 embedded_worker_id_instance_host_ptr_map_[embedded_worker_id] | |
574 ->OnScriptLoaded(); | |
575 base::RunLoop().RunUntilIdle(); | |
560 } | 576 } |
561 | 577 |
562 void EmbeddedWorkerTestHelper::SimulateWorkerThreadStarted( | 578 void EmbeddedWorkerTestHelper::SimulateWorkerThreadStarted( |
563 int thread_id, | 579 int thread_id, |
564 int embedded_worker_id) { | 580 int embedded_worker_id, |
565 thread_id_embedded_worker_id_map_[thread_id] = embedded_worker_id; | 581 int provider_id) { |
566 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); | 582 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); |
567 ASSERT_TRUE(worker); | 583 ASSERT_TRUE(worker); |
568 registry()->OnWorkerThreadStarted(worker->process_id(), thread_id, | 584 // Prepare a provider host to be used by bellowing OnThreadStarted(). |
shimazu
2017/04/06 05:01:36
following?
leonhsl(Using Gerrit)
2017/04/06 09:58:55
Done.
| |
569 embedded_worker_id); | 585 auto host = CreateProviderHostForServiceWorkerContext( |
586 worker->process_id(), provider_id, true /* is_parent_frame_secure */, | |
587 context()->AsWeakPtr()); | |
588 context()->AddProviderHost(std::move(host)); | |
589 | |
590 ASSERT_TRUE(embedded_worker_id_instance_host_ptr_map_[embedded_worker_id]); | |
591 embedded_worker_id_instance_host_ptr_map_[embedded_worker_id] | |
592 ->OnThreadStarted(thread_id, provider_id); | |
593 base::RunLoop().RunUntilIdle(); | |
570 } | 594 } |
571 | 595 |
572 void EmbeddedWorkerTestHelper::SimulateWorkerScriptEvaluated( | 596 void EmbeddedWorkerTestHelper::SimulateWorkerScriptEvaluated( |
573 int embedded_worker_id, | 597 int embedded_worker_id, |
574 bool success) { | 598 bool success) { |
575 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); | 599 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); |
576 ASSERT_TRUE(worker); | 600 ASSERT_TRUE(worker); |
577 registry()->OnWorkerScriptEvaluated(worker->process_id(), embedded_worker_id, | 601 ASSERT_TRUE(embedded_worker_id_instance_host_ptr_map_[embedded_worker_id]); |
578 success); | 602 embedded_worker_id_instance_host_ptr_map_[embedded_worker_id] |
603 ->OnScriptEvaluated(success); | |
604 base::RunLoop().RunUntilIdle(); | |
579 } | 605 } |
580 | 606 |
581 void EmbeddedWorkerTestHelper::SimulateWorkerStarted(int embedded_worker_id) { | 607 void EmbeddedWorkerTestHelper::SimulateWorkerStarted(int embedded_worker_id) { |
582 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); | 608 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); |
583 ASSERT_TRUE(worker); | 609 ASSERT_TRUE(worker); |
584 registry()->OnWorkerStarted(worker->process_id(), embedded_worker_id); | 610 ASSERT_TRUE(embedded_worker_id_instance_host_ptr_map_[embedded_worker_id]); |
611 embedded_worker_id_instance_host_ptr_map_[embedded_worker_id]->OnStarted(); | |
612 base::RunLoop().RunUntilIdle(); | |
585 } | 613 } |
586 | 614 |
587 void EmbeddedWorkerTestHelper::SimulateWorkerStopped(int embedded_worker_id) { | 615 void EmbeddedWorkerTestHelper::SimulateWorkerStopped(int embedded_worker_id) { |
588 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); | 616 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); |
589 if (worker) | 617 if (worker) { |
590 registry()->OnWorkerStopped(worker->process_id(), embedded_worker_id); | 618 ASSERT_TRUE(embedded_worker_id_instance_host_ptr_map_[embedded_worker_id]); |
619 embedded_worker_id_instance_host_ptr_map_[embedded_worker_id]->OnStopped(); | |
620 base::RunLoop().RunUntilIdle(); | |
621 } | |
591 } | 622 } |
592 | 623 |
593 void EmbeddedWorkerTestHelper::SimulateSend(IPC::Message* message) { | 624 void EmbeddedWorkerTestHelper::SimulateSend(IPC::Message* message) { |
594 registry()->OnMessageReceived(*message, mock_render_process_id_); | 625 registry()->OnMessageReceived(*message, mock_render_process_id_); |
595 delete message; | 626 delete message; |
596 } | 627 } |
597 | 628 |
598 void EmbeddedWorkerTestHelper::OnStartWorkerStub( | 629 void EmbeddedWorkerTestHelper::OnStartWorkerStub( |
599 const EmbeddedWorkerStartParams& params, | 630 const EmbeddedWorkerStartParams& params, |
600 mojom::ServiceWorkerEventDispatcherRequest request) { | 631 mojom::ServiceWorkerEventDispatcherRequest request, |
632 mojom::EmbeddedWorkerInstanceHostAssociatedPtrInfo instance_host) { | |
601 EmbeddedWorkerInstance* worker = | 633 EmbeddedWorkerInstance* worker = |
602 registry()->GetWorker(params.embedded_worker_id); | 634 registry()->GetWorker(params.embedded_worker_id); |
603 ASSERT_TRUE(worker); | 635 ASSERT_TRUE(worker); |
604 EXPECT_EQ(EmbeddedWorkerStatus::STARTING, worker->status()); | 636 EXPECT_EQ(EmbeddedWorkerStatus::STARTING, worker->status()); |
605 base::ThreadTaskRunnerHandle::Get()->PostTask( | 637 base::ThreadTaskRunnerHandle::Get()->PostTask( |
606 FROM_HERE, | 638 FROM_HERE, |
607 base::Bind(&EmbeddedWorkerTestHelper::OnStartWorker, AsWeakPtr(), | 639 base::Bind(&EmbeddedWorkerTestHelper::OnStartWorker, AsWeakPtr(), |
608 params.embedded_worker_id, params.service_worker_version_id, | 640 params.embedded_worker_id, params.service_worker_version_id, |
609 params.scope, params.script_url, params.pause_after_download, | 641 params.scope, params.script_url, params.pause_after_download, |
610 base::Passed(&request))); | 642 base::Passed(&request), base::Passed(&instance_host))); |
611 } | 643 } |
612 | 644 |
613 void EmbeddedWorkerTestHelper::OnResumeAfterDownloadStub( | 645 void EmbeddedWorkerTestHelper::OnResumeAfterDownloadStub( |
614 int embedded_worker_id) { | 646 int embedded_worker_id) { |
615 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); | 647 EmbeddedWorkerInstance* worker = registry()->GetWorker(embedded_worker_id); |
616 ASSERT_TRUE(worker); | 648 ASSERT_TRUE(worker); |
617 base::ThreadTaskRunnerHandle::Get()->PostTask( | 649 base::ThreadTaskRunnerHandle::Get()->PostTask( |
618 FROM_HERE, base::Bind(&EmbeddedWorkerTestHelper::OnResumeAfterDownload, | 650 FROM_HERE, base::Bind(&EmbeddedWorkerTestHelper::OnResumeAfterDownload, |
619 AsWeakPtr(), embedded_worker_id)); | 651 AsWeakPtr(), embedded_worker_id)); |
620 } | 652 } |
(...skipping 162 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
783 service_manager::InterfaceProviderSpec()); | 815 service_manager::InterfaceProviderSpec()); |
784 | 816 |
785 std::unique_ptr<service_manager::InterfaceProvider> remote_interfaces( | 817 std::unique_ptr<service_manager::InterfaceProvider> remote_interfaces( |
786 new service_manager::InterfaceProvider); | 818 new service_manager::InterfaceProvider); |
787 remote_interfaces->Bind(std::move(interfaces)); | 819 remote_interfaces->Bind(std::move(interfaces)); |
788 rph->SetRemoteInterfaces(std::move(remote_interfaces)); | 820 rph->SetRemoteInterfaces(std::move(remote_interfaces)); |
789 return registry; | 821 return registry; |
790 } | 822 } |
791 | 823 |
792 } // namespace content | 824 } // namespace content |
OLD | NEW |