OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/public/test/mock_render_thread.h" | 5 #include "content/public/test/mock_render_thread.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "base/single_thread_task_runner.h" | 8 #include "base/single_thread_task_runner.h" |
9 #include "base/threading/thread_task_runner_handle.h" | 9 #include "base/threading/thread_task_runner_handle.h" |
10 #include "build/build_config.h" | 10 #include "build/build_config.h" |
(...skipping 30 matching lines...) Expand all Loading... |
41 | 41 |
42 void CreateNewWindow(mojom::CreateNewWindowParamsPtr params, | 42 void CreateNewWindow(mojom::CreateNewWindowParamsPtr params, |
43 const CreateNewWindowCallback& callback) override { | 43 const CreateNewWindowCallback& callback) override { |
44 // NOTE: This implementation of mojom::RenderMessageFilter is used client- | 44 // NOTE: This implementation of mojom::RenderMessageFilter is used client- |
45 // side only. Because sync mojom methods have a different interface for | 45 // side only. Because sync mojom methods have a different interface for |
46 // bindings- and client-side, we only implement the client-side interface | 46 // bindings- and client-side, we only implement the client-side interface |
47 // on this object. | 47 // on this object. |
48 NOTREACHED(); | 48 NOTREACHED(); |
49 } | 49 } |
50 | 50 |
51 // Note that | |
52 bool CreateNewWindow(mojom::CreateNewWindowParamsPtr params, | 51 bool CreateNewWindow(mojom::CreateNewWindowParamsPtr params, |
53 mojom::CreateNewWindowReplyPtr* reply) override { | 52 mojom::CreateNewWindowReplyPtr* reply) override { |
54 *reply = mojom::CreateNewWindowReply::New(); | 53 *reply = mojom::CreateNewWindowReply::New(); |
55 thread_->OnCreateWindow(*params, reply->get()); | 54 thread_->OnCreateWindow(*params, reply->get()); |
56 return true; | 55 return true; |
57 } | 56 } |
58 | 57 |
| 58 void CreateNewWidget(int32_t opener_id, |
| 59 blink::WebPopupType popup_type, |
| 60 const CreateNewWidgetCallback& callback) override { |
| 61 // See comment in CreateNewWindow(). |
| 62 NOTREACHED(); |
| 63 } |
| 64 |
| 65 bool CreateNewWidget(int32_t opener_id, |
| 66 blink::WebPopupType popup_type, |
| 67 int32_t* route_id) override { |
| 68 thread_->OnCreateWidget(opener_id, popup_type, route_id); |
| 69 return true; |
| 70 } |
| 71 |
59 private: | 72 private: |
60 MockRenderThread* const thread_; | 73 MockRenderThread* const thread_; |
61 }; | 74 }; |
62 | 75 |
63 } // namespace | 76 } // namespace |
64 | 77 |
65 MockRenderThread::MockRenderThread() | 78 MockRenderThread::MockRenderThread() |
66 : routing_id_(0), | 79 : routing_id_(0), |
67 opener_id_(0), | 80 opener_id_(0), |
68 new_window_routing_id_(0), | 81 new_window_routing_id_(0), |
(...skipping 180 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
249 remote_interfaces_->Bind(std::move(remote_interface_provider)); | 262 remote_interfaces_->Bind(std::move(remote_interface_provider)); |
250 } | 263 } |
251 return remote_interfaces_.get(); | 264 return remote_interfaces_.get(); |
252 } | 265 } |
253 | 266 |
254 void MockRenderThread::SendCloseMessage() { | 267 void MockRenderThread::SendCloseMessage() { |
255 ViewMsg_Close msg(routing_id_); | 268 ViewMsg_Close msg(routing_id_); |
256 RenderViewImpl::FromRoutingID(routing_id_)->OnMessageReceived(msg); | 269 RenderViewImpl::FromRoutingID(routing_id_)->OnMessageReceived(msg); |
257 } | 270 } |
258 | 271 |
259 // The Widget expects to be returned valid route_id. | 272 // The Widget expects to be returned a valid route_id. |
260 void MockRenderThread::OnCreateWidget(int opener_id, | 273 void MockRenderThread::OnCreateWidget(int opener_id, |
261 blink::WebPopupType popup_type, | 274 blink::WebPopupType popup_type, |
262 int* route_id) { | 275 int* route_id) { |
263 opener_id_ = opener_id; | 276 opener_id_ = opener_id; |
264 *route_id = routing_id_; | 277 *route_id = routing_id_; |
265 } | 278 } |
266 | 279 |
267 // The Frame expects to be returned a valid route_id different from its own. | 280 // The Frame expects to be returned a valid route_id different from its own. |
268 void MockRenderThread::OnCreateChildFrame( | 281 void MockRenderThread::OnCreateChildFrame( |
269 const FrameHostMsg_CreateChildFrame_Params& params, | 282 const FrameHostMsg_CreateChildFrame_Params& params, |
270 int* new_render_frame_id) { | 283 int* new_render_frame_id) { |
271 *new_render_frame_id = new_frame_routing_id_++; | 284 *new_render_frame_id = new_frame_routing_id_++; |
272 } | 285 } |
273 | 286 |
274 bool MockRenderThread::OnControlMessageReceived(const IPC::Message& msg) { | 287 bool MockRenderThread::OnControlMessageReceived(const IPC::Message& msg) { |
275 for (auto& observer : observers_) { | 288 for (auto& observer : observers_) { |
276 if (observer.OnControlMessageReceived(msg)) | 289 if (observer.OnControlMessageReceived(msg)) |
277 return true; | 290 return true; |
278 } | 291 } |
279 return OnMessageReceived(msg); | 292 return OnMessageReceived(msg); |
280 } | 293 } |
281 | 294 |
282 bool MockRenderThread::OnMessageReceived(const IPC::Message& msg) { | 295 bool MockRenderThread::OnMessageReceived(const IPC::Message& msg) { |
283 // Save the message in the sink. | 296 // Save the message in the sink. |
284 sink_.OnMessageReceived(msg); | 297 sink_.OnMessageReceived(msg); |
285 | 298 |
286 bool handled = true; | 299 bool handled = true; |
287 IPC_BEGIN_MESSAGE_MAP(MockRenderThread, msg) | 300 IPC_BEGIN_MESSAGE_MAP(MockRenderThread, msg) |
288 IPC_MESSAGE_HANDLER(ViewHostMsg_CreateWidget, OnCreateWidget) | |
289 IPC_MESSAGE_HANDLER(FrameHostMsg_CreateChildFrame, OnCreateChildFrame) | 301 IPC_MESSAGE_HANDLER(FrameHostMsg_CreateChildFrame, OnCreateChildFrame) |
290 IPC_MESSAGE_UNHANDLED(handled = false) | 302 IPC_MESSAGE_UNHANDLED(handled = false) |
291 IPC_END_MESSAGE_MAP() | 303 IPC_END_MESSAGE_MAP() |
292 return handled; | 304 return handled; |
293 } | 305 } |
294 | 306 |
295 #if defined(OS_WIN) | 307 #if defined(OS_WIN) |
296 void MockRenderThread::OnDuplicateSection( | 308 void MockRenderThread::OnDuplicateSection( |
297 base::SharedMemoryHandle renderer_handle, | 309 base::SharedMemoryHandle renderer_handle, |
298 base::SharedMemoryHandle* browser_handle) { | 310 base::SharedMemoryHandle* browser_handle) { |
299 // We don't have to duplicate the input handles since RenderViewTest does not | 311 // We don't have to duplicate the input handles since RenderViewTest does not |
300 // separate a browser process from a renderer process. | 312 // separate a browser process from a renderer process. |
301 *browser_handle = renderer_handle; | 313 *browser_handle = renderer_handle; |
302 } | 314 } |
303 #endif // defined(OS_WIN) | 315 #endif // defined(OS_WIN) |
304 | 316 |
305 // The View expects to be returned a valid route_id different from its own. | 317 // The View expects to be returned a valid route_id different from its own. |
306 void MockRenderThread::OnCreateWindow( | 318 void MockRenderThread::OnCreateWindow( |
307 const mojom::CreateNewWindowParams& params, | 319 const mojom::CreateNewWindowParams& params, |
308 mojom::CreateNewWindowReply* reply) { | 320 mojom::CreateNewWindowReply* reply) { |
309 reply->route_id = new_window_routing_id_; | 321 reply->route_id = new_window_routing_id_; |
310 reply->main_frame_route_id = new_window_main_frame_routing_id_; | 322 reply->main_frame_route_id = new_window_main_frame_routing_id_; |
311 reply->main_frame_widget_route_id = new_window_main_frame_widget_routing_id_; | 323 reply->main_frame_widget_route_id = new_window_main_frame_widget_routing_id_; |
312 reply->cloned_session_storage_namespace_id = 0; | 324 reply->cloned_session_storage_namespace_id = 0; |
313 } | 325 } |
314 | 326 |
315 } // namespace content | 327 } // namespace content |
OLD | NEW |