1 // Copyright 2014 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 "components/rappor/log_uploader.h"
7 #include "base/compiler_specific.h"
8 #include "base/message_loop/message_loop_proxy.h"
9 #include "net/url_request/test_url_fetcher_factory.h"
10 #include "net/url_request/url_request_test_util.h"
11 #include "testing/gtest/include/gtest/gtest.h"
17 const char kTestServerURL
[] = "http://a.com/";
18 const char kTestMimeType
[] = "text/plain";
20 class TestLogUploader
: public LogUploader
{
22 TestLogUploader(net::URLRequestContextGetter
* request_context
) :
23 LogUploader(GURL(kTestServerURL
), kTestMimeType
, request_context
) {
27 base::TimeDelta
last_interval_set() const { return last_interval_set_
; };
30 last_interval_set_
= base::TimeDelta();
31 StartScheduledUpload();
34 static base::TimeDelta
BackOff(base::TimeDelta t
) {
35 return LogUploader::BackOffUploadInterval(t
);
39 bool IsUploadScheduled() const override
{
40 return last_interval_set() != base::TimeDelta();
43 // Schedules a future call to StartScheduledUpload if one isn't already
45 void ScheduleNextUpload(base::TimeDelta interval
) override
{
46 EXPECT_EQ(last_interval_set(), base::TimeDelta());
47 last_interval_set_
= interval
;
50 base::TimeDelta last_interval_set_
;
52 DISALLOW_COPY_AND_ASSIGN(TestLogUploader
);
57 class LogUploaderTest
: public testing::Test
{
60 : request_context_(new net::TestURLRequestContextGetter(
61 base::MessageLoopProxy::current())),
65 // Required for base::MessageLoopProxy::current().
66 base::MessageLoopForUI loop_
;
67 scoped_refptr
<net::TestURLRequestContextGetter
> request_context_
;
68 net::FakeURLFetcherFactory factory_
;
70 DISALLOW_COPY_AND_ASSIGN(LogUploaderTest
);
73 TEST_F(LogUploaderTest
, Success
) {
74 TestLogUploader
uploader(request_context_
.get());
76 factory_
.SetFakeResponse(GURL(kTestServerURL
),
79 net::URLRequestStatus::SUCCESS
);
81 uploader
.QueueLog("log1");
82 base::MessageLoop::current()->RunUntilIdle();
83 // Log should be discarded instead of retransmitted.
84 EXPECT_EQ(uploader
.last_interval_set(), base::TimeDelta());
87 TEST_F(LogUploaderTest
, Rejection
) {
88 TestLogUploader
uploader(request_context_
.get());
90 factory_
.SetFakeResponse(GURL(kTestServerURL
),
92 net::HTTP_BAD_REQUEST
,
93 net::URLRequestStatus::SUCCESS
);
95 uploader
.QueueLog("log1");
96 base::MessageLoop::current()->RunUntilIdle();
97 // Log should be discarded instead of retransmitted.
98 EXPECT_EQ(uploader
.last_interval_set(), base::TimeDelta());
101 TEST_F(LogUploaderTest
, Failure
) {
102 TestLogUploader
uploader(request_context_
.get());
104 factory_
.SetFakeResponse(GURL(kTestServerURL
),
106 net::HTTP_INTERNAL_SERVER_ERROR
,
107 net::URLRequestStatus::SUCCESS
);
109 uploader
.QueueLog("log1");
110 base::MessageLoop::current()->RunUntilIdle();
111 // Log should be scheduled for retransmission.
112 base::TimeDelta error_interval
= uploader
.last_interval_set();
113 EXPECT_GT(error_interval
, base::TimeDelta());
115 for (int i
= 0; i
< 10; i
++) {
116 uploader
.QueueLog("logX");
119 // A second failure should lead to a longer interval, and the log should
120 // be discarded due to full queue.
121 uploader
.StartUpload();
122 base::MessageLoop::current()->RunUntilIdle();
123 EXPECT_GT(uploader
.last_interval_set(), error_interval
);
125 factory_
.SetFakeResponse(GURL(kTestServerURL
),
128 net::URLRequestStatus::SUCCESS
);
130 // A success should revert to base interval while queue is not empty.
131 for (int i
= 0; i
< 9; i
++) {
132 uploader
.StartUpload();
133 base::MessageLoop::current()->RunUntilIdle();
134 EXPECT_LT(uploader
.last_interval_set(), error_interval
);
137 // Queue should be empty.
138 uploader
.StartUpload();
139 base::MessageLoop::current()->RunUntilIdle();
140 EXPECT_EQ(uploader
.last_interval_set(), base::TimeDelta());
143 TEST_F(LogUploaderTest
, Backoff
) {
144 base::TimeDelta current
= base::TimeDelta();
145 base::TimeDelta next
= base::TimeDelta::FromSeconds(1);
146 // Backoff until the maximum is reached.
147 while (next
> current
) {
149 next
= TestLogUploader::BackOff(current
);
151 // Maximum backoff should have been reached.
152 EXPECT_EQ(next
, current
);
155 } // namespace rappor