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

Side by Side Diff: content/browser/service_worker/embedded_worker_test_helper.cc

Issue 2638313002: Manage ServiceWorkerDispatcherHost in ServiceWorkerContextCore (Closed)
Patch Set: Remove a break line Created 3 years, 10 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
OLDNEW
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/threading/thread_task_runner_handle.h" 16 #include "base/threading/thread_task_runner_handle.h"
17 #include "base/time/time.h" 17 #include "base/time/time.h"
18 #include "content/browser/message_port_message_filter.h" 18 #include "content/browser/message_port_message_filter.h"
19 #include "content/browser/service_worker/embedded_worker_instance.h" 19 #include "content/browser/service_worker/embedded_worker_instance.h"
20 #include "content/browser/service_worker/embedded_worker_registry.h" 20 #include "content/browser/service_worker/embedded_worker_registry.h"
21 #include "content/browser/service_worker/embedded_worker_status.h" 21 #include "content/browser/service_worker/embedded_worker_status.h"
22 #include "content/browser/service_worker/service_worker_context_core.h" 22 #include "content/browser/service_worker/service_worker_context_core.h"
23 #include "content/browser/service_worker/service_worker_context_wrapper.h" 23 #include "content/browser/service_worker/service_worker_context_wrapper.h"
24 #include "content/browser/service_worker/service_worker_dispatcher_host.h"
24 #include "content/common/service_worker/embedded_worker_messages.h" 25 #include "content/common/service_worker/embedded_worker_messages.h"
25 #include "content/common/service_worker/embedded_worker_start_params.h" 26 #include "content/common/service_worker/embedded_worker_start_params.h"
26 #include "content/common/service_worker/service_worker_messages.h" 27 #include "content/common/service_worker/service_worker_messages.h"
27 #include "content/common/service_worker/service_worker_utils.h" 28 #include "content/common/service_worker/service_worker_utils.h"
28 #include "content/public/common/push_event_payload.h" 29 #include "content/public/common/push_event_payload.h"
29 #include "content/public/test/mock_render_process_host.h" 30 #include "content/public/test/mock_render_process_host.h"
30 #include "content/public/test/test_browser_context.h" 31 #include "content/public/test/test_browser_context.h"
31 #include "mojo/public/cpp/bindings/interface_request.h" 32 #include "mojo/public/cpp/bindings/interface_request.h"
32 #include "mojo/public/cpp/bindings/strong_binding.h" 33 #include "mojo/public/cpp/bindings/strong_binding.h"
33 #include "services/service_manager/public/cpp/interface_provider.h" 34 #include "services/service_manager/public/cpp/interface_provider.h"
(...skipping 16 matching lines...) Expand all
50 message_queue_.push_back(base::WrapUnique(message)); 51 message_queue_.push_back(base::WrapUnique(message));
51 return true; 52 return true;
52 } 53 }
53 54
54 private: 55 private:
55 ~MockMessagePortMessageFilter() override {} 56 ~MockMessagePortMessageFilter() override {}
56 base::AtomicSequenceNumber next_routing_id_; 57 base::AtomicSequenceNumber next_routing_id_;
57 std::vector<std::unique_ptr<IPC::Message>> message_queue_; 58 std::vector<std::unique_ptr<IPC::Message>> message_queue_;
58 }; 59 };
59 60
61 class MockServiceWorkerDispatcherHost : public ServiceWorkerDispatcherHost {
62 public:
63 MockServiceWorkerDispatcherHost(
64 int process_id,
65 MessagePortMessageFilter* message_port_message_filter,
66 ResourceContext* resource_context,
67 IPC::Sender* sender)
68 : ServiceWorkerDispatcherHost(process_id,
69 message_port_message_filter,
70 resource_context),
71 sender_(sender) {}
72
73 bool Send(IPC::Message* message) override { return sender_->Send(message); }
74
75 protected:
76 ~MockServiceWorkerDispatcherHost() override {}
77
78 private:
79 IPC::Sender* sender_;
80 };
horo 2017/02/08 02:14:11 nit: DISALLOW_COPY_AND_ASSIGN(MockServiceWorker
shimazu 2017/02/13 03:25:56 Done.
81
60 } // namespace 82 } // namespace
61 83
62 EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient:: 84 EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient::
63 MockEmbeddedWorkerInstanceClient( 85 MockEmbeddedWorkerInstanceClient(
64 base::WeakPtr<EmbeddedWorkerTestHelper> helper) 86 base::WeakPtr<EmbeddedWorkerTestHelper> helper)
65 : helper_(helper), binding_(this) {} 87 : helper_(helper), binding_(this) {}
66 88
67 EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient:: 89 EmbeddedWorkerTestHelper::MockEmbeddedWorkerInstanceClient::
68 ~MockEmbeddedWorkerInstanceClient() {} 90 ~MockEmbeddedWorkerInstanceClient() {}
69 91
(...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after
206 mock_render_process_id_(render_process_host_->GetID()), 228 mock_render_process_id_(render_process_host_->GetID()),
207 new_mock_render_process_id_(new_render_process_host_->GetID()), 229 new_mock_render_process_id_(new_render_process_host_->GetID()),
208 weak_factory_(this) { 230 weak_factory_(this) {
209 std::unique_ptr<MockServiceWorkerDatabaseTaskManager> database_task_manager( 231 std::unique_ptr<MockServiceWorkerDatabaseTaskManager> database_task_manager(
210 new MockServiceWorkerDatabaseTaskManager( 232 new MockServiceWorkerDatabaseTaskManager(
211 base::ThreadTaskRunnerHandle::Get())); 233 base::ThreadTaskRunnerHandle::Get()));
212 wrapper_->InitInternal(user_data_directory, std::move(database_task_manager), 234 wrapper_->InitInternal(user_data_directory, std::move(database_task_manager),
213 base::ThreadTaskRunnerHandle::Get(), nullptr, nullptr); 235 base::ThreadTaskRunnerHandle::Get(), nullptr, nullptr);
214 wrapper_->process_manager()->SetProcessIdForTest(mock_render_process_id()); 236 wrapper_->process_manager()->SetProcessIdForTest(mock_render_process_id());
215 wrapper_->process_manager()->SetNewProcessIdForTest(new_render_process_id()); 237 wrapper_->process_manager()->SetNewProcessIdForTest(new_render_process_id());
216 registry()->AddChildProcessSender(mock_render_process_id_, this, 238
217 NewMessagePortMessageFilter()); 239 scoped_refptr<ServiceWorkerDispatcherHost> dispatcher_host(
240 new MockServiceWorkerDispatcherHost(
241 mock_render_process_id_, NewMessagePortMessageFilter(),
242 browser_context_->GetResourceContext(), this));
243 wrapper_->context()->AddDispatcherHost(mock_render_process_id_,
244 dispatcher_host.get());
245 dispatcher_hosts_[mock_render_process_id_] = std::move(dispatcher_host);
218 246
219 // Setup process level interface registry. 247 // Setup process level interface registry.
220 render_process_interface_registry_ = 248 render_process_interface_registry_ =
221 CreateInterfaceRegistry(render_process_host_.get()); 249 CreateInterfaceRegistry(render_process_host_.get());
222 new_render_process_interface_registry_ = 250 new_render_process_interface_registry_ =
223 CreateInterfaceRegistry(new_render_process_host_.get()); 251 CreateInterfaceRegistry(new_render_process_host_.get());
224 } 252 }
225 253
226 EmbeddedWorkerTestHelper::~EmbeddedWorkerTestHelper() { 254 EmbeddedWorkerTestHelper::~EmbeddedWorkerTestHelper() {
227 if (wrapper_.get()) 255 if (wrapper_.get())
228 wrapper_->Shutdown(); 256 wrapper_->Shutdown();
229 } 257 }
230 258
231 void EmbeddedWorkerTestHelper::SimulateAddProcessToPattern(const GURL& pattern, 259 void EmbeddedWorkerTestHelper::SimulateAddProcessToPattern(const GURL& pattern,
232 int process_id) { 260 int process_id) {
233 registry()->AddChildProcessSender(process_id, this, 261 if (!context()->GetDispatcherHost(process_id)) {
234 NewMessagePortMessageFilter()); 262 scoped_refptr<ServiceWorkerDispatcherHost> dispatcher_host(
263 new MockServiceWorkerDispatcherHost(
264 process_id, NewMessagePortMessageFilter(),
265 browser_context_->GetResourceContext(), this));
266 wrapper_->context()->AddDispatcherHost(process_id, dispatcher_host.get());
267 dispatcher_hosts_[process_id] = std::move(dispatcher_host);
268 }
235 wrapper_->process_manager()->AddProcessReferenceToPattern(pattern, 269 wrapper_->process_manager()->AddProcessReferenceToPattern(pattern,
236 process_id); 270 process_id);
237 } 271 }
238 272
239 bool EmbeddedWorkerTestHelper::Send(IPC::Message* message) { 273 bool EmbeddedWorkerTestHelper::Send(IPC::Message* message) {
240 OnMessageReceived(*message); 274 OnMessageReceived(*message);
241 delete message; 275 delete message;
242 return true; 276 return true;
243 } 277 }
244 278
(...skipping 341 matching lines...) Expand 10 before | Expand all | Expand 10 after
586 service_manager::InterfaceProviderSpec()); 620 service_manager::InterfaceProviderSpec());
587 621
588 std::unique_ptr<service_manager::InterfaceProvider> remote_interfaces( 622 std::unique_ptr<service_manager::InterfaceProvider> remote_interfaces(
589 new service_manager::InterfaceProvider); 623 new service_manager::InterfaceProvider);
590 remote_interfaces->Bind(std::move(interfaces)); 624 remote_interfaces->Bind(std::move(interfaces));
591 rph->SetRemoteInterfaces(std::move(remote_interfaces)); 625 rph->SetRemoteInterfaces(std::move(remote_interfaces));
592 return registry; 626 return registry;
593 } 627 }
594 628
595 } // namespace content 629 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698