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

Side by Side Diff: chrome/renderer/prerender/prerender_dispatcher_unittest.cc

Issue 11316311: Make PrerenderHandle an observer of PrerenderContents. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: signal stop on match complete Created 8 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "chrome/renderer/prerender/prerender_dispatcher.h" 5 #include "chrome/renderer/prerender/prerender_dispatcher.h"
6 6
7 #include <map>
8 #include <utility>
9
7 #include "base/compiler_specific.h" 10 #include "base/compiler_specific.h"
8 #include "base/logging.h" 11 #include "base/logging.h"
9 #include "googleurl/src/gurl.h" 12 #include "googleurl/src/gurl.h"
10 #include "testing/gtest/include/gtest/gtest.h" 13 #include "testing/gtest/include/gtest/gtest.h"
11 14
12 namespace prerender { 15 namespace prerender {
13 16
17 namespace {
18
19 int g_next_prerender_id = 0;
20
21 } // namespace
22
23 using WebKit::WebPrerender;
24
25 // Since we can't mock out WebKit::WebPrerender in chrome, this test can't test
26 // signalling to or from the WebKit side. Instead, it checks only that the
27 // messages received from the browser generate consistant state in the
28 // PrerenderDispatcher. Since prerenders couldn't even start or stop without the
29 // WebKit signalling, we can expect PrerenderBrowserTest to provide adequate
30 // coverage of this.
14 class PrerenderDispatcherTest : public testing::Test { 31 class PrerenderDispatcherTest : public testing::Test {
15 public: 32 public:
16 PrerenderDispatcherTest() {} 33 PrerenderDispatcherTest() {}
17 34
18 bool is_prerender_url(const GURL& url) const { 35 bool IsPrerenderURL(const GURL& url) const {
19 return prerender_dispatcher_.IsPrerenderURL(url); 36 return prerender_dispatcher_.IsPrerenderURL(url);
20 } 37 }
21 38
22 const PrerenderDispatcher::PrerenderMap& urls() const { 39 const std::map<int, GURL>& prerenders() const {
23 return prerender_dispatcher_.prerender_urls_; 40 return prerender_dispatcher_.prerenders_;
24 } 41 }
25 42
26 void AddURL(const GURL& url) { prerender_dispatcher_.OnAddPrerenderURL(url); } 43 int StartPrerender(const GURL& url) {
27 void RemoveURL(const GURL& url) { 44 DCHECK_EQ(0u, prerender_dispatcher_.prerenders_.count(g_next_prerender_id));
28 prerender_dispatcher_.OnRemovePrerenderURL(url); 45 prerender_dispatcher_.prerenders_[g_next_prerender_id] = url;
46
47 prerender_dispatcher_.OnPrerenderStart(g_next_prerender_id);
48 return g_next_prerender_id++;
49 }
50
51 void AddAliasToPrerender(int prerender_id, const GURL& url) {
52 prerender_dispatcher_.OnPrerenderAddAlias(prerender_id, url);
53 }
54
55 void StopPrerender(int prerender_id) {
56 prerender_dispatcher_.OnPrerenderStop(prerender_id);
29 } 57 }
30 58
31 int GetCountForURL(const GURL& url) const { 59 int GetCountForURL(const GURL& url) const {
32 PrerenderDispatcher::PrerenderMap::const_iterator entry = urls().find(url); 60 return prerender_dispatcher_.running_prerender_urls_.count(url);
33 if (entry == urls().end())
34 return 0;
35 EXPECT_GT(entry->second, 0);
36 return entry->second;
37 } 61 }
38 62
39 private: 63 private:
40 PrerenderDispatcher prerender_dispatcher_; 64 PrerenderDispatcher prerender_dispatcher_;
41 DISALLOW_COPY_AND_ASSIGN(PrerenderDispatcherTest); 65 DISALLOW_COPY_AND_ASSIGN(PrerenderDispatcherTest);
42 }; 66 };
43 67
44 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherEmpty) { 68 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherEmpty) {
45 EXPECT_EQ(0U, urls().size()); 69 EXPECT_TRUE(prerenders().empty());
46 } 70 }
47 71
48 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherSingleAdd) { 72 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherSingleAdd) {
49 GURL foo_url = GURL("http://foo.com"); 73 GURL foo_url = GURL("http://foo.com");
50 EXPECT_FALSE(is_prerender_url(foo_url)); 74 EXPECT_FALSE(IsPrerenderURL(foo_url));
51 AddURL(foo_url); 75 StartPrerender(foo_url);
52 EXPECT_TRUE(is_prerender_url(foo_url)); 76 EXPECT_TRUE(IsPrerenderURL(foo_url));
53 EXPECT_EQ(1, GetCountForURL(foo_url)); 77 EXPECT_EQ(1, GetCountForURL(foo_url));
54 } 78 }
55 79
56 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherMultipleAdd) { 80 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherMultipleAdd) {
57 GURL foo_url = GURL("http://foo.com"); 81 GURL foo_url = GURL("http://foo.com");
58 GURL bar_url = GURL("http://bar.com"); 82 GURL bar_url = GURL("http://bar.com");
59 83
60 EXPECT_FALSE(is_prerender_url(foo_url)); 84 EXPECT_FALSE(IsPrerenderURL(foo_url));
61 EXPECT_FALSE(is_prerender_url(bar_url)); 85 EXPECT_FALSE(IsPrerenderURL(bar_url));
62 AddURL(foo_url); 86 int foo_id = StartPrerender(foo_url);
63 EXPECT_TRUE(is_prerender_url(foo_url)); 87 EXPECT_TRUE(IsPrerenderURL(foo_url));
64 EXPECT_FALSE(is_prerender_url(bar_url)); 88 EXPECT_FALSE(IsPrerenderURL(bar_url));
65 89
66 AddURL(foo_url); 90 AddAliasToPrerender(foo_id, foo_url);
67 EXPECT_TRUE(is_prerender_url(foo_url)); 91 EXPECT_TRUE(IsPrerenderURL(foo_url));
68 EXPECT_FALSE(is_prerender_url(bar_url)); 92 EXPECT_FALSE(IsPrerenderURL(bar_url));
69 EXPECT_EQ(2, GetCountForURL(foo_url)); 93 EXPECT_EQ(2, GetCountForURL(foo_url));
70 94
71 AddURL(bar_url); 95 StartPrerender(bar_url);
72 EXPECT_TRUE(is_prerender_url(foo_url)); 96 EXPECT_TRUE(IsPrerenderURL(foo_url));
73 EXPECT_TRUE(is_prerender_url(bar_url)); 97 EXPECT_TRUE(IsPrerenderURL(bar_url));
74 EXPECT_EQ(2, GetCountForURL(foo_url)); 98 EXPECT_EQ(2, GetCountForURL(foo_url));
75 EXPECT_EQ(1, GetCountForURL(bar_url)); 99 EXPECT_EQ(1, GetCountForURL(bar_url));
76 } 100 }
77 101
78 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherSingleRemove) { 102 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherSingleRemove) {
79 GURL foo_url = GURL("http://foo.com"); 103 GURL foo_url = GURL("http://foo.com");
80 EXPECT_FALSE(is_prerender_url(foo_url)); 104 EXPECT_FALSE(IsPrerenderURL(foo_url));
81 AddURL(foo_url); 105 int foo_id = StartPrerender(foo_url);
82 EXPECT_TRUE(is_prerender_url(foo_url)); 106 EXPECT_TRUE(IsPrerenderURL(foo_url));
83 RemoveURL(foo_url); 107 StopPrerender(foo_id);
84 EXPECT_FALSE(is_prerender_url(foo_url)); 108 EXPECT_FALSE(IsPrerenderURL(foo_url));
85 EXPECT_EQ(0, GetCountForURL(foo_url)); 109 EXPECT_EQ(0, GetCountForURL(foo_url));
86 } 110 }
87 111
88 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherMultipleRemove) {
89 GURL foo_url = GURL("http://foo.com");
90 EXPECT_FALSE(is_prerender_url(foo_url));
91 AddURL(foo_url);
92 EXPECT_TRUE(is_prerender_url(foo_url));
93 AddURL(foo_url);
94 EXPECT_TRUE(is_prerender_url(foo_url));
95 EXPECT_EQ(2, GetCountForURL(foo_url));
96
97 RemoveURL(foo_url);
98 EXPECT_TRUE(is_prerender_url(foo_url));
99 EXPECT_EQ(1, GetCountForURL(foo_url));
100
101 RemoveURL(foo_url);
102 EXPECT_FALSE(is_prerender_url(foo_url));
103 EXPECT_EQ(0, GetCountForURL(foo_url));
104 }
105
106 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherRemoveWithoutAdd) {
107 GURL foo_url = GURL("http://foo.com");
108 EXPECT_FALSE(is_prerender_url(foo_url));
109 RemoveURL(foo_url);
110 EXPECT_FALSE(is_prerender_url(foo_url));
111 EXPECT_EQ(0, GetCountForURL(foo_url));
112 }
113
114 TEST_F(PrerenderDispatcherTest, PrerenderDispatcherRemoveTooMany) {
115 GURL foo_url = GURL("http://foo.com");
116 EXPECT_FALSE(is_prerender_url(foo_url));
117 AddURL(foo_url);
118 EXPECT_TRUE(is_prerender_url(foo_url));
119 RemoveURL(foo_url);
120 EXPECT_FALSE(is_prerender_url(foo_url));
121 RemoveURL(foo_url);
122 EXPECT_FALSE(is_prerender_url(foo_url));
123 EXPECT_EQ(0, GetCountForURL(foo_url));
124 }
125
126 } // end namespace prerender 112 } // end namespace prerender
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698