| 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/change_requests_state_task.h" | 5 #include "components/offline_pages/background/remove_requests_task.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 "testing/gtest/include/gtest/gtest.h" | 13 #include "testing/gtest/include/gtest/gtest.h" |
| 14 | 14 |
| 15 namespace offline_pages { | 15 namespace offline_pages { |
| 16 namespace { | 16 namespace { |
| 17 const int64_t kRequestId1 = 42; | 17 const int64_t kRequestId1 = 42; |
| 18 const int64_t kRequestId2 = 43; | 18 const int64_t kRequestId2 = 43; |
| 19 const int64_t kRequestId3 = 44; | 19 const int64_t kRequestId3 = 44; |
| 20 const GURL kUrl1("http://example.com"); | 20 const GURL kUrl1("http://example.com"); |
| 21 const GURL kUrl2("http://another-example.com"); | 21 const GURL kUrl2("http://another-example.com"); |
| 22 const ClientId kClientId1("bookmark", "1234"); | 22 const ClientId kClientId1("bookmark", "1234"); |
| 23 const ClientId kClientId2("async", "5678"); | 23 const ClientId kClientId2("async", "5678"); |
| 24 } // namespace | 24 } // namespace |
| 25 | 25 |
| 26 class ChangeRequestsStateTaskTest : public testing::Test { | 26 class RemoveRequestsTaskTest : public testing::Test { |
| 27 public: | 27 public: |
| 28 ChangeRequestsStateTaskTest(); | 28 RemoveRequestsTaskTest(); |
| 29 ~ChangeRequestsStateTaskTest() override; | 29 ~RemoveRequestsTaskTest() override; |
| 30 | 30 |
| 31 void PumpLoop(); | 31 void PumpLoop(); |
| 32 | 32 |
| 33 void SetUpStore(RequestQueueStore* store); | 33 void AddRequestsToStore(RequestQueueStore* store); |
| 34 | 34 |
| 35 void AddRequestDone(ItemActionStatus status); | 35 void AddRequestDone(ItemActionStatus status); |
| 36 | 36 |
| 37 void ChangeRequestsStateCallback( | 37 void RemoveRequestsCallback(std::unique_ptr<UpdateRequestsResult> result); |
| 38 std::unique_ptr<UpdateRequestsResult> result); | |
| 39 | 38 |
| 40 UpdateRequestsResult* last_result() const { return result_.get(); } | 39 UpdateRequestsResult* last_result() const { return result_.get(); } |
| 41 | 40 |
| 42 private: | 41 private: |
| 43 std::unique_ptr<UpdateRequestsResult> result_; | 42 std::unique_ptr<UpdateRequestsResult> result_; |
| 44 scoped_refptr<base::TestSimpleTaskRunner> task_runner_; | 43 scoped_refptr<base::TestSimpleTaskRunner> task_runner_; |
| 45 base::ThreadTaskRunnerHandle task_runner_handle_; | 44 base::ThreadTaskRunnerHandle task_runner_handle_; |
| 46 }; | 45 }; |
| 47 | 46 |
| 48 ChangeRequestsStateTaskTest::ChangeRequestsStateTaskTest() | 47 RemoveRequestsTaskTest::RemoveRequestsTaskTest() |
| 49 : task_runner_(new base::TestSimpleTaskRunner), | 48 : task_runner_(new base::TestSimpleTaskRunner), |
| 50 task_runner_handle_(task_runner_) {} | 49 task_runner_handle_(task_runner_) {} |
| 51 | 50 |
| 52 ChangeRequestsStateTaskTest::~ChangeRequestsStateTaskTest() {} | 51 RemoveRequestsTaskTest::~RemoveRequestsTaskTest() {} |
| 53 | 52 |
| 54 void ChangeRequestsStateTaskTest::PumpLoop() { | 53 void RemoveRequestsTaskTest::PumpLoop() { |
| 55 task_runner_->RunUntilIdle(); | 54 task_runner_->RunUntilIdle(); |
| 56 } | 55 } |
| 57 | 56 |
| 58 void ChangeRequestsStateTaskTest::SetUpStore(RequestQueueStore* store) { | 57 void RemoveRequestsTaskTest::AddRequestsToStore(RequestQueueStore* store) { |
| 59 base::Time creation_time = base::Time::Now(); | 58 base::Time creation_time = base::Time::Now(); |
| 60 SavePageRequest request_1(kRequestId1, kUrl1, kClientId1, creation_time, | 59 SavePageRequest request_1(kRequestId1, kUrl1, kClientId1, creation_time, |
| 61 true); | 60 true); |
| 62 store->AddRequest(request_1, | 61 store->AddRequest(request_1, |
| 63 base::Bind(&ChangeRequestsStateTaskTest::AddRequestDone, | 62 base::Bind(&RemoveRequestsTaskTest::AddRequestDone, |
| 64 base::Unretained(this))); | 63 base::Unretained(this))); |
| 65 SavePageRequest request_2(kRequestId2, kUrl2, kClientId2, creation_time, | 64 SavePageRequest request_2(kRequestId2, kUrl2, kClientId2, creation_time, |
| 66 true); | 65 true); |
| 67 store->AddRequest(request_2, | 66 store->AddRequest(request_2, |
| 68 base::Bind(&ChangeRequestsStateTaskTest::AddRequestDone, | 67 base::Bind(&RemoveRequestsTaskTest::AddRequestDone, |
| 69 base::Unretained(this))); | 68 base::Unretained(this))); |
| 70 PumpLoop(); | 69 PumpLoop(); |
| 71 } | 70 } |
| 72 | 71 |
| 73 void ChangeRequestsStateTaskTest::AddRequestDone(ItemActionStatus status) { | 72 void RemoveRequestsTaskTest::AddRequestDone(ItemActionStatus status) { |
| 74 ASSERT_EQ(ItemActionStatus::SUCCESS, status); | 73 ASSERT_EQ(ItemActionStatus::SUCCESS, status); |
| 75 } | 74 } |
| 76 | 75 |
| 77 void ChangeRequestsStateTaskTest::ChangeRequestsStateCallback( | 76 void RemoveRequestsTaskTest::RemoveRequestsCallback( |
| 78 std::unique_ptr<UpdateRequestsResult> result) { | 77 std::unique_ptr<UpdateRequestsResult> result) { |
| 79 result_ = std::move(result); | 78 result_ = std::move(result); |
| 80 } | 79 } |
| 81 | 80 |
| 82 TEST_F(ChangeRequestsStateTaskTest, UpdateWhenStoreEmpty) { | 81 TEST_F(RemoveRequestsTaskTest, RemoveWhenStoreEmpty) { |
| 83 RequestQueueInMemoryStore store; | 82 RequestQueueInMemoryStore store; |
| 84 std::vector<int64_t> request_ids{kRequestId1}; | 83 std::vector<int64_t> request_ids{kRequestId1}; |
| 85 ChangeRequestsStateTask task( | 84 RemoveRequestsTask task( |
| 86 &store, request_ids, SavePageRequest::RequestState::PAUSED, | 85 &store, request_ids, |
| 87 base::Bind(&ChangeRequestsStateTaskTest::ChangeRequestsStateCallback, | 86 base::Bind(&RemoveRequestsTaskTest::RemoveRequestsCallback, |
| 88 base::Unretained(this))); | 87 base::Unretained(this))); |
| 89 task.Run(); | 88 task.Run(); |
| 90 PumpLoop(); | 89 PumpLoop(); |
| 91 ASSERT_TRUE(last_result()); | 90 ASSERT_TRUE(last_result()); |
| 92 EXPECT_EQ(1UL, last_result()->item_statuses.size()); | 91 EXPECT_EQ(1UL, last_result()->item_statuses.size()); |
| 93 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first); | 92 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first); |
| 94 EXPECT_EQ(ItemActionStatus::NOT_FOUND, | 93 EXPECT_EQ(ItemActionStatus::NOT_FOUND, |
| 95 last_result()->item_statuses.at(0).second); | 94 last_result()->item_statuses.at(0).second); |
| 96 EXPECT_EQ(0UL, last_result()->updated_items.size()); | 95 EXPECT_EQ(0UL, last_result()->updated_items.size()); |
| 97 } | 96 } |
| 98 | 97 |
| 99 TEST_F(ChangeRequestsStateTaskTest, UpdateSingleItem) { | 98 TEST_F(RemoveRequestsTaskTest, RemoveSingleItem) { |
| 100 RequestQueueInMemoryStore store; | 99 RequestQueueInMemoryStore store; |
| 101 SetUpStore(&store); | 100 AddRequestsToStore(&store); |
| 102 std::vector<int64_t> request_ids{kRequestId1}; | 101 std::vector<int64_t> request_ids{kRequestId1}; |
| 103 ChangeRequestsStateTask task( | 102 RemoveRequestsTask task( |
| 104 &store, request_ids, SavePageRequest::RequestState::PAUSED, | 103 &store, request_ids, |
| 105 base::Bind(&ChangeRequestsStateTaskTest::ChangeRequestsStateCallback, | 104 base::Bind(&RemoveRequestsTaskTest::RemoveRequestsCallback, |
| 106 base::Unretained(this))); | 105 base::Unretained(this))); |
| 107 task.Run(); | 106 task.Run(); |
| 108 PumpLoop(); | 107 PumpLoop(); |
| 109 ASSERT_TRUE(last_result()); | 108 ASSERT_TRUE(last_result()); |
| 110 EXPECT_EQ(1UL, last_result()->item_statuses.size()); | 109 EXPECT_EQ(1UL, last_result()->item_statuses.size()); |
| 111 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first); | 110 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first); |
| 112 EXPECT_EQ(ItemActionStatus::SUCCESS, | 111 EXPECT_EQ(ItemActionStatus::SUCCESS, |
| 113 last_result()->item_statuses.at(0).second); | 112 last_result()->item_statuses.at(0).second); |
| 114 EXPECT_EQ(1UL, last_result()->updated_items.size()); | 113 EXPECT_EQ(1UL, last_result()->updated_items.size()); |
| 115 EXPECT_EQ(SavePageRequest::RequestState::PAUSED, | 114 EXPECT_EQ(kRequestId1, last_result()->updated_items.at(0).request_id()); |
| 116 last_result()->updated_items.at(0).request_state()); | |
| 117 } | 115 } |
| 118 | 116 |
| 119 TEST_F(ChangeRequestsStateTaskTest, UpdateMultipleItems) { | 117 TEST_F(RemoveRequestsTaskTest, RemoveMultipleItems) { |
| 120 RequestQueueInMemoryStore store; | 118 RequestQueueInMemoryStore store; |
| 121 SetUpStore(&store); | 119 AddRequestsToStore(&store); |
| 122 std::vector<int64_t> request_ids{kRequestId1, kRequestId2}; | 120 std::vector<int64_t> request_ids{kRequestId1, kRequestId2}; |
| 123 ChangeRequestsStateTask task( | 121 RemoveRequestsTask task( |
| 124 &store, request_ids, SavePageRequest::RequestState::PAUSED, | 122 &store, request_ids, |
| 125 base::Bind(&ChangeRequestsStateTaskTest::ChangeRequestsStateCallback, | 123 base::Bind(&RemoveRequestsTaskTest::RemoveRequestsCallback, |
| 126 base::Unretained(this))); | 124 base::Unretained(this))); |
| 127 task.Run(); | 125 task.Run(); |
| 128 PumpLoop(); | 126 PumpLoop(); |
| 129 ASSERT_TRUE(last_result()); | 127 ASSERT_TRUE(last_result()); |
| 130 EXPECT_EQ(2UL, last_result()->item_statuses.size()); | 128 EXPECT_EQ(2UL, last_result()->item_statuses.size()); |
| 131 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first); | 129 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first); |
| 132 EXPECT_EQ(ItemActionStatus::SUCCESS, | 130 EXPECT_EQ(ItemActionStatus::SUCCESS, |
| 133 last_result()->item_statuses.at(0).second); | 131 last_result()->item_statuses.at(0).second); |
| 134 EXPECT_EQ(kRequestId2, last_result()->item_statuses.at(1).first); | 132 EXPECT_EQ(kRequestId2, last_result()->item_statuses.at(1).first); |
| 135 EXPECT_EQ(ItemActionStatus::SUCCESS, | 133 EXPECT_EQ(ItemActionStatus::SUCCESS, |
| 136 last_result()->item_statuses.at(1).second); | 134 last_result()->item_statuses.at(1).second); |
| 137 EXPECT_EQ(2UL, last_result()->updated_items.size()); | 135 EXPECT_EQ(2UL, last_result()->updated_items.size()); |
| 138 EXPECT_EQ(SavePageRequest::RequestState::PAUSED, | 136 EXPECT_EQ(kRequestId1, last_result()->updated_items.at(0).request_id()); |
| 139 last_result()->updated_items.at(0).request_state()); | 137 EXPECT_EQ(kRequestId2, last_result()->updated_items.at(1).request_id()); |
| 140 EXPECT_EQ(SavePageRequest::RequestState::PAUSED, | |
| 141 last_result()->updated_items.at(0).request_state()); | |
| 142 } | 138 } |
| 143 | 139 |
| 144 TEST_F(ChangeRequestsStateTaskTest, EmptyRequestsList) { | 140 TEST_F(RemoveRequestsTaskTest, DeleteWithEmptyIdList) { |
| 145 RequestQueueInMemoryStore store; | 141 RequestQueueInMemoryStore store; |
| 146 std::vector<int64_t> request_ids; | 142 std::vector<int64_t> request_ids; |
| 147 ChangeRequestsStateTask task( | 143 RemoveRequestsTask task( |
| 148 &store, request_ids, SavePageRequest::RequestState::PAUSED, | 144 &store, request_ids, |
| 149 base::Bind(&ChangeRequestsStateTaskTest::ChangeRequestsStateCallback, | 145 base::Bind(&RemoveRequestsTaskTest::RemoveRequestsCallback, |
| 150 base::Unretained(this))); | 146 base::Unretained(this))); |
| 151 task.Run(); | 147 task.Run(); |
| 152 PumpLoop(); | 148 PumpLoop(); |
| 153 ASSERT_TRUE(last_result()); | 149 ASSERT_TRUE(last_result()); |
| 154 EXPECT_EQ(0UL, last_result()->item_statuses.size()); | 150 EXPECT_EQ(0UL, last_result()->item_statuses.size()); |
| 155 EXPECT_EQ(0UL, last_result()->updated_items.size()); | 151 EXPECT_EQ(0UL, last_result()->updated_items.size()); |
| 156 } | 152 } |
| 157 | 153 |
| 158 TEST_F(ChangeRequestsStateTaskTest, UpdateMissingItem) { | 154 TEST_F(RemoveRequestsTaskTest, RemoveMissingItem) { |
| 159 RequestQueueInMemoryStore store; | 155 RequestQueueInMemoryStore store; |
| 160 SetUpStore(&store); | 156 AddRequestsToStore(&store); |
| 161 std::vector<int64_t> request_ids{kRequestId1, kRequestId3}; | 157 std::vector<int64_t> request_ids{kRequestId1, kRequestId3}; |
| 162 ChangeRequestsStateTask task( | 158 RemoveRequestsTask task( |
| 163 &store, request_ids, SavePageRequest::RequestState::PAUSED, | 159 &store, request_ids, |
| 164 base::Bind(&ChangeRequestsStateTaskTest::ChangeRequestsStateCallback, | 160 base::Bind(&RemoveRequestsTaskTest::RemoveRequestsCallback, |
| 165 base::Unretained(this))); | 161 base::Unretained(this))); |
| 166 task.Run(); | 162 task.Run(); |
| 167 PumpLoop(); | 163 PumpLoop(); |
| 168 ASSERT_TRUE(last_result()); | 164 ASSERT_TRUE(last_result()); |
| 169 EXPECT_EQ(2UL, last_result()->item_statuses.size()); | 165 EXPECT_EQ(2UL, last_result()->item_statuses.size()); |
| 170 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first); | 166 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first); |
| 171 EXPECT_EQ(ItemActionStatus::SUCCESS, | 167 EXPECT_EQ(ItemActionStatus::SUCCESS, |
| 172 last_result()->item_statuses.at(0).second); | 168 last_result()->item_statuses.at(0).second); |
| 173 EXPECT_EQ(kRequestId3, last_result()->item_statuses.at(1).first); | 169 EXPECT_EQ(kRequestId3, last_result()->item_statuses.at(1).first); |
| 174 EXPECT_EQ(ItemActionStatus::NOT_FOUND, | 170 EXPECT_EQ(ItemActionStatus::NOT_FOUND, |
| 175 last_result()->item_statuses.at(1).second); | 171 last_result()->item_statuses.at(1).second); |
| 176 EXPECT_EQ(1UL, last_result()->updated_items.size()); | 172 EXPECT_EQ(1UL, last_result()->updated_items.size()); |
| 177 EXPECT_EQ(SavePageRequest::RequestState::PAUSED, | 173 EXPECT_EQ(kRequestId1, last_result()->updated_items.at(0).request_id()); |
| 178 last_result()->updated_items.at(0).request_state()); | |
| 179 } | 174 } |
| 180 | 175 |
| 181 } // namespace offline_pages | 176 } // namespace offline_pages |
| OLD | NEW |