Chromium Code Reviews| Index: content/browser/service_worker/embedded_worker_test_helper.cc |
| diff --git a/content/browser/service_worker/embedded_worker_test_helper.cc b/content/browser/service_worker/embedded_worker_test_helper.cc |
| index 2b05b9bb1c2c16538663d8c6c4a805a6ca229b21..727e5e93635d73f66eeb4c0253c67358e5a1cff0 100644 |
| --- a/content/browser/service_worker/embedded_worker_test_helper.cc |
| +++ b/content/browser/service_worker/embedded_worker_test_helper.cc |
| @@ -21,6 +21,7 @@ |
| #include "content/browser/service_worker/service_worker_context_wrapper.h" |
| #include "content/common/service_worker/embedded_worker_messages.h" |
| #include "content/common/service_worker/embedded_worker_setup.mojom.h" |
| +#include "content/common/service_worker/embedded_worker_start_params.h" |
| #include "content/common/service_worker/service_worker_messages.h" |
| #include "content/public/common/push_event_payload.h" |
| #include "content/public/test/mock_render_process_host.h" |
| @@ -84,13 +85,63 @@ class EmbeddedWorkerTestHelper::MockEmbeddedWorkerSetup |
| mojo::StrongBinding<mojom::EmbeddedWorkerSetup> binding_; |
| }; |
| +EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient:: |
| + MockEmbeddedWorkerInstanceClient( |
| + base::WeakPtr<EmbeddedWorkerTestHelper> helper) |
| + : helper_(helper), binding_(this) {} |
| + |
| +EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient:: |
| + ~MockEmbeddedWorkerInstanceClient() {} |
| + |
| +void EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient::StartWorker( |
| + const EmbeddedWorkerStartParams& params) { |
| + if (!helper_) |
| + return; |
| + |
| + embedded_worker_id_ = params.embedded_worker_id; |
| + |
| + EmbeddedWorkerInstance* worker = |
| + helper_->registry()->GetWorker(params.embedded_worker_id); |
| + ASSERT_TRUE(worker != NULL); |
| + EXPECT_EQ(EmbeddedWorkerStatus::STARTING, worker->status()); |
| + |
| + base::ThreadTaskRunnerHandle::Get()->PostTask( |
| + FROM_HERE, |
| + base::Bind(&EmbeddedWorkerTestHelper::OnStartWorker, |
| + helper_->weak_factory_.GetWeakPtr(), params.embedded_worker_id, |
| + params.service_worker_version_id, params.scope, |
| + params.script_url, params.pause_after_download)); |
| +} |
| + |
| +// static |
| +void EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient::Bind( |
| + const base::WeakPtr<EmbeddedWorkerTestHelper>& helper, |
| + mojom::EmbeddedWorkerInstanceClientRequest request) { |
| + ASSERT_GE(helper->mock_instance_clients()->size(), |
| + helper->mock_instance_clients_next_); |
| + if (helper->mock_instance_clients()->size() == |
| + helper->mock_instance_clients_next_) { |
| + helper->mock_instance_clients()->push_back( |
| + base::MakeUnique<MockEmbeddedWorkerInstanceClient>(helper)); |
| + } |
| + |
| + auto& instance_client = |
| + helper->mock_instance_clients_[helper->mock_instance_clients_next_++]; |
|
falken
2016/09/13 05:48:02
Is the |next_| thing really needed? It's possible
shimazu
2016/09/15 03:24:42
Sorry for confusing you... This will be used in la
|
| + if (instance_client) |
| + instance_client->binding_.Bind(std::move(request)); |
| +} |
| + |
| EmbeddedWorkerTestHelper::EmbeddedWorkerTestHelper( |
| const base::FilePath& user_data_directory) |
| : browser_context_(new TestBrowserContext), |
| render_process_host_(new MockRenderProcessHost(browser_context_.get())), |
| + new_render_process_host_( |
| + new MockRenderProcessHost(browser_context_.get())), |
| wrapper_(new ServiceWorkerContextWrapper(browser_context_.get())), |
| + mock_instance_clients_next_(0), |
| next_thread_id_(0), |
| mock_render_process_id_(render_process_host_->GetID()), |
| + new_mock_render_process_id_(new_render_process_host_->GetID()), |
| weak_factory_(this) { |
| std::unique_ptr<MockServiceWorkerDatabaseTaskManager> database_task_manager( |
| new MockServiceWorkerDatabaseTaskManager( |
| @@ -103,16 +154,10 @@ EmbeddedWorkerTestHelper::EmbeddedWorkerTestHelper( |
| NewMessagePortMessageFilter()); |
| // Setup process level interface registry. |
| - render_process_interface_registry_.reset(new shell::InterfaceRegistry); |
| - render_process_interface_registry_->AddInterface( |
| - base::Bind(&MockEmbeddedWorkerSetup::Create, weak_factory_.GetWeakPtr())); |
| - shell::mojom::InterfaceProviderPtr interfaces; |
| - render_process_interface_registry_->Bind(mojo::GetProxy(&interfaces)); |
| - |
| - std::unique_ptr<shell::InterfaceProvider> host_remote_interfaces( |
| - new shell::InterfaceProvider); |
| - host_remote_interfaces->Bind(std::move(interfaces)); |
| - render_process_host_->SetRemoteInterfaces(std::move(host_remote_interfaces)); |
| + render_process_interface_registry_ = |
| + CreateInterfaceRegistry(render_process_host_.get()); |
| + new_render_process_interface_registry_ = |
| + CreateInterfaceRegistry(new_render_process_host_.get()); |
| } |
| EmbeddedWorkerTestHelper::~EmbeddedWorkerTestHelper() { |
| @@ -329,7 +374,7 @@ void EmbeddedWorkerTestHelper::SimulateSend(IPC::Message* message) { |
| } |
| void EmbeddedWorkerTestHelper::OnStartWorkerStub( |
| - const EmbeddedWorkerMsg_StartWorker_Params& params) { |
| + const EmbeddedWorkerStartParams& params) { |
| EmbeddedWorkerInstance* worker = |
| registry()->GetWorker(params.embedded_worker_id); |
| ASSERT_TRUE(worker != NULL); |
| @@ -446,4 +491,23 @@ EmbeddedWorkerTestHelper::NewMessagePortMessageFilter() { |
| return filter.get(); |
| } |
| +std::unique_ptr<shell::InterfaceRegistry> |
| +EmbeddedWorkerTestHelper::CreateInterfaceRegistry(MockRenderProcessHost* rph) { |
| + std::unique_ptr<shell::InterfaceRegistry> registry( |
| + new shell::InterfaceRegistry); |
| + registry->AddInterface( |
| + base::Bind(&MockEmbeddedWorkerSetup::Create, weak_factory_.GetWeakPtr())); |
| + registry->AddInterface(base::Bind(&MockEmbeddedWorkerInstanceClient::Bind, |
| + weak_factory_.GetWeakPtr())); |
| + |
| + shell::mojom::InterfaceProviderPtr interfaces; |
| + registry->Bind(mojo::GetProxy(&interfaces)); |
| + |
| + std::unique_ptr<shell::InterfaceProvider> remote_interfaces( |
| + new shell::InterfaceProvider); |
| + remote_interfaces->Bind(std::move(interfaces)); |
| + rph->SetRemoteInterfaces(std::move(remote_interfaces)); |
| + return registry; |
| +} |
| + |
| } // namespace content |