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

Side by Side Diff: content/browser/renderer_host/websocket_dispatcher_host_unittest.cc

Issue 390773002: [WebSocket] Send a close frame when the renderer process is gone. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 4 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 | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/renderer_host/websocket_dispatcher_host.h" 5 #include "content/browser/renderer_host/websocket_dispatcher_host.h"
6 6
7 #include <algorithm>
7 #include <vector> 8 #include <vector>
8 9
9 #include "base/bind.h" 10 #include "base/bind.h"
10 #include "base/bind_helpers.h" 11 #include "base/bind_helpers.h"
11 #include "base/memory/ref_counted.h" 12 #include "base/memory/ref_counted.h"
12 #include "content/browser/renderer_host/websocket_host.h" 13 #include "content/browser/renderer_host/websocket_host.h"
13 #include "content/common/websocket.h" 14 #include "content/common/websocket.h"
14 #include "content/common/websocket_messages.h" 15 #include "content/common/websocket_messages.h"
15 #include "ipc/ipc_message.h" 16 #include "ipc/ipc_message.h"
16 #include "testing/gtest/include/gtest/gtest.h" 17 #include "testing/gtest/include/gtest/gtest.h"
17 #include "url/gurl.h" 18 #include "url/gurl.h"
18 #include "url/origin.h" 19 #include "url/origin.h"
19 20
20 namespace content { 21 namespace content {
21 namespace { 22 namespace {
22 23
23 // This number is unlikely to occur by chance. 24 // This number is unlikely to occur by chance.
24 static const int kMagicRenderProcessId = 506116062; 25 static const int kMagicRenderProcessId = 506116062;
25 26
27 class WebSocketDispatcherHostTest;
28
26 // A mock of WebsocketHost which records received messages. 29 // A mock of WebsocketHost which records received messages.
27 class MockWebSocketHost : public WebSocketHost { 30 class MockWebSocketHost : public WebSocketHost {
28 public: 31 public:
29 MockWebSocketHost(int routing_id, 32 MockWebSocketHost(int routing_id,
30 WebSocketDispatcherHost* dispatcher, 33 WebSocketDispatcherHost* dispatcher,
31 net::URLRequestContext* url_request_context) 34 net::URLRequestContext* url_request_context,
32 : WebSocketHost(routing_id, dispatcher, url_request_context) { 35 WebSocketDispatcherHostTest* owner)
36 : WebSocketHost(routing_id, dispatcher, url_request_context),
37 owner_(owner) {
33 } 38 }
34 39
35 virtual ~MockWebSocketHost() {} 40 virtual ~MockWebSocketHost() {}
36 41
37 virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE{ 42 virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE {
38 received_messages_.push_back(message); 43 received_messages_.push_back(message);
39 return true; 44 return true;
40 } 45 }
41 46
47 virtual void GoAway() OVERRIDE;
48
42 std::vector<IPC::Message> received_messages_; 49 std::vector<IPC::Message> received_messages_;
50 WebSocketDispatcherHostTest* owner_;
43 }; 51 };
44 52
45 class WebSocketDispatcherHostTest : public ::testing::Test { 53 class WebSocketDispatcherHostTest : public ::testing::Test {
46 public: 54 public:
47 WebSocketDispatcherHostTest() { 55 WebSocketDispatcherHostTest()
56 : on_destruction_(false) {
48 dispatcher_host_ = new WebSocketDispatcherHost( 57 dispatcher_host_ = new WebSocketDispatcherHost(
49 kMagicRenderProcessId, 58 kMagicRenderProcessId,
50 base::Bind(&WebSocketDispatcherHostTest::OnGetRequestContext, 59 base::Bind(&WebSocketDispatcherHostTest::OnGetRequestContext,
51 base::Unretained(this)), 60 base::Unretained(this)),
52 base::Bind(&WebSocketDispatcherHostTest::CreateWebSocketHost, 61 base::Bind(&WebSocketDispatcherHostTest::CreateWebSocketHost,
53 base::Unretained(this))); 62 base::Unretained(this)));
54 } 63 }
55 64
56 virtual ~WebSocketDispatcherHostTest() {} 65 virtual ~WebSocketDispatcherHostTest() {
66 on_destruction_ = true;
Adam Rice 2014/07/28 04:29:22 This doesn't seem safe to me. How about changing t
yhirano 2014/07/28 05:08:52 Done.
67 }
68
69 void GoAway(int routing_id) {
70 if (!on_destruction_)
71 gone_hosts_.push_back(routing_id);
72 }
57 73
58 protected: 74 protected:
59 scoped_refptr<WebSocketDispatcherHost> dispatcher_host_; 75 scoped_refptr<WebSocketDispatcherHost> dispatcher_host_;
60 76
61 // Stores allocated MockWebSocketHost instances. Doesn't take ownership of 77 // Stores allocated MockWebSocketHost instances. Doesn't take ownership of
62 // them. 78 // them.
63 std::vector<MockWebSocketHost*> mock_hosts_; 79 std::vector<MockWebSocketHost*> mock_hosts_;
80 std::vector<int> gone_hosts_;
81 bool on_destruction_;
64 82
65 private: 83 private:
66 net::URLRequestContext* OnGetRequestContext() { 84 net::URLRequestContext* OnGetRequestContext() {
67 return NULL; 85 return NULL;
68 } 86 }
69 87
70 WebSocketHost* CreateWebSocketHost(int routing_id) { 88 WebSocketHost* CreateWebSocketHost(int routing_id) {
71 MockWebSocketHost* host = 89 MockWebSocketHost* host =
72 new MockWebSocketHost(routing_id, dispatcher_host_.get(), NULL); 90 new MockWebSocketHost(routing_id, dispatcher_host_.get(), NULL, this);
73 mock_hosts_.push_back(host); 91 mock_hosts_.push_back(host);
74 return host; 92 return host;
75 } 93 }
76 }; 94 };
77 95
96 void MockWebSocketHost::GoAway() {
97 owner_->GoAway(routing_id());
98 }
99
78 TEST_F(WebSocketDispatcherHostTest, Construct) { 100 TEST_F(WebSocketDispatcherHostTest, Construct) {
79 // Do nothing. 101 // Do nothing.
80 } 102 }
81 103
82 TEST_F(WebSocketDispatcherHostTest, UnrelatedMessage) { 104 TEST_F(WebSocketDispatcherHostTest, UnrelatedMessage) {
83 IPC::Message message; 105 IPC::Message message;
84 EXPECT_FALSE(dispatcher_host_->OnMessageReceived(message)); 106 EXPECT_FALSE(dispatcher_host_->OnMessageReceived(message));
85 } 107 }
86 108
87 TEST_F(WebSocketDispatcherHostTest, RenderProcessIdGetter) { 109 TEST_F(WebSocketDispatcherHostTest, RenderProcessIdGetter) {
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after
149 EXPECT_EQ(WebSocketHostMsg_AddChannelRequest::ID, forwarded_message.type()); 171 EXPECT_EQ(WebSocketHostMsg_AddChannelRequest::ID, forwarded_message.type());
150 EXPECT_EQ(routing_id, forwarded_message.routing_id()); 172 EXPECT_EQ(routing_id, forwarded_message.routing_id());
151 } 173 }
152 { 174 {
153 const IPC::Message& forwarded_message = host->received_messages_[1]; 175 const IPC::Message& forwarded_message = host->received_messages_[1];
154 EXPECT_EQ(WebSocketMsg_SendFrame::ID, forwarded_message.type()); 176 EXPECT_EQ(WebSocketMsg_SendFrame::ID, forwarded_message.type());
155 EXPECT_EQ(routing_id, forwarded_message.routing_id()); 177 EXPECT_EQ(routing_id, forwarded_message.routing_id());
156 } 178 }
157 } 179 }
158 180
181 TEST_F(WebSocketDispatcherHostTest, Destruct) {
182 WebSocketHostMsg_AddChannelRequest message1(
183 123, GURL("ws://example.com/test"), std::vector<std::string>(),
184 url::Origin("http://example.com"), -1);
185 WebSocketHostMsg_AddChannelRequest message2(
186 456, GURL("ws://example.com/test2"), std::vector<std::string>(),
187 url::Origin("http://example.com"), -1);
188
189 ASSERT_TRUE(dispatcher_host_->OnMessageReceived(message1));
190 ASSERT_TRUE(dispatcher_host_->OnMessageReceived(message2));
191
192 ASSERT_EQ(2u, mock_hosts_.size());
193
194 mock_hosts_.clear();
195 dispatcher_host_ = NULL;
196
197 ASSERT_EQ(2u, gone_hosts_.size());
198 // The gone_hosts_ ordering is not predictable because it depends on the
199 // hash_map ordering.
200 std::sort(gone_hosts_.begin(), gone_hosts_.end());
201 EXPECT_EQ(123, gone_hosts_[0]);
202 EXPECT_EQ(456, gone_hosts_[1]);
203 }
204
159 } // namespace 205 } // namespace
160 } // namespace content 206 } // namespace content
OLDNEW
« no previous file with comments | « content/browser/renderer_host/websocket_dispatcher_host.cc ('k') | content/browser/renderer_host/websocket_host.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698