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

Side by Side Diff: remoting/host/security_key/security_key_auth_handler_linux_unittest.cc

Issue 2168303003: Removing 'AllowScopedIO' exception from SecurityKeyAuthHandlerLinux (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@temp_dir
Patch Set: Fixing some comments Created 4 years, 5 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
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 <stddef.h> 5 #include <stddef.h>
6 6
7 #include <memory>
8 #include <string>
9
10 #include "base/bind.h"
7 #include "base/files/file_path.h" 11 #include "base/files/file_path.h"
8 #include "base/files/scoped_temp_dir.h" 12 #include "base/files/scoped_temp_dir.h"
9 #include "base/macros.h" 13 #include "base/macros.h"
10 #include "base/message_loop/message_loop.h" 14 #include "base/message_loop/message_loop.h"
11 #include "base/run_loop.h" 15 #include "base/run_loop.h"
12 #include "base/strings/stringprintf.h" 16 #include "base/threading/thread.h"
13 #include "base/timer/mock_timer.h"
14 #include "base/values.h"
15 #include "net/base/io_buffer.h" 17 #include "net/base/io_buffer.h"
16 #include "net/base/net_errors.h" 18 #include "net/base/net_errors.h"
17 #include "net/base/test_completion_callback.h" 19 #include "net/base/test_completion_callback.h"
18 #include "net/socket/unix_domain_client_socket_posix.h" 20 #include "net/socket/unix_domain_client_socket_posix.h"
19 #include "remoting/host/security_key/security_key_auth_handler.h" 21 #include "remoting/host/security_key/security_key_auth_handler.h"
20 #include "remoting/host/security_key/security_key_socket.h" 22 #include "remoting/host/security_key/security_key_socket.h"
21 #include "remoting/proto/internal.pb.h"
22 #include "testing/gtest/include/gtest/gtest.h" 23 #include "testing/gtest/include/gtest/gtest.h"
23 24
24 namespace remoting { 25 namespace remoting {
25 26
26 namespace { 27 namespace {
27 28
28 const char kSocketFilename[] = "socket_for_testing"; 29 const char kSocketFilename[] = "socket_for_testing";
29 30
30 // Test security key request data. 31 // Test security key request data.
31 const unsigned char kRequestData[] = { 32 const unsigned char kRequestData[] = {
32 0x00, 0x00, 0x00, 0x9a, 0x65, 0x1e, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 33 0x00, 0x00, 0x00, 0x9a, 0x65, 0x1e, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00,
33 0x00, 0x90, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x60, 0x90, 34 0x00, 0x90, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x60, 0x90,
34 0x24, 0x71, 0xf8, 0xf2, 0xe5, 0xdf, 0x7f, 0x81, 0xc7, 0x49, 0xc4, 0xa3, 35 0x24, 0x71, 0xf8, 0xf2, 0xe5, 0xdf, 0x7f, 0x81, 0xc7, 0x49, 0xc4, 0xa3,
35 0x58, 0x5c, 0xf6, 0xcc, 0x40, 0x14, 0x28, 0x0c, 0xa0, 0xfa, 0x03, 0x18, 36 0x58, 0x5c, 0xf6, 0xcc, 0x40, 0x14, 0x28, 0x0c, 0xa0, 0xfa, 0x03, 0x18,
36 0x38, 0xd8, 0x7d, 0x77, 0x2b, 0x3a, 0x00, 0x00, 0x00, 0x20, 0x64, 0x46, 37 0x38, 0xd8, 0x7d, 0x77, 0x2b, 0x3a, 0x00, 0x00, 0x00, 0x20, 0x64, 0x46,
37 0x47, 0x2f, 0xdf, 0x6e, 0xed, 0x7b, 0xf3, 0xc3, 0x37, 0x20, 0xf2, 0x36, 38 0x47, 0x2f, 0xdf, 0x6e, 0xed, 0x7b, 0xf3, 0xc3, 0x37, 0x20, 0xf2, 0x36,
38 0x67, 0x6c, 0x36, 0xe1, 0xb4, 0x5e, 0xbe, 0x04, 0x85, 0xdb, 0x89, 0xa3, 39 0x67, 0x6c, 0x36, 0xe1, 0xb4, 0x5e, 0xbe, 0x04, 0x85, 0xdb, 0x89, 0xa3,
39 0xcd, 0xfd, 0xd2, 0x4b, 0xd6, 0x9f, 0x00, 0x00, 0x00, 0x40, 0x38, 0x35, 40 0xcd, 0xfd, 0xd2, 0x4b, 0xd6, 0x9f, 0x00, 0x00, 0x00, 0x40, 0x38, 0x35,
40 0x05, 0x75, 0x1d, 0x13, 0x6e, 0xb3, 0x6b, 0x1d, 0x29, 0xae, 0xd3, 0x43, 41 0x05, 0x75, 0x1d, 0x13, 0x6e, 0xb3, 0x6b, 0x1d, 0x29, 0xae, 0xd3, 0x43,
41 0xe6, 0x84, 0x8f, 0xa3, 0x9d, 0x65, 0x4e, 0x2f, 0x57, 0xe3, 0xf6, 0xe6, 42 0xe6, 0x84, 0x8f, 0xa3, 0x9d, 0x65, 0x4e, 0x2f, 0x57, 0xe3, 0xf6, 0xe6,
42 0x20, 0x3c, 0x00, 0xc6, 0xe1, 0x73, 0x34, 0xe2, 0x23, 0x99, 0xc4, 0xfa, 43 0x20, 0x3c, 0x00, 0xc6, 0xe1, 0x73, 0x34, 0xe2, 0x23, 0x99, 0xc4, 0xfa,
43 0x91, 0xc2, 0xd5, 0x97, 0xc1, 0x8b, 0xd0, 0x3c, 0x13, 0xba, 0xf0, 0xd7, 44 0x91, 0xc2, 0xd5, 0x97, 0xc1, 0x8b, 0xd0, 0x3c, 0x13, 0xba, 0xf0, 0xd7,
44 0x5e, 0xa3, 0xbc, 0x02, 0x5b, 0xec, 0xe4, 0x4b, 0xae, 0x0e, 0xf2, 0xbd, 45 0x5e, 0xa3, 0xbc, 0x02, 0x5b, 0xec, 0xe4, 0x4b, 0xae, 0x0e, 0xf2, 0xbd,
45 0xc8, 0xaa}; 46 0xc8, 0xaa};
46 47
48 void RunUntilIdle() {
49 base::RunLoop run_loop;
50 run_loop.RunUntilIdle();
51 }
52
47 } // namespace 53 } // namespace
48 54
49 class SecurityKeyAuthHandlerLinuxTest : public testing::Test { 55 class SecurityKeyAuthHandlerLinuxTest : public testing::Test {
50 public: 56 public:
51 SecurityKeyAuthHandlerLinuxTest() 57 SecurityKeyAuthHandlerLinuxTest()
52 : run_loop_(new base::RunLoop()), last_connection_id_received_(-1) { 58 : run_loop_(new base::RunLoop()),
59 file_thread_("SecurityKeyAuthHandlerLinuxTest_FileThread") {
53 EXPECT_TRUE(temp_dir_.CreateUniqueTempDir()); 60 EXPECT_TRUE(temp_dir_.CreateUniqueTempDir());
54 socket_path_ = temp_dir_.path().Append(kSocketFilename); 61 socket_path_ = temp_dir_.path().Append(kSocketFilename);
55 remoting::SecurityKeyAuthHandler::SetSecurityKeySocketName(socket_path_); 62 remoting::SecurityKeyAuthHandler::SetSecurityKeySocketName(socket_path_);
56 63
64 EXPECT_TRUE(file_thread_.StartWithOptions(
65 base::Thread::Options(base::MessageLoop::TYPE_IO, 0)));
66
57 send_message_callback_ = 67 send_message_callback_ =
58 base::Bind(&SecurityKeyAuthHandlerLinuxTest::SendMessageToClient, 68 base::Bind(&SecurityKeyAuthHandlerLinuxTest::SendMessageToClient,
59 base::Unretained(this)); 69 base::Unretained(this));
70
60 auth_handler_ = remoting::SecurityKeyAuthHandler::Create( 71 auth_handler_ = remoting::SecurityKeyAuthHandler::Create(
61 nullptr, send_message_callback_); 72 /*client_session_details=*/nullptr, send_message_callback_,
73 file_thread_.task_runner());
74 EXPECT_NE(auth_handler_.get(), nullptr);
62 } 75 }
63 76
64 void WaitForSendMessageToClient() { 77 void CreateSocketAndWait() {
78 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest());
79 auth_handler_->CreateSecurityKeyConnection();
80
81 ASSERT_TRUE(file_thread_.task_runner()->PostTaskAndReply(
82 FROM_HERE, base::Bind(&RunUntilIdle), run_loop_->QuitClosure()));
65 run_loop_->Run(); 83 run_loop_->Run();
66 run_loop_.reset(new base::RunLoop); 84 run_loop_.reset(new base::RunLoop);
85
86 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest());
67 } 87 }
68 88
69 void SendMessageToClient(int connection_id, const std::string& data) { 89 void SendMessageToClient(int connection_id, const std::string& data) {
70 last_connection_id_received_ = connection_id; 90 last_connection_id_received_ = connection_id;
71 last_message_received_ = data; 91 last_message_received_ = data;
72 run_loop_->Quit(); 92 run_loop_->Quit();
73 } 93 }
74 94
95 void WaitForSendMessageToClient() {
96 run_loop_->Run();
97 run_loop_.reset(new base::RunLoop);
98 }
99
75 void CheckHostDataMessage(int id, const std::string& expected_data) { 100 void CheckHostDataMessage(int id, const std::string& expected_data) {
76 ASSERT_EQ(id, last_connection_id_received_); 101 ASSERT_EQ(id, last_connection_id_received_);
77 ASSERT_EQ(expected_data.length(), last_message_received_.length()); 102 ASSERT_EQ(expected_data.length(), last_message_received_.length());
78 ASSERT_EQ(expected_data, last_message_received_); 103 ASSERT_EQ(expected_data, last_message_received_);
79 } 104 }
80 105
81 void WriteRequestData(net::UnixDomainClientSocket* client_socket) { 106 void WriteRequestData(net::UnixDomainClientSocket* client_socket) {
82 int request_len = sizeof(kRequestData); 107 int request_len = sizeof(kRequestData);
83 scoped_refptr<net::DrainableIOBuffer> request_buffer( 108 scoped_refptr<net::DrainableIOBuffer> request_buffer(
84 new net::DrainableIOBuffer( 109 new net::DrainableIOBuffer(
(...skipping 25 matching lines...) Expand all
110 expected_data.append(1, static_cast<unsigned char>(kRequestData[i])); 135 expected_data.append(1, static_cast<unsigned char>(kRequestData[i]));
111 } 136 }
112 137
113 CheckHostDataMessage(connection_id, expected_data); 138 CheckHostDataMessage(connection_id, expected_data);
114 } 139 }
115 140
116 protected: 141 protected:
117 base::MessageLoopForIO message_loop_; 142 base::MessageLoopForIO message_loop_;
118 std::unique_ptr<base::RunLoop> run_loop_; 143 std::unique_ptr<base::RunLoop> run_loop_;
119 144
145 base::Thread file_thread_;
146
120 // Object under test. 147 // Object under test.
121 std::unique_ptr<SecurityKeyAuthHandler> auth_handler_; 148 std::unique_ptr<SecurityKeyAuthHandler> auth_handler_;
122 149
123 SecurityKeyAuthHandler::SendMessageCallback send_message_callback_; 150 SecurityKeyAuthHandler::SendMessageCallback send_message_callback_;
124 151
125 int last_connection_id_received_; 152 int last_connection_id_received_ = -1;
126 std::string last_message_received_; 153 std::string last_message_received_;
127 154
128 base::ScopedTempDir temp_dir_; 155 base::ScopedTempDir temp_dir_;
129 base::FilePath socket_path_; 156 base::FilePath socket_path_;
130 base::Closure accept_callback_; 157 base::Closure accept_callback_;
131 158
132 private: 159 private:
133 DISALLOW_COPY_AND_ASSIGN(SecurityKeyAuthHandlerLinuxTest); 160 DISALLOW_COPY_AND_ASSIGN(SecurityKeyAuthHandlerLinuxTest);
134 }; 161 };
135 162
136 TEST_F(SecurityKeyAuthHandlerLinuxTest, NotClosedAfterRequest) { 163 TEST_F(SecurityKeyAuthHandlerLinuxTest, NotClosedAfterRequest) {
137 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest()); 164 CreateSocketAndWait();
138
139 auth_handler_->CreateSecurityKeyConnection();
140 165
141 net::UnixDomainClientSocket client_socket(socket_path_.value(), false); 166 net::UnixDomainClientSocket client_socket(socket_path_.value(), false);
142 net::TestCompletionCallback connect_callback; 167 net::TestCompletionCallback connect_callback;
143 168
144 int rv = client_socket.Connect(connect_callback.callback()); 169 int rv = client_socket.Connect(connect_callback.callback());
145 ASSERT_EQ(net::OK, connect_callback.GetResult(rv)); 170 ASSERT_EQ(net::OK, connect_callback.GetResult(rv));
146 171
147 // Write the request and verify the response. 172 // Write the request and verify the response.
148 WriteRequestData(&client_socket); 173 WriteRequestData(&client_socket);
149 WaitForAndVerifyHostMessage(1); 174 WaitForAndVerifyHostMessage(1);
150 175
151 // Verify the connection is now valid. 176 // Verify the connection is now valid.
152 ASSERT_TRUE(auth_handler_->IsValidConnectionId(1)); 177 ASSERT_TRUE(auth_handler_->IsValidConnectionId(1));
153 178
154 // Verify that completing a request/response cycle didn't close the socket. 179 // Verify that completing a request/response cycle didn't close the socket.
155 ASSERT_EQ(1u, auth_handler_->GetActiveConnectionCountForTest()); 180 ASSERT_EQ(1u, auth_handler_->GetActiveConnectionCountForTest());
156 } 181 }
157 182
158 TEST_F(SecurityKeyAuthHandlerLinuxTest, HandleTwoRequests) { 183 TEST_F(SecurityKeyAuthHandlerLinuxTest, HandleTwoRequests) {
159 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest()); 184 CreateSocketAndWait();
160
161 auth_handler_->CreateSecurityKeyConnection();
162 185
163 net::UnixDomainClientSocket client_socket(socket_path_.value(), false); 186 net::UnixDomainClientSocket client_socket(socket_path_.value(), false);
164 net::TestCompletionCallback connect_callback; 187 net::TestCompletionCallback connect_callback;
165 188
166 int rv = client_socket.Connect(connect_callback.callback()); 189 int rv = client_socket.Connect(connect_callback.callback());
167 ASSERT_EQ(net::OK, connect_callback.GetResult(rv)); 190 ASSERT_EQ(net::OK, connect_callback.GetResult(rv));
168 191
169 // Write the request and verify the response. 192 // Write the request and verify the response.
170 WriteRequestData(&client_socket); 193 WriteRequestData(&client_socket);
171 WaitForAndVerifyHostMessage(1); 194 WaitForAndVerifyHostMessage(1);
172 195
173 // Verify the connection is now valid. 196 // Verify the connection is now valid.
174 ASSERT_TRUE(auth_handler_->IsValidConnectionId(1)); 197 ASSERT_TRUE(auth_handler_->IsValidConnectionId(1));
175 198
176 // Repeat the request/response cycle. 199 // Repeat the request/response cycle.
177 WriteRequestData(&client_socket); 200 WriteRequestData(&client_socket);
178 WaitForAndVerifyHostMessage(1); 201 WaitForAndVerifyHostMessage(1);
179 202
180 // Verify the connection is still valid. 203 // Verify the connection is still valid.
181 ASSERT_TRUE(auth_handler_->IsValidConnectionId(1)); 204 ASSERT_TRUE(auth_handler_->IsValidConnectionId(1));
182 205
183 // Verify that completing two request/response cycles didn't close the 206 // Verify that completing two request/response cycles didn't close the
184 // socket. 207 // socket.
185 ASSERT_EQ(1u, auth_handler_->GetActiveConnectionCountForTest()); 208 ASSERT_EQ(1u, auth_handler_->GetActiveConnectionCountForTest());
186 } 209 }
187 210
188 TEST_F(SecurityKeyAuthHandlerLinuxTest, HandleTwoIndependentRequests) { 211 TEST_F(SecurityKeyAuthHandlerLinuxTest, HandleTwoIndependentRequests) {
189 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest()); 212 CreateSocketAndWait();
190
191 auth_handler_->CreateSecurityKeyConnection();
192 213
193 net::UnixDomainClientSocket client_socket(socket_path_.value(), false); 214 net::UnixDomainClientSocket client_socket(socket_path_.value(), false);
194 net::TestCompletionCallback connect_callback; 215 net::TestCompletionCallback connect_callback;
195 216
196 int rv = client_socket.Connect(connect_callback.callback()); 217 int rv = client_socket.Connect(connect_callback.callback());
197 ASSERT_EQ(net::OK, connect_callback.GetResult(rv)); 218 ASSERT_EQ(net::OK, connect_callback.GetResult(rv));
198 219
199 // Write the request and verify the response. 220 // Write the request and verify the response.
200 WriteRequestData(&client_socket); 221 WriteRequestData(&client_socket);
201 WaitForAndVerifyHostMessage(1); 222 WaitForAndVerifyHostMessage(1);
(...skipping 12 matching lines...) Expand all
214 235
215 // Verify the second connection is valid and the first is not. 236 // Verify the second connection is valid and the first is not.
216 ASSERT_TRUE(auth_handler_->IsValidConnectionId(2)); 237 ASSERT_TRUE(auth_handler_->IsValidConnectionId(2));
217 ASSERT_FALSE(auth_handler_->IsValidConnectionId(1)); 238 ASSERT_FALSE(auth_handler_->IsValidConnectionId(1));
218 239
219 // Verify that the initial socket was released properly. 240 // Verify that the initial socket was released properly.
220 ASSERT_EQ(1u, auth_handler_->GetActiveConnectionCountForTest()); 241 ASSERT_EQ(1u, auth_handler_->GetActiveConnectionCountForTest());
221 } 242 }
222 243
223 TEST_F(SecurityKeyAuthHandlerLinuxTest, DidReadTimeout) { 244 TEST_F(SecurityKeyAuthHandlerLinuxTest, DidReadTimeout) {
224 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest()); 245 CreateSocketAndWait();
225 auth_handler_->CreateSecurityKeyConnection();
226 246
227 net::UnixDomainClientSocket client_socket(socket_path_.value(), false); 247 net::UnixDomainClientSocket client_socket(socket_path_.value(), false);
228 net::TestCompletionCallback connect_callback; 248 net::TestCompletionCallback connect_callback;
229 int rv = client_socket.Connect(connect_callback.callback()); 249 int rv = client_socket.Connect(connect_callback.callback());
230 ASSERT_EQ(net::OK, connect_callback.GetResult(rv)); 250 ASSERT_EQ(net::OK, connect_callback.GetResult(rv));
231 auth_handler_->SetRequestTimeoutForTest(base::TimeDelta()); 251 auth_handler_->SetRequestTimeoutForTest(base::TimeDelta());
232 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest()); 252 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest());
233 } 253 }
234 254
235 TEST_F(SecurityKeyAuthHandlerLinuxTest, ClientErrorMessageDelivered) { 255 TEST_F(SecurityKeyAuthHandlerLinuxTest, ClientErrorMessageDelivered) {
236 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest()); 256 CreateSocketAndWait();
237 auth_handler_->CreateSecurityKeyConnection();
238 257
239 net::UnixDomainClientSocket client_socket(socket_path_.value(), false); 258 net::UnixDomainClientSocket client_socket(socket_path_.value(), false);
240 net::TestCompletionCallback connect_callback; 259 net::TestCompletionCallback connect_callback;
241 int rv = client_socket.Connect(connect_callback.callback()); 260 int rv = client_socket.Connect(connect_callback.callback());
242 ASSERT_EQ(net::OK, connect_callback.GetResult(rv)); 261 ASSERT_EQ(net::OK, connect_callback.GetResult(rv));
243 262
244 auth_handler_->SendErrorAndCloseConnection(1); 263 auth_handler_->SendErrorAndCloseConnection(1);
245 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest()); 264 ASSERT_EQ(0u, auth_handler_->GetActiveConnectionCountForTest());
246 } 265 }
247 266
248 } // namespace remoting 267 } // namespace remoting
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698