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

Side by Side Diff: chrome/browser/android/offline_pages/prerendering_offliner_unittest.cc

Issue 1961083002: Updates to PrerenderingOffliner and PrerenderingLoader interfaces to push PrerenderManager knowledge (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressed fgosrki feedback wrt loader creation Created 4 years, 7 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 "chrome/browser/android/offline_pages/prerendering_offliner.h"
6
7 #include <memory>
8
9 #include "base/bind.h"
10 #include "chrome/browser/android/offline_pages/prerendering_loader.h"
11 #include "components/offline_pages/background/offliner.h"
12 #include "components/offline_pages/background/save_page_request.h"
13 #include "testing/gtest/include/gtest/gtest.h"
14
15 namespace offline_pages {
16
17 namespace {
18 const int64_t kRequestId = 7;
19 const GURL kHttpUrl("http://tunafish.com");
20 const GURL kFileUrl("file://sailfish.png");
21 const ClientId kClientId("AsyncLoading", "88");
22
23 // Mock Loader for testing the Offliner calls.
24 class MockPrerenderingLoader : public PrerenderingLoader {
25 public:
26 explicit MockPrerenderingLoader(content::BrowserContext* browser_context)
27 : PrerenderingLoader(browser_context), mock_loading_(false) {}
28 ~MockPrerenderingLoader() override {}
29
30 bool LoadPage(const GURL& url, const LoadPageCallback& callback) override {
31 mock_loading_ = true;
32 return mock_loading_;
33 }
34
35 void StopLoading() override { mock_loading_ = false; }
36
37 bool mock_loading() const { return mock_loading_; }
38
39 private:
40 bool mock_loading_;
41
42 DISALLOW_COPY_AND_ASSIGN(MockPrerenderingLoader);
43 };
44
45 } // namespace
46
47 class PrerenderingOfflinerTest : public testing::Test {
48 public:
49 PrerenderingOfflinerTest();
50 ~PrerenderingOfflinerTest() override;
51
52 void SetUp() override;
53
54 PrerenderingOffliner* offliner() const { return offliner_.get(); }
55 Offliner::CompletionCallback callback() {
fgorski 2016/05/10 03:52:43 this can be a const function
dougarnett 2016/05/10 15:30:19 Done.
56 return base::Bind(&PrerenderingOfflinerTest::OnCompletion,
57 base::Unretained(this));
58 }
59
60 bool loading() const { return loader_->mock_loading(); }
61 Offliner::CompletionStatus completion_status() { return completion_status_; }
fgorski 2016/05/10 03:52:43 this can be a const function as well
dougarnett 2016/05/10 15:30:19 Done.
62
63 private:
64 void OnCompletion(const SavePageRequest& request,
65 Offliner::CompletionStatus status);
66
67 std::unique_ptr<PrerenderingOffliner> offliner_;
68 // Not owned.
69 MockPrerenderingLoader* loader_;
fgorski 2016/05/10 03:52:43 I think this is OK. You should be able to work wit
dougarnett 2016/05/10 15:30:19 I plan to access the LoadPageCallback but wasn't t
70 Offliner::CompletionStatus completion_status_;
71
72 DISALLOW_COPY_AND_ASSIGN(PrerenderingOfflinerTest);
73 };
74
75 PrerenderingOfflinerTest::PrerenderingOfflinerTest() {}
76
77 PrerenderingOfflinerTest::~PrerenderingOfflinerTest() {}
78
79 void PrerenderingOfflinerTest::SetUp() {
80 offliner_.reset(new PrerenderingOffliner(nullptr, nullptr, nullptr));
81 std::unique_ptr<MockPrerenderingLoader> mock_loader(
82 new MockPrerenderingLoader(nullptr));
83 loader_ = mock_loader.get();
84 offliner_->SetLoaderForTesting(std::move(mock_loader));
85 // loader_ =
86 // static_cast<MockPrerenderingLoader*>(offliner_->GetLoaderForTesting());
87 // offliner_.reset(
88 // new TestPrerenderingOffliner(nullptr, nullptr, nullptr,
89 // std::move(mock_loader)));
90 }
91
92 void PrerenderingOfflinerTest::OnCompletion(const SavePageRequest& request,
93 Offliner::CompletionStatus status) {
94 completion_status_ = status;
95 }
96
97 // Tests initiate loading.
98 TEST_F(PrerenderingOfflinerTest, LoadAndSaveBadUrl) {
99 base::Time creation_time = base::Time::Now();
100 SavePageRequest request(kRequestId, kFileUrl, kClientId, creation_time);
101 EXPECT_FALSE(offliner()->LoadAndSave(request, callback()));
102 EXPECT_FALSE(loading());
103 }
104
105 // Tests initiate loading.
106 TEST_F(PrerenderingOfflinerTest, LoadAndSaveStartsLoading) {
107 base::Time creation_time = base::Time::Now();
108 SavePageRequest request(kRequestId, kHttpUrl, kClientId, creation_time);
109 EXPECT_TRUE(offliner()->LoadAndSave(request, callback()));
110 EXPECT_TRUE(loading());
111 }
112
113 // Tests cancels loading.
114 TEST_F(PrerenderingOfflinerTest, CancelLoading) {
115 base::Time creation_time = base::Time::Now();
116 SavePageRequest request(kRequestId, kHttpUrl, kClientId, creation_time);
117 EXPECT_TRUE(offliner()->LoadAndSave(request, callback()));
118 EXPECT_TRUE(loading());
119
120 offliner()->Cancel();
121 EXPECT_FALSE(loading());
122 }
123
124 } // namespace offline_pages
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698