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

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

Issue 2373933003: [Offline pages] Updating RequestQueue::RemoveRequests to use a TaskQueue (Closed)
Patch Set: Addressing final feedback Created 4 years, 2 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/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
OLDNEW
« no previous file with comments | « components/offline_pages/background/remove_requests_task.cc ('k') | components/offline_pages/background/request_coordinator.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698