| 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 |