Chromium Code Reviews| 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/request_queue.h" | 5 #include "components/offline_pages/background/request_queue.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 #include <utility> | 8 #include <utility> |
| 9 | 9 |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| 11 #include "base/test/test_simple_task_runner.h" | 11 #include "base/test/test_simple_task_runner.h" |
| 12 #include "base/threading/thread_task_runner_handle.h" | 12 #include "base/threading/thread_task_runner_handle.h" |
| 13 #include "components/offline_pages/background/device_conditions.h" | |
| 14 #include "components/offline_pages/background/offliner_policy.h" | |
| 15 #include "components/offline_pages/background/request_coordinator_event_logger.h " | |
| 16 #include "components/offline_pages/background/request_notifier.h" | |
| 13 #include "components/offline_pages/background/request_queue_in_memory_store.h" | 17 #include "components/offline_pages/background/request_queue_in_memory_store.h" |
| 14 #include "components/offline_pages/background/save_page_request.h" | 18 #include "components/offline_pages/background/save_page_request.h" |
| 15 #include "testing/gtest/include/gtest/gtest.h" | 19 #include "testing/gtest/include/gtest/gtest.h" |
| 16 | 20 |
| 17 namespace offline_pages { | 21 namespace offline_pages { |
| 18 | 22 |
| 19 using AddRequestResult = RequestQueue::AddRequestResult; | 23 using AddRequestResult = AddRequestResult; |
| 20 using GetRequestsResult = RequestQueue::GetRequestsResult; | 24 using GetRequestsResult = GetRequestsResult; |
| 21 using UpdateRequestResult = RequestQueue::UpdateRequestResult; | 25 using UpdateRequestResult = UpdateRequestResult; |
| 22 | 26 |
| 23 namespace { | 27 namespace { |
| 24 // Data for request 1. | 28 // Data for request 1. |
| 25 const int64_t kRequestId = 42; | 29 const int64_t kRequestId = 42; |
| 26 const GURL kUrl("http://example.com"); | 30 const GURL kUrl("http://example.com"); |
| 27 const ClientId kClientId("bookmark", "1234"); | 31 const ClientId kClientId("bookmark", "1234"); |
| 28 // Data for request 2. | 32 // Data for request 2. |
| 29 const int64_t kRequestId2 = 77; | 33 const int64_t kRequestId2 = 77; |
| 30 const GURL kUrl2("http://test.com"); | 34 const GURL kUrl2("http://test.com"); |
| 31 const ClientId kClientId2("bookmark", "567"); | 35 const ClientId kClientId2("bookmark", "567"); |
| 32 const bool kUserRequested = true; | 36 const bool kUserRequested = true; |
| 33 const int64_t kRequestId3 = 99; | 37 const int64_t kRequestId3 = 99; |
| 38 const int kOneWeekInSeconds = 7 * 24 * 60 * 60; | |
| 39 | |
| 40 // Default request | |
| 41 const SavePageRequest kEmptyRequest(0UL, | |
| 42 GURL(""), | |
| 43 ClientId("", ""), | |
| 44 base::Time(), | |
| 45 true); | |
| 46 | |
| 34 } // namespace | 47 } // namespace |
| 35 | 48 |
| 49 // Helper class needed by the PickRequestTask | |
| 50 class RequestNotifierStub : public RequestNotifier { | |
| 51 public: | |
| 52 RequestNotifierStub() | |
| 53 : last_expired_request_(kEmptyRequest), total_expired_requests_(0) {} | |
| 54 | |
| 55 void NotifyAdded(const SavePageRequest& request) override {} | |
| 56 void NotifyChanged(const SavePageRequest& request) override {} | |
| 57 | |
| 58 void NotifyCompleted(const SavePageRequest& request, | |
| 59 BackgroundSavePageResult status) override { | |
| 60 last_expired_request_ = request; | |
| 61 last_request_expiration_status_ = status; | |
| 62 total_expired_requests_++; | |
| 63 } | |
| 64 | |
| 65 const SavePageRequest& last_expired_request() { | |
| 66 return last_expired_request_; | |
| 67 } | |
| 68 | |
| 69 RequestCoordinator::BackgroundSavePageResult | |
| 70 last_request_expiration_status() { | |
| 71 return last_request_expiration_status_; | |
| 72 } | |
| 73 | |
| 74 int32_t total_expired_requests() { return total_expired_requests_; } | |
| 75 | |
| 76 private: | |
| 77 BackgroundSavePageResult last_request_expiration_status_; | |
| 78 SavePageRequest last_expired_request_; | |
| 79 int32_t total_expired_requests_; | |
| 80 }; | |
| 81 | |
| 36 // TODO(fgorski): Add tests for store failures in add/remove/get. | 82 // TODO(fgorski): Add tests for store failures in add/remove/get. |
| 37 class RequestQueueTest : public testing::Test { | 83 class RequestQueueTest : public testing::Test { |
| 38 public: | 84 public: |
| 39 RequestQueueTest(); | 85 RequestQueueTest(); |
| 40 ~RequestQueueTest() override; | 86 ~RequestQueueTest() override; |
| 41 | 87 |
| 42 // Test overrides. | 88 // Test overrides. |
| 43 void SetUp() override; | 89 void SetUp() override; |
| 44 | 90 |
| 45 void PumpLoop(); | 91 void PumpLoop(); |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 69 } | 115 } |
| 70 | 116 |
| 71 const std::vector<std::unique_ptr<SavePageRequest>>& last_requests() const { | 117 const std::vector<std::unique_ptr<SavePageRequest>>& last_requests() const { |
| 72 return last_requests_; | 118 return last_requests_; |
| 73 } | 119 } |
| 74 | 120 |
| 75 UpdateRequestsResult* update_requests_result() const { | 121 UpdateRequestsResult* update_requests_result() const { |
| 76 return update_requests_result_.get(); | 122 return update_requests_result_.get(); |
| 77 } | 123 } |
| 78 | 124 |
| 125 void RequestPickedCallback(const SavePageRequest& request) {} | |
| 126 void RequestNotPickedCallback(bool non_user_requested_tasks_remain) {} | |
| 127 | |
| 79 private: | 128 private: |
| 80 AddRequestResult last_add_result_; | 129 AddRequestResult last_add_result_; |
| 81 std::unique_ptr<SavePageRequest> last_added_request_; | 130 std::unique_ptr<SavePageRequest> last_added_request_; |
| 82 std::unique_ptr<UpdateRequestsResult> update_requests_result_; | 131 std::unique_ptr<UpdateRequestsResult> update_requests_result_; |
| 83 UpdateRequestResult last_update_result_; | 132 UpdateRequestResult last_update_result_; |
| 84 | 133 |
| 85 GetRequestsResult last_get_requests_result_; | 134 GetRequestsResult last_get_requests_result_; |
| 86 std::vector<std::unique_ptr<SavePageRequest>> last_requests_; | 135 std::vector<std::unique_ptr<SavePageRequest>> last_requests_; |
| 87 | 136 |
| 88 std::unique_ptr<RequestQueue> queue_; | 137 std::unique_ptr<RequestQueue> queue_; |
| (...skipping 388 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 477 ASSERT_TRUE(update_requests_result()); | 526 ASSERT_TRUE(update_requests_result()); |
| 478 EXPECT_EQ(1UL, update_requests_result()->item_statuses.size()); | 527 EXPECT_EQ(1UL, update_requests_result()->item_statuses.size()); |
| 479 EXPECT_EQ(kRequestId, update_requests_result()->item_statuses.at(0).first); | 528 EXPECT_EQ(kRequestId, update_requests_result()->item_statuses.at(0).first); |
| 480 EXPECT_EQ(ItemActionStatus::SUCCESS, | 529 EXPECT_EQ(ItemActionStatus::SUCCESS, |
| 481 update_requests_result()->item_statuses.at(0).second); | 530 update_requests_result()->item_statuses.at(0).second); |
| 482 EXPECT_EQ(1UL, update_requests_result()->updated_items.size()); | 531 EXPECT_EQ(1UL, update_requests_result()->updated_items.size()); |
| 483 EXPECT_EQ(SavePageRequest::RequestState::AVAILABLE, | 532 EXPECT_EQ(SavePageRequest::RequestState::AVAILABLE, |
| 484 update_requests_result()->updated_items.at(0).request_state()); | 533 update_requests_result()->updated_items.at(0).request_state()); |
| 485 } | 534 } |
| 486 | 535 |
| 536 TEST_F(RequestQueueTest, CleanStaleRequests) { | |
|
fgorski
2016/11/09 17:58:07
please add a comment to this test:
Request expirat
Pete Williamson
2016/11/09 23:53:56
1. Comments added.
2. Generally I try to test som
| |
| 537 // Create a request that is already expired. | |
| 538 base::Time creation_time = | |
| 539 base::Time::Now() - base::TimeDelta::FromSeconds(2 * kOneWeekInSeconds); | |
| 540 | |
| 541 SavePageRequest original_request(kRequestId, kUrl, kClientId, creation_time, | |
| 542 kUserRequested); | |
| 543 queue()->AddRequest( | |
| 544 original_request, | |
| 545 base::Bind(&RequestQueueTest::AddRequestDone, base::Unretained(this))); | |
| 546 this->PumpLoop(); | |
| 547 this->ClearResults(); | |
| 548 | |
| 549 // Set up a picker factory pointing to our fake notifier. | |
| 550 OfflinerPolicy policy; | |
| 551 RequestNotifierStub notifier; | |
| 552 RequestCoordinatorEventLogger event_logger; | |
| 553 std::unique_ptr<PickRequestTaskFactory> picker_factory( | |
| 554 new PickRequestTaskFactory(&policy, ¬ifier, &event_logger)); | |
| 555 queue()->SetPickerFactory(std::move(picker_factory)); | |
| 556 | |
| 557 // Do a pick and clean operation, which will remove stale entries. | |
| 558 DeviceConditions conditions; | |
| 559 std::set<int64_t> disabled_list; | |
| 560 queue()->PickNextRequest( | |
| 561 base::Bind(&RequestQueueTest::RequestPickedCallback, | |
| 562 base::Unretained(this)), | |
| 563 base::Bind(&RequestQueueTest::RequestNotPickedCallback, | |
| 564 base::Unretained(this)), | |
| 565 conditions, disabled_list); | |
| 566 | |
| 567 this->PumpLoop(); | |
| 568 | |
| 569 // Notifier should have been notified that the request was removed. | |
| 570 ASSERT_EQ(notifier.last_expired_request().request_id(), kRequestId); | |
| 571 ASSERT_EQ(notifier.last_request_expiration_status(), | |
| 572 RequestNotifier::BackgroundSavePageResult::EXPIRED); | |
| 573 | |
| 574 // Doing a get should show no entries left in the queue since the expired | |
| 575 // request has been removed. | |
| 576 queue()->GetRequests( | |
| 577 base::Bind(&RequestQueueTest::GetRequestsDone, base::Unretained(this))); | |
| 578 this->PumpLoop(); | |
| 579 ASSERT_EQ(GetRequestsResult::SUCCESS, this->last_get_requests_result()); | |
| 580 ASSERT_TRUE(this->last_requests().empty()); | |
| 581 } | |
| 582 | |
| 487 } // namespace offline_pages | 583 } // namespace offline_pages |
| OLD | NEW |