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
) {
26 base::TimeDelta
last_interval_set() const { return last_interval_set_
; };
29 last_interval_set_
= base::TimeDelta();
30 StartScheduledUpload();
33 static base::TimeDelta
BackOff(base::TimeDelta t
) {
34 return LogUploader::BackOffUploadInterval(t
);
38 bool IsUploadScheduled() const override
{
39 return last_interval_set() != base::TimeDelta();
42 // Schedules a future call to StartScheduledUpload if one isn't already
44 void ScheduleNextUpload(base::TimeDelta interval
) override
{
45 EXPECT_EQ(last_interval_set(), base::TimeDelta());
46 last_interval_set_
= interval
;
49 base::TimeDelta last_interval_set_
;
51 DISALLOW_COPY_AND_ASSIGN(TestLogUploader
);
56 class LogUploaderTest
: public testing::Test
{
59 : request_context_(new net::TestURLRequestContextGetter(
60 base::MessageLoopProxy::current())),
64 // Required for base::MessageLoopProxy::current().
65 base::MessageLoopForUI loop_
;
66 scoped_refptr
<net::TestURLRequestContextGetter
> request_context_
;
67 net::FakeURLFetcherFactory factory_
;
69 DISALLOW_COPY_AND_ASSIGN(LogUploaderTest
);
72 TEST_F(LogUploaderTest
, Success
) {
73 TestLogUploader
uploader(request_context_
.get());
75 factory_
.SetFakeResponse(GURL(kTestServerURL
),
78 net::URLRequestStatus::SUCCESS
);
80 uploader
.QueueLog("log1");
81 base::MessageLoop::current()->RunUntilIdle();
82 // Log should be discarded instead of retransmitted.
83 EXPECT_EQ(uploader
.last_interval_set(), base::TimeDelta());
86 TEST_F(LogUploaderTest
, Rejection
) {
87 TestLogUploader
uploader(request_context_
.get());
89 factory_
.SetFakeResponse(GURL(kTestServerURL
),
91 net::HTTP_BAD_REQUEST
,
92 net::URLRequestStatus::SUCCESS
);
94 uploader
.QueueLog("log1");
95 base::MessageLoop::current()->RunUntilIdle();
96 // Log should be discarded instead of retransmitted.
97 EXPECT_EQ(uploader
.last_interval_set(), base::TimeDelta());
100 TEST_F(LogUploaderTest
, Failure
) {
101 TestLogUploader
uploader(request_context_
.get());
103 factory_
.SetFakeResponse(GURL(kTestServerURL
),
105 net::HTTP_INTERNAL_SERVER_ERROR
,
106 net::URLRequestStatus::SUCCESS
);
108 uploader
.QueueLog("log1");
109 base::MessageLoop::current()->RunUntilIdle();
110 // Log should be scheduled for retransmission.
111 base::TimeDelta error_interval
= uploader
.last_interval_set();
112 EXPECT_GT(error_interval
, base::TimeDelta());
114 for (int i
= 0; i
< 10; i
++) {
115 uploader
.QueueLog("logX");
118 // A second failure should lead to a longer interval, and the log should
119 // be discarded due to full queue.
120 uploader
.StartUpload();
121 base::MessageLoop::current()->RunUntilIdle();
122 EXPECT_GT(uploader
.last_interval_set(), error_interval
);
124 factory_
.SetFakeResponse(GURL(kTestServerURL
),
127 net::URLRequestStatus::SUCCESS
);
129 // A success should revert to base interval while queue is not empty.
130 for (int i
= 0; i
< 9; i
++) {
131 uploader
.StartUpload();
132 base::MessageLoop::current()->RunUntilIdle();
133 EXPECT_LT(uploader
.last_interval_set(), error_interval
);
136 // Queue should be empty.
137 uploader
.StartUpload();
138 base::MessageLoop::current()->RunUntilIdle();
139 EXPECT_EQ(uploader
.last_interval_set(), base::TimeDelta());
142 TEST_F(LogUploaderTest
, Backoff
) {
143 base::TimeDelta current
= base::TimeDelta();
144 base::TimeDelta next
= base::TimeDelta::FromSeconds(1);
145 // Backoff until the maximum is reached.
146 while (next
> current
) {
148 next
= TestLogUploader::BackOff(current
);
150 // Maximum backoff should have been reached.
151 EXPECT_EQ(next
, current
);
154 } // namespace rappor