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

Side by Side Diff: components/offline_pages/background/request_queue_unittest.cc

Issue 2176453002: Update the request count when a request fails. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: 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 "components/offline_pages/background/request_queue.h" 5 #include "components/offline_pages/background/request_queue.h"
6 6
7 #include <memory> 7 #include <memory>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/test/test_simple_task_runner.h" 10 #include "base/test/test_simple_task_runner.h"
11 #include "base/threading/thread_task_runner_handle.h" 11 #include "base/threading/thread_task_runner_handle.h"
12 #include "components/offline_pages/background/request_queue_in_memory_store.h" 12 #include "components/offline_pages/background/request_queue_in_memory_store.h"
13 #include "components/offline_pages/background/save_page_request.h" 13 #include "components/offline_pages/background/save_page_request.h"
14 #include "testing/gtest/include/gtest/gtest.h" 14 #include "testing/gtest/include/gtest/gtest.h"
15 15
16 namespace offline_pages { 16 namespace offline_pages {
17 17
18 using AddRequestResult = RequestQueue::AddRequestResult; 18 using AddRequestResult = RequestQueue::AddRequestResult;
19 using GetRequestsResult = RequestQueue::GetRequestsResult; 19 using GetRequestsResult = RequestQueue::GetRequestsResult;
20 using UpdateRequestResult = RequestQueue::UpdateRequestResult; 20 using UpdateRequestResult = RequestQueue::UpdateRequestResult;
21 21
22 namespace { 22 namespace {
23 // Data for request 1. 23 // Data for request 1.
24 const int64_t kRequestId = 42; 24 const int64_t kRequestId = 42;
25 const GURL kUrl("http://example.com"); 25 const GURL kUrl("http://example.com");
26 const ClientId kClientId("bookmark", "1234"); 26 const ClientId kClientId("bookmark", "1234");
27 const int64_t kRetryCount = 2;
27 // Data for request 2. 28 // Data for request 2.
28 const int64_t kRequestId2 = 77; 29 const int64_t kRequestId2 = 77;
29 const GURL kUrl2("http://test.com"); 30 const GURL kUrl2("http://test.com");
30 const ClientId kClientId2("bookmark", "567"); 31 const ClientId kClientId2("bookmark", "567");
31 } // namespace 32 } // namespace
32 33
33 // TODO(fgorski): Add tests for store failures in add/remove/get. 34 // TODO(fgorski): Add tests for store failures in add/remove/get.
34 class RequestQueueTest : public testing::Test { 35 class RequestQueueTest : public testing::Test {
35 public: 36 public:
36 RequestQueueTest(); 37 RequestQueueTest();
37 ~RequestQueueTest() override; 38 ~RequestQueueTest() override;
38 39
39 // Test overrides. 40 // Test overrides.
40 void SetUp() override; 41 void SetUp() override;
41 42
42 void PumpLoop(); 43 void PumpLoop();
43 44
44 // Callback for adding requests. 45 // Callback for adding requests.
45 void AddRequestDone(AddRequestResult result, const SavePageRequest& request); 46 void AddRequestDone(AddRequestResult result, const SavePageRequest& request);
46 // Callback for getting requests. 47 // Callback for getting requests.
47 void GetRequestsDone(GetRequestsResult result, 48 void GetRequestsDone(GetRequestsResult result,
48 const std::vector<SavePageRequest>& requests); 49 const std::vector<SavePageRequest>& requests);
49 // Callback for removing request. 50 // Callback for removing request.
50 void RemoveRequestDone(UpdateRequestResult result); 51 void RemoveRequestDone(UpdateRequestResult result);
51 52
53 void UpdateRequestDone(UpdateRequestResult result);
54
52 RequestQueue* queue() { return queue_.get(); } 55 RequestQueue* queue() { return queue_.get(); }
53 56
54 AddRequestResult last_add_result() const { return last_add_result_; } 57 AddRequestResult last_add_result() const { return last_add_result_; }
55 SavePageRequest* last_added_request() { 58 SavePageRequest* last_added_request() {
56 return last_added_request_.get(); 59 return last_added_request_.get();
57 } 60 }
58 61
59 UpdateRequestResult last_remove_result() const { return last_remove_result_; } 62 UpdateRequestResult last_remove_result() const { return last_remove_result_; }
60 63
64 UpdateRequestResult last_update_result() const { return last_update_result_; }
65
61 GetRequestsResult last_get_requests_result() const { 66 GetRequestsResult last_get_requests_result() const {
62 return last_get_requests_result_; 67 return last_get_requests_result_;
63 } 68 }
64 const std::vector<SavePageRequest>& last_requests() const { 69 const std::vector<SavePageRequest>& last_requests() const {
65 return last_requests_; 70 return last_requests_;
66 } 71 }
67 72
68 private: 73 private:
69 AddRequestResult last_add_result_; 74 AddRequestResult last_add_result_;
70 std::unique_ptr<SavePageRequest> last_added_request_; 75 std::unique_ptr<SavePageRequest> last_added_request_;
71 76
72 UpdateRequestResult last_remove_result_; 77 UpdateRequestResult last_remove_result_;
78 UpdateRequestResult last_update_result_;
73 79
74 GetRequestsResult last_get_requests_result_; 80 GetRequestsResult last_get_requests_result_;
75 std::vector<SavePageRequest> last_requests_; 81 std::vector<SavePageRequest> last_requests_;
76 82
77 std::unique_ptr<RequestQueue> queue_; 83 std::unique_ptr<RequestQueue> queue_;
78 scoped_refptr<base::TestSimpleTaskRunner> task_runner_; 84 scoped_refptr<base::TestSimpleTaskRunner> task_runner_;
79 base::ThreadTaskRunnerHandle task_runner_handle_; 85 base::ThreadTaskRunnerHandle task_runner_handle_;
80 }; 86 };
81 87
82 RequestQueueTest::RequestQueueTest() 88 RequestQueueTest::RequestQueueTest()
83 : last_add_result_(AddRequestResult::STORE_FAILURE), 89 : last_add_result_(AddRequestResult::STORE_FAILURE),
84 last_remove_result_(UpdateRequestResult::STORE_FAILURE), 90 last_remove_result_(UpdateRequestResult::STORE_FAILURE),
91 last_update_result_(UpdateRequestResult::STORE_FAILURE),
85 last_get_requests_result_(GetRequestsResult::STORE_FAILURE), 92 last_get_requests_result_(GetRequestsResult::STORE_FAILURE),
86 task_runner_(new base::TestSimpleTaskRunner), 93 task_runner_(new base::TestSimpleTaskRunner),
87 task_runner_handle_(task_runner_) {} 94 task_runner_handle_(task_runner_) {}
88 95
89 RequestQueueTest::~RequestQueueTest() {} 96 RequestQueueTest::~RequestQueueTest() {}
90 97
91 void RequestQueueTest::SetUp() { 98 void RequestQueueTest::SetUp() {
92 std::unique_ptr<RequestQueueInMemoryStore> store( 99 std::unique_ptr<RequestQueueInMemoryStore> store(
93 new RequestQueueInMemoryStore()); 100 new RequestQueueInMemoryStore());
94 queue_.reset(new RequestQueue(std::move(store))); 101 queue_.reset(new RequestQueue(std::move(store)));
(...skipping 13 matching lines...) Expand all
108 GetRequestsResult result, 115 GetRequestsResult result,
109 const std::vector<SavePageRequest>& requests) { 116 const std::vector<SavePageRequest>& requests) {
110 last_get_requests_result_ = result; 117 last_get_requests_result_ = result;
111 last_requests_ = requests; 118 last_requests_ = requests;
112 } 119 }
113 120
114 void RequestQueueTest::RemoveRequestDone(UpdateRequestResult result) { 121 void RequestQueueTest::RemoveRequestDone(UpdateRequestResult result) {
115 last_remove_result_ = result; 122 last_remove_result_ = result;
116 } 123 }
117 124
125 void RequestQueueTest::UpdateRequestDone(UpdateRequestResult result) {
126 last_update_result_ = result;
127 }
128
118 TEST_F(RequestQueueTest, GetRequestsEmpty) { 129 TEST_F(RequestQueueTest, GetRequestsEmpty) {
119 queue()->GetRequests( 130 queue()->GetRequests(
120 base::Bind(&RequestQueueTest::GetRequestsDone, base::Unretained(this))); 131 base::Bind(&RequestQueueTest::GetRequestsDone, base::Unretained(this)));
121 PumpLoop(); 132 PumpLoop();
122 ASSERT_EQ(GetRequestsResult::SUCCESS, last_get_requests_result()); 133 ASSERT_EQ(GetRequestsResult::SUCCESS, last_get_requests_result());
123 ASSERT_EQ(0ul, last_requests().size()); 134 ASSERT_EQ(0ul, last_requests().size());
124 } 135 }
125 136
126 TEST_F(RequestQueueTest, AddRequest) { 137 TEST_F(RequestQueueTest, AddRequest) {
127 base::Time creation_time = base::Time::Now(); 138 base::Time creation_time = base::Time::Now();
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after
189 ASSERT_EQ(UpdateRequestResult::SUCCESS, last_remove_result()); 200 ASSERT_EQ(UpdateRequestResult::SUCCESS, last_remove_result());
190 201
191 queue()->GetRequests( 202 queue()->GetRequests(
192 base::Bind(&RequestQueueTest::GetRequestsDone, base::Unretained(this))); 203 base::Bind(&RequestQueueTest::GetRequestsDone, base::Unretained(this)));
193 PumpLoop(); 204 PumpLoop();
194 ASSERT_EQ(GetRequestsResult::SUCCESS, last_get_requests_result()); 205 ASSERT_EQ(GetRequestsResult::SUCCESS, last_get_requests_result());
195 ASSERT_EQ(1ul, last_requests().size()); 206 ASSERT_EQ(1ul, last_requests().size());
196 ASSERT_EQ(request2.request_id(), last_requests()[0].request_id()); 207 ASSERT_EQ(request2.request_id(), last_requests()[0].request_id());
197 } 208 }
198 209
210 TEST_F(RequestQueueTest, UpdateRequest) {
fgorski 2016/07/22 16:14:58 Please add a test for UpdateRequest, when it is no
Pete Williamson 2016/07/22 18:27:00 Done.
211 // First add a request. Retry count will be set to 0.
212 base::Time creation_time = base::Time::Now();
213 SavePageRequest request(kRequestId, kUrl, kClientId, creation_time);
214 queue()->AddRequest(request, base::Bind(&RequestQueueTest::AddRequestDone,
215 base::Unretained(this)));
216 PumpLoop();
217
218 // Update the request, ensure it succeeded.
219 request.set_attempt_count(kRetryCount);
220 queue()->UpdateRequest(
221 request,
222 base::Bind(&RequestQueueTest::UpdateRequestDone, base::Unretained(this)));
223 PumpLoop();
224 ASSERT_EQ(UpdateRequestResult::SUCCESS, last_update_result());
225
226 // Get the request, and verify the update took effect.
227 queue()->GetRequests(
228 base::Bind(&RequestQueueTest::GetRequestsDone, base::Unretained(this)));
229 PumpLoop();
230 ASSERT_EQ(GetRequestsResult::SUCCESS, last_get_requests_result());
231 ASSERT_EQ(1ul, last_requests().size());
232 ASSERT_EQ(kRetryCount, last_requests().front().attempt_count());
233 }
234
199 } // namespace offline_pages 235 } // namespace offline_pages
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698