OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "remoting/signaling/xmpp_signal_strategy.h" | 5 #include "remoting/signaling/xmpp_signal_strategy.h" |
6 | 6 |
7 #include "base/base64.h" | 7 #include "base/base64.h" |
8 #include "base/message_loop/message_loop.h" | 8 #include "base/message_loop/message_loop.h" |
9 #include "base/run_loop.h" | 9 #include "base/run_loop.h" |
10 #include "net/socket/socket_test_util.h" | 10 #include "net/socket/socket_test_util.h" |
11 #include "net/url_request/url_request_test_util.h" | 11 #include "net/url_request/url_request_test_util.h" |
12 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
13 #include "third_party/webrtc/libjingle/xmllite/xmlelement.h" | 13 #include "third_party/webrtc/libjingle/xmllite/xmlelement.h" |
14 | 14 |
15 namespace remoting { | 15 namespace remoting { |
16 | 16 |
17 namespace { | 17 namespace { |
18 | 18 |
19 class XmppSocketDataProvider: public net::SocketDataProvider { | 19 class XmppSocketDataProvider : public net::SocketDataProvider { |
20 public: | 20 public: |
21 net::MockRead OnRead() override { | 21 net::MockRead OnRead() override { |
22 return net::MockRead(net::ASYNC, net::ERR_IO_PENDING); | 22 return net::MockRead(net::ASYNC, net::ERR_IO_PENDING); |
23 } | 23 } |
24 | 24 |
25 net::MockWriteResult OnWrite(const std::string& data) override { | 25 net::MockWriteResult OnWrite(const std::string& data) override { |
| 26 if (write_error_ != net::OK) |
| 27 return net::MockWriteResult(net::SYNCHRONOUS, write_error_); |
| 28 |
26 written_data_.append(data); | 29 written_data_.append(data); |
27 | 30 |
28 if (use_async_write_) { | 31 if (use_async_write_) { |
29 pending_write_size_ = data.size(); | 32 pending_write_size_ = data.size(); |
30 return net::MockWriteResult(net::ASYNC, net::ERR_IO_PENDING); | 33 return net::MockWriteResult(net::ASYNC, net::ERR_IO_PENDING); |
31 } | 34 } |
32 | 35 |
33 return net::MockWriteResult(net::SYNCHRONOUS, data.size()); | 36 return net::MockWriteResult(net::SYNCHRONOUS, data.size()); |
34 } | 37 } |
35 | 38 |
36 void Reset() override {} | 39 void Reset() override {} |
37 | 40 |
38 bool AllReadDataConsumed() const override { | 41 bool AllReadDataConsumed() const override { |
39 return true; | 42 return true; |
40 } | 43 } |
41 | 44 |
42 bool AllWriteDataConsumed() const override { | 45 bool AllWriteDataConsumed() const override { |
43 return true; | 46 return true; |
44 } | 47 } |
45 | 48 |
46 void ReceiveData(const std::string& text) { | 49 void ReceiveData(const std::string& text) { |
47 socket()->OnReadComplete( | 50 socket()->OnReadComplete( |
48 net::MockRead(net::ASYNC, text.data(), text.size())); | 51 net::MockRead(net::ASYNC, text.data(), text.size())); |
49 } | 52 } |
50 | 53 |
51 void Close() { | 54 void Close() { |
52 ReceiveData(std::string()); | 55 ReceiveData(std::string()); |
53 } | 56 } |
54 | 57 |
55 void SimulateNetworkError() { | 58 void SimulateAsyncReadError() { |
56 socket()->OnReadComplete( | 59 socket()->OnReadComplete( |
57 net::MockRead(net::ASYNC, net::ERR_CONNECTION_RESET)); | 60 net::MockRead(net::ASYNC, net::ERR_CONNECTION_RESET)); |
58 } | 61 } |
59 | 62 |
60 std::string GetAndClearWrittenData() { | 63 std::string GetAndClearWrittenData() { |
61 std::string data; | 64 std::string data; |
62 data.swap(written_data_); | 65 data.swap(written_data_); |
63 return data; | 66 return data; |
64 } | 67 } |
65 | 68 |
66 void set_use_async_write(bool use_async_write) { | 69 void set_use_async_write(bool use_async_write) { |
67 use_async_write_ = use_async_write; | 70 use_async_write_ = use_async_write; |
68 } | 71 } |
69 | 72 |
| 73 void set_write_error(net::Error error) { |
| 74 write_error_ = error; |
| 75 } |
| 76 |
70 void CompletePendingWrite() { | 77 void CompletePendingWrite() { |
71 socket()->OnWriteComplete(pending_write_size_); | 78 socket()->OnWriteComplete(pending_write_size_); |
72 } | 79 } |
73 | 80 |
74 private: | 81 private: |
75 std::string written_data_; | 82 std::string written_data_; |
76 bool use_async_write_ = false; | 83 bool use_async_write_ = false; |
77 int pending_write_size_ = 0; | 84 int pending_write_size_ = 0; |
| 85 net::Error write_error_ = net::OK; |
78 }; | 86 }; |
79 | 87 |
80 class MockClientSocketFactory : public net::MockClientSocketFactory { | 88 class MockClientSocketFactory : public net::MockClientSocketFactory { |
81 public: | 89 public: |
82 scoped_ptr<net::SSLClientSocket> CreateSSLClientSocket( | 90 scoped_ptr<net::SSLClientSocket> CreateSSLClientSocket( |
83 scoped_ptr<net::ClientSocketHandle> transport_socket, | 91 scoped_ptr<net::ClientSocketHandle> transport_socket, |
84 const net::HostPortPair& host_and_port, | 92 const net::HostPortPair& host_and_port, |
85 const net::SSLConfig& ssl_config, | 93 const net::SSLConfig& ssl_config, |
86 const net::SSLClientSocketContext& context) override { | 94 const net::SSLClientSocketContext& context) override { |
87 ssl_socket_created_ = true; | 95 ssl_socket_created_ = true; |
(...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
289 EXPECT_EQ(SignalStrategy::OK, signal_strategy_->GetError()); | 297 EXPECT_EQ(SignalStrategy::OK, signal_strategy_->GetError()); |
290 | 298 |
291 // Can't send messages anymore. | 299 // Can't send messages anymore. |
292 EXPECT_FALSE(signal_strategy_->SendStanza(make_scoped_ptr( | 300 EXPECT_FALSE(signal_strategy_->SendStanza(make_scoped_ptr( |
293 new buzz::XmlElement(buzz::QName(std::string(), "hello"))))); | 301 new buzz::XmlElement(buzz::QName(std::string(), "hello"))))); |
294 | 302 |
295 // Try connecting again. | 303 // Try connecting again. |
296 Connect(true); | 304 Connect(true); |
297 } | 305 } |
298 | 306 |
299 TEST_F(XmppSignalStrategyTest, NetworkError) { | 307 TEST_F(XmppSignalStrategyTest, NetworkReadError) { |
300 CreateSignalStrategy(kDefaultPort); | 308 CreateSignalStrategy(kDefaultPort); |
301 Connect(true); | 309 Connect(true); |
302 | 310 |
303 socket_data_provider_->SimulateNetworkError(); | 311 socket_data_provider_->SimulateAsyncReadError(); |
304 | 312 |
305 EXPECT_EQ(3U, state_history_.size()); | 313 EXPECT_EQ(3U, state_history_.size()); |
306 EXPECT_EQ(SignalStrategy::DISCONNECTED, state_history_[2]); | 314 EXPECT_EQ(SignalStrategy::DISCONNECTED, state_history_[2]); |
307 EXPECT_EQ(SignalStrategy::NETWORK_ERROR, signal_strategy_->GetError()); | 315 EXPECT_EQ(SignalStrategy::NETWORK_ERROR, signal_strategy_->GetError()); |
308 | 316 |
309 // Can't send messages anymore. | 317 // Can't send messages anymore. |
310 EXPECT_FALSE(signal_strategy_->SendStanza(make_scoped_ptr( | 318 EXPECT_FALSE(signal_strategy_->SendStanza(make_scoped_ptr( |
311 new buzz::XmlElement(buzz::QName(std::string(), "hello"))))); | 319 new buzz::XmlElement(buzz::QName(std::string(), "hello"))))); |
312 | 320 |
313 // Try connecting again. | 321 // Try connecting again. |
314 Connect(true); | 322 Connect(true); |
315 } | 323 } |
316 | 324 |
| 325 TEST_F(XmppSignalStrategyTest, NetworkWriteError) { |
| 326 CreateSignalStrategy(kDefaultPort); |
| 327 Connect(true); |
| 328 |
| 329 socket_data_provider_->set_write_error(net::ERR_FAILED); |
| 330 |
| 331 // Next SendMessage() will call Write() which will fail. |
| 332 EXPECT_FALSE(signal_strategy_->SendStanza(make_scoped_ptr( |
| 333 new buzz::XmlElement(buzz::QName(std::string(), "hello"))))); |
| 334 |
| 335 EXPECT_EQ(3U, state_history_.size()); |
| 336 EXPECT_EQ(SignalStrategy::DISCONNECTED, state_history_[2]); |
| 337 EXPECT_EQ(SignalStrategy::NETWORK_ERROR, signal_strategy_->GetError()); |
| 338 |
| 339 // Try connecting again. |
| 340 Connect(true); |
| 341 } |
| 342 |
317 TEST_F(XmppSignalStrategyTest, StartTlsWithPendingWrite) { | 343 TEST_F(XmppSignalStrategyTest, StartTlsWithPendingWrite) { |
318 // Use port 5222 so that XmppLoginHandler uses starttls/proceed handshake | 344 // Use port 5222 so that XmppLoginHandler uses starttls/proceed handshake |
319 // before starting TLS. | 345 // before starting TLS. |
320 CreateSignalStrategy(5222); | 346 CreateSignalStrategy(5222); |
321 | 347 |
322 socket_data_provider_.reset(new XmppSocketDataProvider()); | 348 socket_data_provider_.reset(new XmppSocketDataProvider()); |
323 socket_data_provider_->set_connect_data( | 349 socket_data_provider_->set_connect_data( |
324 net::MockConnect(net::SYNCHRONOUS, net::OK)); | 350 net::MockConnect(net::SYNCHRONOUS, net::OK)); |
325 client_socket_factory_.AddSocketDataProvider(socket_data_provider_.get()); | 351 client_socket_factory_.AddSocketDataProvider(socket_data_provider_.get()); |
326 | 352 |
(...skipping 19 matching lines...) Expand all Loading... |
346 "<proceed xmlns=\"urn:ietf:params:xml:ns:xmpp-tls\"/>"); | 372 "<proceed xmlns=\"urn:ietf:params:xml:ns:xmpp-tls\"/>"); |
347 | 373 |
348 // Verify that SSL is connected only after write is finished. | 374 // Verify that SSL is connected only after write is finished. |
349 EXPECT_FALSE(client_socket_factory_.ssl_socket_created()); | 375 EXPECT_FALSE(client_socket_factory_.ssl_socket_created()); |
350 socket_data_provider_->CompletePendingWrite(); | 376 socket_data_provider_->CompletePendingWrite(); |
351 EXPECT_TRUE(client_socket_factory_.ssl_socket_created()); | 377 EXPECT_TRUE(client_socket_factory_.ssl_socket_created()); |
352 } | 378 } |
353 | 379 |
354 | 380 |
355 } // namespace remoting | 381 } // namespace remoting |
OLD | NEW |