diff options
author | creis@chromium.org <creis@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-11-27 01:26:14 +0000 |
---|---|---|
committer | creis@chromium.org <creis@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-11-27 01:26:14 +0000 |
commit | 04981a6e55d581749b28e2493cd65b655f63a114 (patch) | |
tree | 69a49576ccd0e52d4c9cb2b46234bafc1249b22f /content/browser/site_per_process_browsertest.cc | |
parent | 297ace04e7f0a31465d93843e01b4dbf4cb5453b (diff) | |
download | chromium_src-04981a6e55d581749b28e2493cd65b655f63a114.zip chromium_src-04981a6e55d581749b28e2493cd65b655f63a114.tar.gz chromium_src-04981a6e55d581749b28e2493cd65b655f63a114.tar.bz2 |
Revert 237119 "Always create FrameTreeNodes and RenderFrameHosts..."
> Always create FrameTreeNodes and RenderFrameHosts for every frame.
>
> This allows us to run the FrameTreeShape tests without a flag.
>
> BUG=245126
> TEST=FrameTreeBrowserTest.FrameTreeShape*
>
> Review URL: https://codereview.chromium.org/82033002
TBR=creis@chromium.org
Review URL: https://codereview.chromium.org/90213002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@237469 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/browser/site_per_process_browsertest.cc')
-rw-r--r-- | content/browser/site_per_process_browsertest.cc | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/content/browser/site_per_process_browsertest.cc b/content/browser/site_per_process_browsertest.cc index af645e0..cf92072 100644 --- a/content/browser/site_per_process_browsertest.cc +++ b/content/browser/site_per_process_browsertest.cc @@ -420,6 +420,83 @@ IN_PROC_BROWSER_TEST_F(SitePerProcessBrowserTest, } } +// Ensures FrameTree correctly reflects page structure during navigations. +IN_PROC_BROWSER_TEST_F(SitePerProcessBrowserTest, + FrameTreeShape) { + host_resolver()->AddRule("*", "127.0.0.1"); + ASSERT_TRUE(test_server()->Start()); + + GURL base_url = test_server()->GetURL("files/site_isolation/"); + GURL::Replacements replace_host; + std::string host_str("A.com"); // Must stay in scope with replace_host. + replace_host.SetHostStr(host_str); + base_url = base_url.ReplaceComponents(replace_host); + + // Load doc without iframes. Verify FrameTree just has root. + // Frame tree: + // Site-A Root + NavigateToURL(shell(), base_url.Resolve("blank.html")); + FrameTreeNode* root = + static_cast<WebContentsImpl*>(shell()->web_contents())-> + GetFrameTree()->root(); + EXPECT_EQ(0U, root->child_count()); + + // Add 2 same-site frames. Verify 3 nodes in tree with proper names. + // Frame tree: + // Site-A Root -- Site-A frame1 + // \-- Site-A frame2 + WindowedNotificationObserver observer1( + content::NOTIFICATION_LOAD_STOP, + content::Source<NavigationController>( + &shell()->web_contents()->GetController())); + NavigateToURL(shell(), base_url.Resolve("frames-X-X.html")); + observer1.Wait(); + ASSERT_EQ(2U, root->child_count()); + EXPECT_EQ(0U, root->child_at(0)->child_count()); + EXPECT_EQ(0U, root->child_at(1)->child_count()); +} + +// TODO(ajwong): Talk with nasko and merge this functionality with +// FrameTreeShape. +IN_PROC_BROWSER_TEST_F(SitePerProcessBrowserTest, + FrameTreeShape2) { + host_resolver()->AddRule("*", "127.0.0.1"); + ASSERT_TRUE(test_server()->Start()); + + NavigateToURL(shell(), + test_server()->GetURL("files/frame_tree/top.html")); + + WebContentsImpl* wc = static_cast<WebContentsImpl*>(shell()->web_contents()); + RenderViewHostImpl* rvh = static_cast<RenderViewHostImpl*>( + wc->GetRenderViewHost()); + FrameTreeNode* root = wc->GetFrameTree()->root(); + + // Check that the root node is properly created with the frame id of the + // initial navigation. + ASSERT_EQ(3UL, root->child_count()); + EXPECT_EQ(std::string(), root->frame_name()); + EXPECT_EQ(rvh->main_frame_id(), root->frame_id()); + + ASSERT_EQ(2UL, root->child_at(0)->child_count()); + EXPECT_STREQ("1-1-name", root->child_at(0)->frame_name().c_str()); + + // Verify the deepest node exists and has the right name. + ASSERT_EQ(2UL, root->child_at(2)->child_count()); + EXPECT_EQ(1UL, root->child_at(2)->child_at(1)->child_count()); + EXPECT_EQ(0UL, root->child_at(2)->child_at(1)->child_at(0)->child_count()); + EXPECT_STREQ("3-1-id", + root->child_at(2)->child_at(1)->child_at(0)->frame_name().c_str()); + + // Navigate to about:blank, which should leave only the root node of the frame + // tree in the browser process. + NavigateToURL(shell(), test_server()->GetURL("files/title1.html")); + + root = wc->GetFrameTree()->root(); + EXPECT_EQ(0UL, root->child_count()); + EXPECT_EQ(std::string(), root->frame_name()); + EXPECT_EQ(rvh->main_frame_id(), root->frame_id()); +} + // Tests that the |should_replace_current_entry| flag persists correctly across // request transfers that began with a cross-process navigation. IN_PROC_BROWSER_TEST_F(SitePerProcessBrowserTest, |