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

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

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