Chromium Code Reviews| 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 |