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 "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 Loading... | |
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 Loading... | |
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 |
OLD | NEW |