| Index: chrome/renderer/prerender/prerender_dispatcher_unittest.cc
|
| diff --git a/chrome/renderer/prerender/prerender_dispatcher_unittest.cc b/chrome/renderer/prerender/prerender_dispatcher_unittest.cc
|
| index f7170ba8b4c6a49c1bb7dc4fed4f8283f2ea5807..ebe807b5ee1ae8e383d9281ec4b6ca7b89dbfc3a 100644
|
| --- a/chrome/renderer/prerender/prerender_dispatcher_unittest.cc
|
| +++ b/chrome/renderer/prerender/prerender_dispatcher_unittest.cc
|
| @@ -11,29 +11,62 @@
|
|
|
| namespace prerender {
|
|
|
| +namespace {
|
| +
|
| +int s_next_prerender_id = 0;
|
| +
|
| +} // namespace
|
| +
|
| +using WebKit::WebPrerender;
|
| +
|
| +// Since we can't mock out WebKit::WebPrerender in chrome, this test can't test
|
| +// signalling to or from the WebKit side. Instead, it checks only that the
|
| +// messages received from the browser generate consistant state in the
|
| +// PrerenderDispatcher. Since prerenders couldn't even start or stop without the
|
| +// WebKit signalling, we can expect PrerenderBrowserTest to provide adequate
|
| +// coverage of this.
|
| class PrerenderDispatcherTest : public testing::Test {
|
| public:
|
| PrerenderDispatcherTest() {}
|
|
|
| bool is_prerender_url(const GURL& url) const {
|
| - return prerender_dispatcher_.IsPrerenderURL(url);
|
| + // We cannot call PrerenderDispatcher::IsPrerenderURL, since it dereferences
|
| + // WebPrerender to call WebPrerender::url().
|
| + for (std::multimap<int, GURL>::const_iterator
|
| + it = prerender_dispatcher_.prerender_aliases_.begin();
|
| + it != prerender_dispatcher_.prerender_aliases_.end(); ++it) {
|
| + if (it->second == url)
|
| + return true;
|
| + }
|
| + return false;
|
| + }
|
| +
|
| + const std::map<int, WebPrerender*>& prerenders() const {
|
| + return prerender_dispatcher_.prerenders_;
|
| }
|
|
|
| - const PrerenderDispatcher::PrerenderMap& urls() const {
|
| - return prerender_dispatcher_.prerender_urls_;
|
| + int StartPrerender() {
|
| + prerender_dispatcher_.OnStartedPrerender(s_next_prerender_id);
|
| + return s_next_prerender_id++;
|
| }
|
|
|
| - void AddURL(const GURL& url) { prerender_dispatcher_.OnAddPrerenderURL(url); }
|
| - void RemoveURL(const GURL& url) {
|
| - prerender_dispatcher_.OnRemovePrerenderURL(url);
|
| + void AddAliasToPrerender(int prerender_id, const GURL& url) {
|
| + prerender_dispatcher_.OnAddAliasToPrerender(prerender_id, url);
|
| + }
|
| +
|
| + void StopPrerender(int prerender_id) {
|
| + prerender_dispatcher_.OnStoppedPrerender(prerender_id);
|
| }
|
|
|
| int GetCountForURL(const GURL& url) const {
|
| - PrerenderDispatcher::PrerenderMap::const_iterator entry = urls().find(url);
|
| - if (entry == urls().end())
|
| - return 0;
|
| - EXPECT_GT(entry->second, 0);
|
| - return entry->second;
|
| + int count = 0;
|
| + for (std::multimap<int, GURL>::const_iterator
|
| + it = prerender_dispatcher_.prerender_aliases_.begin();
|
| + it != prerender_dispatcher_.prerender_aliases_.end(); ++it) {
|
| + if (it->second == url)
|
| + count++;
|
| + }
|
| + return count;
|
| }
|
|
|
| private:
|
| @@ -42,13 +75,14 @@ class PrerenderDispatcherTest : public testing::Test {
|
| };
|
|
|
| TEST_F(PrerenderDispatcherTest, PrerenderDispatcherEmpty) {
|
| - EXPECT_EQ(0U, urls().size());
|
| + EXPECT_EQ(0U, prerenders().size());
|
| }
|
|
|
| TEST_F(PrerenderDispatcherTest, PrerenderDispatcherSingleAdd) {
|
| GURL foo_url = GURL("http://foo.com");
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| - AddURL(foo_url);
|
| + int foo_id = StartPrerender();
|
| + AddAliasToPrerender(foo_id, foo_url);
|
| EXPECT_TRUE(is_prerender_url(foo_url));
|
| EXPECT_EQ(1, GetCountForURL(foo_url));
|
| }
|
| @@ -59,16 +93,18 @@ TEST_F(PrerenderDispatcherTest, PrerenderDispatcherMultipleAdd) {
|
|
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| EXPECT_FALSE(is_prerender_url(bar_url));
|
| - AddURL(foo_url);
|
| + int foo_id = StartPrerender();
|
| + AddAliasToPrerender(foo_id, foo_url);
|
| EXPECT_TRUE(is_prerender_url(foo_url));
|
| EXPECT_FALSE(is_prerender_url(bar_url));
|
|
|
| - AddURL(foo_url);
|
| + AddAliasToPrerender(foo_id, foo_url);
|
| EXPECT_TRUE(is_prerender_url(foo_url));
|
| EXPECT_FALSE(is_prerender_url(bar_url));
|
| EXPECT_EQ(2, GetCountForURL(foo_url));
|
|
|
| - AddURL(bar_url);
|
| + int bar_id = StartPrerender();
|
| + AddAliasToPrerender(bar_id, bar_url);
|
| EXPECT_TRUE(is_prerender_url(foo_url));
|
| EXPECT_TRUE(is_prerender_url(bar_url));
|
| EXPECT_EQ(2, GetCountForURL(foo_url));
|
| @@ -78,9 +114,10 @@ TEST_F(PrerenderDispatcherTest, PrerenderDispatcherMultipleAdd) {
|
| TEST_F(PrerenderDispatcherTest, PrerenderDispatcherSingleRemove) {
|
| GURL foo_url = GURL("http://foo.com");
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| - AddURL(foo_url);
|
| + int foo_id = StartPrerender();
|
| + AddAliasToPrerender(foo_id, foo_url);
|
| EXPECT_TRUE(is_prerender_url(foo_url));
|
| - RemoveURL(foo_url);
|
| + StopPrerender(foo_id);
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| EXPECT_EQ(0, GetCountForURL(foo_url));
|
| }
|
| @@ -88,17 +125,14 @@ TEST_F(PrerenderDispatcherTest, PrerenderDispatcherSingleRemove) {
|
| TEST_F(PrerenderDispatcherTest, PrerenderDispatcherMultipleRemove) {
|
| GURL foo_url = GURL("http://foo.com");
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| - AddURL(foo_url);
|
| + int foo_id = StartPrerender();
|
| + AddAliasToPrerender(foo_id, foo_url);
|
| EXPECT_TRUE(is_prerender_url(foo_url));
|
| - AddURL(foo_url);
|
| + AddAliasToPrerender(foo_id, foo_url);
|
| EXPECT_TRUE(is_prerender_url(foo_url));
|
| EXPECT_EQ(2, GetCountForURL(foo_url));
|
|
|
| - RemoveURL(foo_url);
|
| - EXPECT_TRUE(is_prerender_url(foo_url));
|
| - EXPECT_EQ(1, GetCountForURL(foo_url));
|
| -
|
| - RemoveURL(foo_url);
|
| + StopPrerender(foo_id);
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| EXPECT_EQ(0, GetCountForURL(foo_url));
|
| }
|
| @@ -106,7 +140,8 @@ TEST_F(PrerenderDispatcherTest, PrerenderDispatcherMultipleRemove) {
|
| TEST_F(PrerenderDispatcherTest, PrerenderDispatcherRemoveWithoutAdd) {
|
| GURL foo_url = GURL("http://foo.com");
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| - RemoveURL(foo_url);
|
| + int crazy_prerender_id = 13;
|
| + StopPrerender(crazy_prerender_id);
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| EXPECT_EQ(0, GetCountForURL(foo_url));
|
| }
|
| @@ -114,11 +149,12 @@ TEST_F(PrerenderDispatcherTest, PrerenderDispatcherRemoveWithoutAdd) {
|
| TEST_F(PrerenderDispatcherTest, PrerenderDispatcherRemoveTooMany) {
|
| GURL foo_url = GURL("http://foo.com");
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| - AddURL(foo_url);
|
| + int foo_id = StartPrerender();
|
| + AddAliasToPrerender(foo_id, foo_url);
|
| EXPECT_TRUE(is_prerender_url(foo_url));
|
| - RemoveURL(foo_url);
|
| + StopPrerender(foo_id);
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| - RemoveURL(foo_url);
|
| + StopPrerender(foo_id);
|
| EXPECT_FALSE(is_prerender_url(foo_url));
|
| EXPECT_EQ(0, GetCountForURL(foo_url));
|
| }
|
|
|