OLD | NEW |
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 "remoting/signaling/telemetry_log_writer.h" | 5 #include "remoting/base/telemetry_log_writer.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
9 #include "base/macros.h" | 9 #include "base/macros.h" |
10 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
11 #include "net/http/http_status_code.h" | 11 #include "net/http/http_status_code.h" |
| 12 #include "remoting/base/chromoting_event.h" |
12 #include "remoting/base/url_request.h" | 13 #include "remoting/base/url_request.h" |
13 #include "remoting/signaling/chromoting_event.h" | |
14 #include "testing/gtest/include/gtest/gtest.h" | 14 #include "testing/gtest/include/gtest/gtest.h" |
15 | 15 |
16 namespace remoting { | 16 namespace remoting { |
17 | 17 |
18 class FakeUrlRequest : public UrlRequest { | 18 class FakeUrlRequest : public UrlRequest { |
19 public: | 19 public: |
20 FakeUrlRequest(const std::string& expected_post, | 20 FakeUrlRequest(const std::string& expected_post, |
21 const UrlRequest::Result& returned_result) | 21 const UrlRequest::Result& returned_result) |
22 : expected_post_(expected_post), returned_result_(returned_result) {} | 22 : expected_post_(expected_post), returned_result_(returned_result) {} |
23 | 23 |
(...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
163 respond4.Run(); | 163 respond4.Run(); |
164 respond5.Run(); | 164 respond5.Run(); |
165 } | 165 } |
166 | 166 |
167 TEST_F(TelemetryLogWriterTest, PostOneLogFailedResendWithTwoPendingLogs) { | 167 TEST_F(TelemetryLogWriterTest, PostOneLogFailedResendWithTwoPendingLogs) { |
168 auto respond1 = request_factory_->AddExpectedRequest( | 168 auto respond1 = request_factory_->AddExpectedRequest( |
169 "{\"event\":[{\"id\":0}]}", UrlRequest::Result::Failed()); | 169 "{\"event\":[{\"id\":0}]}", UrlRequest::Result::Failed()); |
170 LogFakeEvent(); | 170 LogFakeEvent(); |
171 | 171 |
172 auto respond2 = request_factory_->AddExpectedRequest( | 172 auto respond2 = request_factory_->AddExpectedRequest( |
173 "{\"event\":[{\"id\":1},{\"id\":2},{\"id\":0}]}", success_result_); | 173 "{\"event\":[{\"id\":0},{\"id\":1},{\"id\":2}]}", success_result_); |
174 LogFakeEvent(); | 174 LogFakeEvent(); |
175 LogFakeEvent(); | 175 LogFakeEvent(); |
176 | 176 |
177 respond1.Run(); | 177 respond1.Run(); |
178 respond2.Run(); | 178 respond2.Run(); |
179 } | 179 } |
180 | 180 |
| 181 TEST_F(TelemetryLogWriterTest, PostThreeLogsFailedAndResendWithOnePending) { |
| 182 // This tests the ordering of the resent log. |
| 183 auto respond1 = request_factory_->AddExpectedRequest( |
| 184 "{\"event\":[{\"id\":0}]}", UrlRequest::Result::Failed()); |
| 185 LogFakeEvent(); |
| 186 |
| 187 auto respond2 = request_factory_->AddExpectedRequest( |
| 188 "{\"event\":[{\"id\":0},{\"id\":1},{\"id\":2}]}", |
| 189 UrlRequest::Result::Failed()); |
| 190 LogFakeEvent(); |
| 191 LogFakeEvent(); |
| 192 |
| 193 respond1.Run(); |
| 194 |
| 195 auto respond3 = request_factory_->AddExpectedRequest( |
| 196 "{\"event\":[{\"id\":0},{\"id\":1},{\"id\":2},{\"id\":3}]}", |
| 197 success_result_); |
| 198 LogFakeEvent(); |
| 199 |
| 200 respond2.Run(); |
| 201 respond3.Run(); |
| 202 } |
| 203 |
181 TEST_F(TelemetryLogWriterTest, PostOneUnauthorizedCallClosureAndRetry) { | 204 TEST_F(TelemetryLogWriterTest, PostOneUnauthorizedCallClosureAndRetry) { |
182 SetAuthClosure(); | 205 SetAuthClosure(); |
183 | 206 |
184 auto respond1 = request_factory_->AddExpectedRequest( | 207 auto respond1 = request_factory_->AddExpectedRequest( |
185 "{\"event\":[{\"id\":0}]}", unauth_result_); | 208 "{\"event\":[{\"id\":0}]}", unauth_result_); |
186 LogFakeEvent(); | 209 LogFakeEvent(); |
187 | 210 |
188 auto respond2 = request_factory_->AddExpectedRequest( | 211 auto respond2 = request_factory_->AddExpectedRequest( |
189 "{\"event\":[{\"id\":0}]}", success_result_); | 212 "{\"event\":[{\"id\":0}]}", success_result_); |
190 respond1.Run(); | 213 respond1.Run(); |
191 respond2.Run(); | 214 respond2.Run(); |
192 | 215 |
193 EXPECT_EQ(1, set_auth_count_); | 216 EXPECT_EQ(1, set_auth_count_); |
194 } | 217 } |
195 | 218 |
196 TEST_F(TelemetryLogWriterTest, PostOneUnauthorizedAndJustRetry) { | 219 TEST_F(TelemetryLogWriterTest, PostOneUnauthorizedAndJustRetry) { |
197 auto respond1 = request_factory_->AddExpectedRequest( | 220 auto respond1 = request_factory_->AddExpectedRequest( |
198 "{\"event\":[{\"id\":0}]}", unauth_result_); | 221 "{\"event\":[{\"id\":0}]}", unauth_result_); |
199 LogFakeEvent(); | 222 LogFakeEvent(); |
200 | 223 |
201 auto respond2 = request_factory_->AddExpectedRequest( | 224 auto respond2 = request_factory_->AddExpectedRequest( |
202 "{\"event\":[{\"id\":0}]}", success_result_); | 225 "{\"event\":[{\"id\":0}]}", success_result_); |
203 respond1.Run(); | 226 respond1.Run(); |
204 respond2.Run(); | 227 respond2.Run(); |
205 | 228 |
206 EXPECT_EQ(0, set_auth_count_); | 229 EXPECT_EQ(0, set_auth_count_); |
207 } | 230 } |
208 | 231 |
209 } // namespace remoting | 232 } // namespace remoting |
OLD | NEW |