Chromium Code Reviews| 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 |