| 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 <utility> |
| 8 |
| 7 #include "base/base64.h" | 9 #include "base/base64.h" |
| 8 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
| 9 #include "base/run_loop.h" | 11 #include "base/run_loop.h" |
| 10 #include "net/socket/socket_test_util.h" | 12 #include "net/socket/socket_test_util.h" |
| 11 #include "net/url_request/url_request_test_util.h" | 13 #include "net/url_request/url_request_test_util.h" |
| 12 #include "testing/gtest/include/gtest/gtest.h" | 14 #include "testing/gtest/include/gtest/gtest.h" |
| 13 #include "third_party/webrtc/libjingle/xmllite/xmlelement.h" | 15 #include "third_party/webrtc/libjingle/xmllite/xmlelement.h" |
| 14 | 16 |
| 15 namespace remoting { | 17 namespace remoting { |
| 16 | 18 |
| (...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 87 | 89 |
| 88 class MockClientSocketFactory : public net::MockClientSocketFactory { | 90 class MockClientSocketFactory : public net::MockClientSocketFactory { |
| 89 public: | 91 public: |
| 90 scoped_ptr<net::SSLClientSocket> CreateSSLClientSocket( | 92 scoped_ptr<net::SSLClientSocket> CreateSSLClientSocket( |
| 91 scoped_ptr<net::ClientSocketHandle> transport_socket, | 93 scoped_ptr<net::ClientSocketHandle> transport_socket, |
| 92 const net::HostPortPair& host_and_port, | 94 const net::HostPortPair& host_and_port, |
| 93 const net::SSLConfig& ssl_config, | 95 const net::SSLConfig& ssl_config, |
| 94 const net::SSLClientSocketContext& context) override { | 96 const net::SSLClientSocketContext& context) override { |
| 95 ssl_socket_created_ = true; | 97 ssl_socket_created_ = true; |
| 96 return net::MockClientSocketFactory::CreateSSLClientSocket( | 98 return net::MockClientSocketFactory::CreateSSLClientSocket( |
| 97 transport_socket.Pass(), host_and_port, ssl_config, context); | 99 std::move(transport_socket), host_and_port, ssl_config, context); |
| 98 } | 100 } |
| 99 | 101 |
| 100 bool ssl_socket_created() const { return ssl_socket_created_; } | 102 bool ssl_socket_created() const { return ssl_socket_created_; } |
| 101 | 103 |
| 102 private: | 104 private: |
| 103 bool ssl_socket_created_ = false; | 105 bool ssl_socket_created_ = false; |
| 104 }; | 106 }; |
| 105 | 107 |
| 106 } // namespace | 108 } // namespace |
| 107 | 109 |
| 108 const char kTestUsername[] = "test_username@example.com"; | 110 const char kTestUsername[] = "test_username@example.com"; |
| 109 const char kTestAuthToken[] = "test_auth_token"; | 111 const char kTestAuthToken[] = "test_auth_token"; |
| 110 const int kDefaultPort = 443; | 112 const int kDefaultPort = 443; |
| 111 | 113 |
| 112 class XmppSignalStrategyTest : public testing::Test, | 114 class XmppSignalStrategyTest : public testing::Test, |
| 113 public SignalStrategy::Listener { | 115 public SignalStrategy::Listener { |
| 114 public: | 116 public: |
| 115 XmppSignalStrategyTest() : message_loop_(base::MessageLoop::TYPE_IO) {} | 117 XmppSignalStrategyTest() : message_loop_(base::MessageLoop::TYPE_IO) {} |
| 116 | 118 |
| 117 void SetUp() override { | 119 void SetUp() override { |
| 118 scoped_ptr<net::TestURLRequestContext> context( | |
| 119 new net::TestURLRequestContext()); | |
| 120 request_context_getter_ = new net::TestURLRequestContextGetter( | 120 request_context_getter_ = new net::TestURLRequestContextGetter( |
| 121 message_loop_.task_runner(), context.Pass()); | 121 message_loop_.task_runner(), |
| 122 make_scoped_ptr(new net::TestURLRequestContext())); |
| 122 } | 123 } |
| 123 | 124 |
| 124 void CreateSignalStrategy(int port) { | 125 void CreateSignalStrategy(int port) { |
| 125 XmppSignalStrategy::XmppServerConfig config; | 126 XmppSignalStrategy::XmppServerConfig config; |
| 126 config.host = "talk.google.com"; | 127 config.host = "talk.google.com"; |
| 127 config.port = port; | 128 config.port = port; |
| 128 config.username = kTestUsername; | 129 config.username = kTestUsername; |
| 129 config.auth_token = kTestAuthToken; | 130 config.auth_token = kTestAuthToken; |
| 130 signal_strategy_.reset(new XmppSignalStrategy( | 131 signal_strategy_.reset(new XmppSignalStrategy( |
| 131 &client_socket_factory_, request_context_getter_, config)); | 132 &client_socket_factory_, request_context_getter_, config)); |
| (...skipping 240 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 372 "<proceed xmlns=\"urn:ietf:params:xml:ns:xmpp-tls\"/>"); | 373 "<proceed xmlns=\"urn:ietf:params:xml:ns:xmpp-tls\"/>"); |
| 373 | 374 |
| 374 // Verify that SSL is connected only after write is finished. | 375 // Verify that SSL is connected only after write is finished. |
| 375 EXPECT_FALSE(client_socket_factory_.ssl_socket_created()); | 376 EXPECT_FALSE(client_socket_factory_.ssl_socket_created()); |
| 376 socket_data_provider_->CompletePendingWrite(); | 377 socket_data_provider_->CompletePendingWrite(); |
| 377 EXPECT_TRUE(client_socket_factory_.ssl_socket_created()); | 378 EXPECT_TRUE(client_socket_factory_.ssl_socket_created()); |
| 378 } | 379 } |
| 379 | 380 |
| 380 | 381 |
| 381 } // namespace remoting | 382 } // namespace remoting |
| OLD | NEW |