Revert of Add button to add new FSP services to Files app. (patchset #8 id:140001...
[chromium-blink-merge.git] / remoting / test / test_chromoting_client.cc
blobadf1093893c11cfbb5a2ef9ec1ebacee23cc17d0
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
3 // found in the LICENSE file.
5 #include "remoting/test/test_chromoting_client.h"
7 #include <string>
8 #include <vector>
10 #include "base/logging.h"
11 #include "base/thread_task_runner_handle.h"
12 #include "jingle/glue/thread_wrapper.h"
13 #include "net/base/request_priority.h"
14 #include "net/socket/client_socket_factory.h"
15 #include "remoting/base/url_request_context_getter.h"
16 #include "remoting/client/audio_player.h"
17 #include "remoting/client/chromoting_client.h"
18 #include "remoting/client/client_context.h"
19 #include "remoting/client/token_fetcher_proxy.h"
20 #include "remoting/protocol/authentication_method.h"
21 #include "remoting/protocol/chromium_port_allocator.h"
22 #include "remoting/protocol/host_stub.h"
23 #include "remoting/protocol/libjingle_transport_factory.h"
24 #include "remoting/protocol/negotiating_client_authenticator.h"
25 #include "remoting/protocol/network_settings.h"
26 #include "remoting/protocol/session_config.h"
27 #include "remoting/protocol/third_party_client_authenticator.h"
28 #include "remoting/signaling/xmpp_signal_strategy.h"
29 #include "remoting/test/remote_host_info_fetcher.h"
30 #include "remoting/test/test_video_renderer.h"
32 namespace {
34 const char kAppRemotingCapabilities[] =
35 "rateLimitResizeRequests desktopShape sendInitialResolution googleDrive";
37 const char kXmppHostName[] = "talk.google.com";
38 const int kXmppPortNumber = 5222;
40 // Used as the TokenFetcherCallback for App Remoting sessions.
41 void FetchThirdPartyToken(
42 const std::string& authorization_token,
43 const std::string& shared_secret,
44 const GURL& token_url,
45 const std::string& host_public_key,
46 const std::string& scope,
47 base::WeakPtr<remoting::TokenFetcherProxy> token_fetcher_proxy) {
48 DVLOG(1) << "FetchThirdPartyToken("
49 << "token_url: " << token_url << ", "
50 << "host_public_key: " << host_public_key << ", "
51 << "scope: " << scope << ") Called";
53 if (token_fetcher_proxy) {
54 token_fetcher_proxy->OnTokenFetched(authorization_token, shared_secret);
55 token_fetcher_proxy.reset();
56 } else {
57 LOG(ERROR) << "Invalid token fetcher proxy passed in";
61 const char* ConnectionStateToFriendlyString(
62 remoting::protocol::ConnectionToHost::State state) {
63 switch (state) {
64 case remoting::protocol::ConnectionToHost::INITIALIZING:
65 return "INITIALIZING";
67 case remoting::protocol::ConnectionToHost::CONNECTING:
68 return "CONNECTING";
70 case remoting::protocol::ConnectionToHost::AUTHENTICATED:
71 return "AUTHENTICATED";
73 case remoting::protocol::ConnectionToHost::CONNECTED:
74 return "CONNECTED";
76 case remoting::protocol::ConnectionToHost::CLOSED:
77 return "CLOSED";
79 case remoting::protocol::ConnectionToHost::FAILED:
80 return "FAILED";
82 default:
83 LOG(ERROR) << "Unknown connection state: '" << state << "'";
84 return "UNKNOWN";
88 const char* ProtocolErrorToFriendlyString(
89 remoting::protocol::ErrorCode error_code) {
90 switch (error_code) {
91 case remoting::protocol::OK:
92 return "NONE";
94 case remoting::protocol::PEER_IS_OFFLINE:
95 return "PEER_IS_OFFLINE";
97 case remoting::protocol::SESSION_REJECTED:
98 return "SESSION_REJECTED";
100 case remoting::protocol::AUTHENTICATION_FAILED:
101 return "AUTHENTICATION_FAILED";
103 case remoting::protocol::INCOMPATIBLE_PROTOCOL:
104 return "INCOMPATIBLE_PROTOCOL";
106 case remoting::protocol::HOST_OVERLOAD:
107 return "HOST_OVERLOAD";
109 case remoting::protocol::CHANNEL_CONNECTION_ERROR:
110 return "CHANNEL_CONNECTION_ERROR";
112 case remoting::protocol::SIGNALING_ERROR:
113 return "SIGNALING_ERROR";
115 case remoting::protocol::SIGNALING_TIMEOUT:
116 return "SIGNALING_TIMEOUT";
118 case remoting::protocol::UNKNOWN_ERROR:
119 return "UNKNOWN_ERROR";
121 default:
122 LOG(ERROR) << "Unrecognized error code: '" << error_code << "'";
123 return "UNKNOWN_ERROR";
127 } // namespace
129 namespace remoting {
130 namespace test {
132 TestChromotingClient::TestChromotingClient()
133 : connection_to_host_state_(protocol::ConnectionToHost::INITIALIZING),
134 connection_error_code_(protocol::OK) {
137 TestChromotingClient::~TestChromotingClient() {
138 // Ensure any connections are closed and the members are destroyed in the
139 // appropriate order.
140 EndConnection();
143 void TestChromotingClient::StartConnection(
144 const std::string& user_name,
145 const std::string& access_token,
146 const RemoteHostInfo& remote_host_info) {
147 DCHECK(!user_name.empty());
148 DCHECK(!access_token.empty());
149 DCHECK(remote_host_info.IsReadyForConnection());
151 // Required to establish a connection to the host.
152 jingle_glue::JingleThreadWrapper::EnsureForCurrentMessageLoop();
154 scoped_refptr<URLRequestContextGetter> request_context_getter;
155 request_context_getter = new URLRequestContextGetter(
156 base::ThreadTaskRunnerHandle::Get(), // network_runner
157 base::ThreadTaskRunnerHandle::Get()); // file_runner
159 client_context_.reset(new ClientContext(base::ThreadTaskRunnerHandle::Get()));
161 video_renderer_.reset(new TestVideoRenderer());
163 chromoting_client_.reset(new ChromotingClient(client_context_.get(),
164 this, // client_user_interface.
165 video_renderer_.get(),
166 nullptr)); // audio_player
168 if (test_connection_to_host_) {
169 chromoting_client_->SetConnectionToHostForTests(
170 test_connection_to_host_.Pass());
173 XmppSignalStrategy::XmppServerConfig xmpp_server_config;
174 xmpp_server_config.host = kXmppHostName;
175 xmpp_server_config.port = kXmppPortNumber;
176 xmpp_server_config.use_tls = true;
177 xmpp_server_config.username = user_name;
178 xmpp_server_config.auth_token = access_token;
180 // Set up the signal strategy. This must outlive the client object.
181 signal_strategy_.reset(
182 new XmppSignalStrategy(net::ClientSocketFactory::GetDefaultFactory(),
183 request_context_getter, xmpp_server_config));
185 protocol::NetworkSettings network_settings(
186 protocol::NetworkSettings::NAT_TRAVERSAL_FULL);
188 scoped_ptr<protocol::ChromiumPortAllocator> port_allocator(
189 protocol::ChromiumPortAllocator::Create(request_context_getter,
190 network_settings));
192 scoped_ptr<protocol::TransportFactory> transport_factory(
193 new protocol::LibjingleTransportFactory(
194 signal_strategy_.get(), port_allocator.Pass(), network_settings));
196 scoped_ptr<protocol::ThirdPartyClientAuthenticator::TokenFetcher>
197 token_fetcher(new TokenFetcherProxy(
198 base::Bind(&FetchThirdPartyToken, remote_host_info.authorization_code,
199 remote_host_info.shared_secret),
200 "FAKE_HOST_PUBLIC_KEY"));
202 std::vector<protocol::AuthenticationMethod> auth_methods;
203 auth_methods.push_back(protocol::AuthenticationMethod::ThirdParty());
205 // FetchSecretCallback is used for PIN based auth which we aren't using so we
206 // can pass a null callback here.
207 protocol::FetchSecretCallback fetch_secret_callback;
208 scoped_ptr<protocol::Authenticator> authenticator(
209 new protocol::NegotiatingClientAuthenticator(
210 std::string(), // client_pairing_id
211 std::string(), // shared_secret
212 std::string(), // authentication_tag
213 fetch_secret_callback, token_fetcher.Pass(), auth_methods));
215 chromoting_client_->Start(signal_strategy_.get(), authenticator.Pass(),
216 transport_factory.Pass(), remote_host_info.host_jid,
217 kAppRemotingCapabilities);
220 void TestChromotingClient::EndConnection() {
221 // Clearing out the client will close the connection.
222 chromoting_client_.reset();
224 // The signal strategy object must outlive the client so destroy it next.
225 signal_strategy_.reset();
227 // The connection state will be updated when the chromoting client was
228 // destroyed if an active connection was established, but not in other cases.
229 // We should be consistent in either case so we will set the state if needed.
230 if (connection_to_host_state_ != protocol::ConnectionToHost::CLOSED &&
231 connection_to_host_state_ != protocol::ConnectionToHost::FAILED &&
232 connection_error_code_ == protocol::OK) {
233 OnConnectionState(protocol::ConnectionToHost::CLOSED, protocol::OK);
237 void TestChromotingClient::AddRemoteConnectionObserver(
238 RemoteConnectionObserver* observer) {
239 DCHECK(observer);
241 connection_observers_.AddObserver(observer);
244 void TestChromotingClient::RemoveRemoteConnectionObserver(
245 RemoteConnectionObserver* observer) {
246 DCHECK(observer);
248 connection_observers_.RemoveObserver(observer);
251 void TestChromotingClient::SetConnectionToHostForTests(
252 scoped_ptr<protocol::ConnectionToHost> connection_to_host) {
253 test_connection_to_host_ = connection_to_host.Pass();
256 void TestChromotingClient::OnConnectionState(
257 protocol::ConnectionToHost::State state,
258 protocol::ErrorCode error_code) {
259 DVLOG(1) << "TestChromotingClient::OnConnectionState("
260 << "state: " << ConnectionStateToFriendlyString(state) << ", "
261 << "error_code: " << ProtocolErrorToFriendlyString(error_code)
262 << ") Called";
264 connection_error_code_ = error_code;
265 connection_to_host_state_ = state;
267 FOR_EACH_OBSERVER(RemoteConnectionObserver, connection_observers_,
268 ConnectionStateChanged(state, error_code));
271 void TestChromotingClient::OnConnectionReady(bool ready) {
272 DVLOG(1) << "TestChromotingClient::OnConnectionReady("
273 << "ready:" << ready << ") Called";
275 FOR_EACH_OBSERVER(RemoteConnectionObserver, connection_observers_,
276 ConnectionReady(ready));
279 void TestChromotingClient::OnRouteChanged(
280 const std::string& channel_name,
281 const protocol::TransportRoute& route) {
282 DVLOG(1) << "TestChromotingClient::OnRouteChanged("
283 << "channel_name:" << channel_name << ", "
284 << "route:" << protocol::TransportRoute::GetTypeString(route.type)
285 << ") Called";
287 FOR_EACH_OBSERVER(RemoteConnectionObserver, connection_observers_,
288 RouteChanged(channel_name, route));
291 void TestChromotingClient::SetCapabilities(const std::string& capabilities) {
292 DVLOG(1) << "TestChromotingClient::SetCapabilities("
293 << "capabilities: " << capabilities << ") Called";
295 FOR_EACH_OBSERVER(RemoteConnectionObserver, connection_observers_,
296 CapabilitiesSet(capabilities));
299 void TestChromotingClient::SetPairingResponse(
300 const protocol::PairingResponse& pairing_response) {
301 DVLOG(1) << "TestChromotingClient::SetPairingResponse("
302 << "client_id: " << pairing_response.client_id() << ", "
303 << "shared_secret: " << pairing_response.shared_secret()
304 << ") Called";
306 FOR_EACH_OBSERVER(RemoteConnectionObserver, connection_observers_,
307 PairingResponseSet(pairing_response));
310 void TestChromotingClient::DeliverHostMessage(
311 const protocol::ExtensionMessage& message) {
312 DVLOG(1) << "TestChromotingClient::DeliverHostMessage("
313 << "type: " << message.type() << ", "
314 << "data: " << message.data() << ") Called";
316 FOR_EACH_OBSERVER(RemoteConnectionObserver, connection_observers_,
317 HostMessageReceived(message));
320 protocol::ClipboardStub* TestChromotingClient::GetClipboardStub() {
321 DVLOG(1) << "TestChromotingClient::GetClipboardStub() Called";
322 return this;
325 protocol::CursorShapeStub* TestChromotingClient::GetCursorShapeStub() {
326 DVLOG(1) << "TestChromotingClient::GetCursorShapeStub() Called";
327 return this;
330 void TestChromotingClient::InjectClipboardEvent(
331 const protocol::ClipboardEvent& event) {
332 DVLOG(1) << "TestChromotingClient::InjectClipboardEvent() Called";
335 void TestChromotingClient::SetCursorShape(
336 const protocol::CursorShapeInfo& cursor_shape) {
337 DVLOG(1) << "TestChromotingClient::SetCursorShape() Called";
340 } // namespace test
341 } // namespace remoting