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

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

Issue 2372043002: [Offline pages] Applying TaskQueue to RequestQueue::ChangeRequestsState (Closed)
Patch Set: 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/change_requests_state_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;
Pete Williamson 2016/09/27 23:49:56 Let's remove or comment in (and use) the commented
fgorski 2016/09/28 22:39:06 Done.
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 ChangeRequestsStateTaskTest : public testing::Test {
27 public:
28 ChangeRequestsStateTaskTest();
29 ~ChangeRequestsStateTaskTest() override;
30
31 void PumpLoop();
32
33 void SetUpStore(RequestQueueStore* store);
34
35 void AddRequestDone(ItemActionStatus status);
36
37 void ChangeRequestsStateCallback(
38 std::unique_ptr<UpdateRequestsResult> result);
39
40 UpdateRequestsResult* last_result() const { return result_.get(); }
41
42 private:
43 std::unique_ptr<UpdateRequestsResult> result_;
44 scoped_refptr<base::TestSimpleTaskRunner> task_runner_;
45 base::ThreadTaskRunnerHandle task_runner_handle_;
46 };
47
48 ChangeRequestsStateTaskTest::ChangeRequestsStateTaskTest()
49 : task_runner_(new base::TestSimpleTaskRunner),
50 task_runner_handle_(task_runner_) {}
51
52 ChangeRequestsStateTaskTest::~ChangeRequestsStateTaskTest() {}
53
54 void ChangeRequestsStateTaskTest::PumpLoop() {
55 task_runner_->RunUntilIdle();
56 }
57
58 void ChangeRequestsStateTaskTest::SetUpStore(RequestQueueStore* store) {
59 base::Time creation_time = base::Time::Now();
60 SavePageRequest original_request(kRequestId1, kUrl1, kClientId1,
61 creation_time, true);
62 store->AddRequest(original_request,
63 base::Bind(&ChangeRequestsStateTaskTest::AddRequestDone,
64 base::Unretained(this)));
65 PumpLoop();
66 }
67
68 void ChangeRequestsStateTaskTest::AddRequestDone(ItemActionStatus status) {
69 ASSERT_EQ(ItemActionStatus::SUCCESS, status);
70 }
71
72 void ChangeRequestsStateTaskTest::ChangeRequestsStateCallback(
73 std::unique_ptr<UpdateRequestsResult> result) {
74 result_ = std::move(result);
75 }
76
77 TEST_F(ChangeRequestsStateTaskTest, UpdateWhenStoreEmpty) {
78 RequestQueueInMemoryStore store;
79 std::vector<int64_t> request_ids{kRequestId1};
80 ChangeRequestsStateTask task(
81 &store, request_ids, SavePageRequest::RequestState::PAUSED,
82 base::Bind(&ChangeRequestsStateTaskTest::ChangeRequestsStateCallback,
83 base::Unretained(this)));
84 task.Run();
85 PumpLoop();
86 ASSERT_TRUE(last_result());
87 EXPECT_EQ(1UL, last_result()->item_statuses.size());
88 EXPECT_EQ(kRequestId1, last_result()->item_statuses[0].first);
89 EXPECT_EQ(ItemActionStatus::NOT_FOUND,
90 last_result()->item_statuses[0].second);
91 EXPECT_EQ(0UL, last_result()->updated_items.size());
92 }
93
94 TEST_F(ChangeRequestsStateTaskTest, UpdateSingleItem) {
Pete Williamson 2016/09/27 23:49:56 Maybe add a test to update multiple items?
fgorski 2016/09/28 22:39:06 Done.
95 RequestQueueInMemoryStore store;
96 SetUpStore(&store);
97 std::vector<int64_t> request_ids{kRequestId1};
98 ChangeRequestsStateTask task(
99 &store, request_ids, SavePageRequest::RequestState::PAUSED,
100 base::Bind(&ChangeRequestsStateTaskTest::ChangeRequestsStateCallback,
101 base::Unretained(this)));
102 task.Run();
103 PumpLoop();
104 ASSERT_TRUE(last_result());
105 EXPECT_EQ(1UL, last_result()->item_statuses.size());
106 EXPECT_EQ(kRequestId1, last_result()->item_statuses[0].first);
107 EXPECT_EQ(ItemActionStatus::SUCCESS, last_result()->item_statuses[0].second);
108 EXPECT_EQ(1UL, last_result()->updated_items.size());
109 EXPECT_EQ(SavePageRequest::RequestState::PAUSED,
110 last_result()->updated_items[0].request_state());
111 }
112
113 TEST_F(ChangeRequestsStateTaskTest, EmptyRequestsList) {
114 RequestQueueInMemoryStore store;
115 std::vector<int64_t> request_ids;
116 ChangeRequestsStateTask task(
117 &store, request_ids, SavePageRequest::RequestState::PAUSED,
118 base::Bind(&ChangeRequestsStateTaskTest::ChangeRequestsStateCallback,
119 base::Unretained(this)));
120 task.Run();
121 PumpLoop();
122 ASSERT_TRUE(last_result());
123 EXPECT_EQ(0UL, last_result()->item_statuses.size());
124 EXPECT_EQ(0UL, last_result()->updated_items.size());
125 }
126
127 TEST_F(ChangeRequestsStateTaskTest, UpdateMissingItem) {
128 RequestQueueInMemoryStore store;
129 SetUpStore(&store);
130 std::vector<int64_t> request_ids{kRequestId1, kRequestId3};
131 ChangeRequestsStateTask task(
132 &store, request_ids, SavePageRequest::RequestState::PAUSED,
133 base::Bind(&ChangeRequestsStateTaskTest::ChangeRequestsStateCallback,
134 base::Unretained(this)));
135 task.Run();
136 PumpLoop();
137 ASSERT_TRUE(last_result());
138 EXPECT_EQ(2UL, last_result()->item_statuses.size());
139 EXPECT_EQ(kRequestId1, last_result()->item_statuses[0].first);
140 EXPECT_EQ(ItemActionStatus::SUCCESS, last_result()->item_statuses[0].second);
141 EXPECT_EQ(kRequestId3, last_result()->item_statuses[1].first);
142 EXPECT_EQ(ItemActionStatus::NOT_FOUND,
143 last_result()->item_statuses[1].second);
144 EXPECT_EQ(1UL, last_result()->updated_items.size());
145 EXPECT_EQ(SavePageRequest::RequestState::PAUSED,
146 last_result()->updated_items[0].request_state());
147 }
148
149 } // namespace offline_pages
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698