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

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: Rebasing 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
(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 GURL kUrl1("http://example.com");
20 const ClientId kClientId1("bookmark", "1234");
21 } // namespace
22
23 class RemoveRequestsTaskTest : public testing::Test {
24 public:
25 RemoveRequestsTaskTest();
26 ~RemoveRequestsTaskTest() override;
27
28 void PumpLoop();
29
30 void SetUpStore(RequestQueueStore* store);
31
32 void AddRequestDone(ItemActionStatus status);
33
34 void RemoveRequestsCallback(std::unique_ptr<UpdateRequestsResult> result);
35
36 UpdateRequestsResult* last_result() const { return result_.get(); }
37
38 private:
39 std::unique_ptr<UpdateRequestsResult> result_;
40 scoped_refptr<base::TestSimpleTaskRunner> task_runner_;
41 base::ThreadTaskRunnerHandle task_runner_handle_;
42 };
43
44 RemoveRequestsTaskTest::RemoveRequestsTaskTest()
45 : task_runner_(new base::TestSimpleTaskRunner),
46 task_runner_handle_(task_runner_) {}
47
48 RemoveRequestsTaskTest::~RemoveRequestsTaskTest() {}
49
50 void RemoveRequestsTaskTest::PumpLoop() {
51 task_runner_->RunUntilIdle();
52 }
53
54 void RemoveRequestsTaskTest::SetUpStore(RequestQueueStore* store) {
Pete Williamson 2016/09/30 18:03:53 A better name might be "AddARequestToStore". This
fgorski 2016/10/04 17:18:23 Done.
55 base::Time creation_time = base::Time::Now();
56 SavePageRequest original_request(kRequestId1, kUrl1, kClientId1,
57 creation_time, true);
58 store->AddRequest(original_request,
59 base::Bind(&RemoveRequestsTaskTest::AddRequestDone,
60 base::Unretained(this)));
61 PumpLoop();
62 }
63
64 void RemoveRequestsTaskTest::AddRequestDone(ItemActionStatus status) {
65 ASSERT_EQ(ItemActionStatus::SUCCESS, status);
66 }
67
68 void RemoveRequestsTaskTest::RemoveRequestsCallback(
69 std::unique_ptr<UpdateRequestsResult> result) {
70 result_ = std::move(result);
71 }
72
73 TEST_F(RemoveRequestsTaskTest, RemoveWhenStoreEmpty) {
74 RequestQueueInMemoryStore store;
75 std::vector<int64_t> request_ids{kRequestId1};
76 RemoveRequestsTask task(
77 &store, request_ids,
78 base::Bind(&RemoveRequestsTaskTest::RemoveRequestsCallback,
79 base::Unretained(this)));
80 task.Run();
81 PumpLoop();
82 ASSERT_TRUE(last_result());
83 EXPECT_EQ(1UL, last_result()->item_statuses.size());
84 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first);
85 EXPECT_EQ(ItemActionStatus::NOT_FOUND,
86 last_result()->item_statuses.at(0).second);
87 EXPECT_EQ(0UL, last_result()->updated_items.size());
88 }
89
90 TEST_F(RemoveRequestsTaskTest, RemoveSingleItem) {
Pete Williamson 2016/09/30 18:03:53 Maybe add a test for removing multiple items.
fgorski 2016/10/04 17:18:23 Done.
91 RequestQueueInMemoryStore store;
92 SetUpStore(&store);
93 std::vector<int64_t> request_ids{kRequestId1};
94 RemoveRequestsTask task(
95 &store, request_ids,
96 base::Bind(&RemoveRequestsTaskTest::RemoveRequestsCallback,
97 base::Unretained(this)));
98 task.Run();
99 PumpLoop();
100 ASSERT_TRUE(last_result());
101 EXPECT_EQ(1UL, last_result()->item_statuses.size());
102 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first);
103 EXPECT_EQ(ItemActionStatus::SUCCESS,
104 last_result()->item_statuses.at(0).second);
105 EXPECT_EQ(1UL, last_result()->updated_items.size());
106 EXPECT_EQ(kRequestId1, last_result()->updated_items.at(0).request_id());
107 }
108
109 TEST_F(RemoveRequestsTaskTest, DeleteWithEmptyIdList) {
110 RequestQueueInMemoryStore store;
111 std::vector<int64_t> request_ids;
112 RemoveRequestsTask task(
113 &store, request_ids,
114 base::Bind(&RemoveRequestsTaskTest::RemoveRequestsCallback,
115 base::Unretained(this)));
116 task.Run();
117 PumpLoop();
118 ASSERT_TRUE(last_result());
119 EXPECT_EQ(0UL, last_result()->item_statuses.size());
120 EXPECT_EQ(0UL, last_result()->updated_items.size());
121 }
122
123 TEST_F(RemoveRequestsTaskTest, RemoveMissingItem) {
124 RequestQueueInMemoryStore store;
125 SetUpStore(&store);
126 std::vector<int64_t> request_ids{kRequestId1, kRequestId2};
127 RemoveRequestsTask task(
128 &store, request_ids,
129 base::Bind(&RemoveRequestsTaskTest::RemoveRequestsCallback,
130 base::Unretained(this)));
131 task.Run();
132 PumpLoop();
133 ASSERT_TRUE(last_result());
134 EXPECT_EQ(2UL, last_result()->item_statuses.size());
135 EXPECT_EQ(kRequestId1, last_result()->item_statuses.at(0).first);
136 EXPECT_EQ(ItemActionStatus::SUCCESS,
137 last_result()->item_statuses.at(0).second);
138 EXPECT_EQ(kRequestId2, last_result()->item_statuses.at(1).first);
139 EXPECT_EQ(ItemActionStatus::NOT_FOUND,
140 last_result()->item_statuses.at(1).second);
141 EXPECT_EQ(1UL, last_result()->updated_items.size());
142 EXPECT_EQ(kRequestId1, last_result()->updated_items.at(0).request_id());
143 }
144
145 } // namespace offline_pages
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698