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

Unified Diff: content/browser/frame_host/navigation_controller_impl_unittest.cc

Issue 281653003: DRAFT CL: Add FrameNavigationEntry and track subframe session histories. Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase Created 5 years, 9 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 side-by-side diff with in-line comments
Download patch
Index: content/browser/frame_host/navigation_controller_impl_unittest.cc
diff --git a/content/browser/frame_host/navigation_controller_impl_unittest.cc b/content/browser/frame_host/navigation_controller_impl_unittest.cc
index c18ca9be21cbf1e05198a511ab574c94508f6803..bc1f89709a97fdb3ef9ac80686588c3c4592439d 100644
--- a/content/browser/frame_host/navigation_controller_impl_unittest.cc
+++ b/content/browser/frame_host/navigation_controller_impl_unittest.cc
@@ -12,6 +12,7 @@
#include "base/strings/utf_string_conversions.h"
#include "base/time/time.h"
#include "content/browser/frame_host/cross_site_transferring_request.h"
+#include "content/browser/frame_host/frame_navigation_entry.h"
#include "content/browser/frame_host/navigation_controller_impl.h"
#include "content/browser/frame_host/navigation_entry_impl.h"
#include "content/browser/frame_host/navigation_entry_screenshot_manager.h"
@@ -1598,14 +1599,9 @@ TEST_F(NavigationControllerTest, Back_OtherBackPending) {
main_test_rfh()->PrepareForCommit();
main_test_rfh()->SendNavigate(1, kUrl2);
- // We know all the entries have the same site instance, so we can just grab
- // a random one for looking up other entries.
- SiteInstance* site_instance =
- controller.GetLastCommittedEntry()->site_instance();
-
// That second URL should be the last committed and it should have gotten the
// new title.
- EXPECT_EQ(kUrl2, controller.GetEntryWithPageID(site_instance, 1)->GetURL());
+ EXPECT_EQ(kUrl2, controller.GetEntryWithPageID(1)->GetURL());
EXPECT_EQ(1, controller.GetLastCommittedEntryIndex());
EXPECT_EQ(-1, controller.GetPendingEntryIndex());
@@ -1932,23 +1928,43 @@ TEST_F(NavigationControllerTest, NewSubframe) {
RegisterForAllNavNotifications(&notifications, &controller);
const GURL url1("http://foo1");
- main_test_rfh()->SendNavigate(0, url1);
+ main_test_rfh()->SendNavigate(-1, url1);
EXPECT_EQ(1U, navigation_entry_committed_counter_);
navigation_entry_committed_counter_ = 0;
+ EXPECT_EQ(1, controller.GetLastCommittedEntry()->GetPageID());
- const GURL url2("http://foo2");
+ // Add a subframe to navigate, with an initial page.
+ main_test_rfh()->OnCreateChildFrame(MSG_ROUTING_NONE, std::string(),
+ SandboxFlags::NONE);
+ RenderFrameHostImpl* subframe =
+ contents()->GetFrameTree()->root()->child_at(0)->current_frame_host();
+ {
+ const GURL url2("http://foo2");
+ FrameHostMsg_DidCommitProvisionalLoad_Params params;
+ params.page_id = 1;
+ params.url = url2;
+ params.transition = ui::PAGE_TRANSITION_AUTO_SUBFRAME;
+ params.should_update_history = false;
+ params.gesture = NavigationGestureUser;
+ params.is_post = false;
+ params.page_state = PageState::CreateFromURL(url2);
+ LoadCommittedDetails details;
+ EXPECT_FALSE(controller.RendererDidNavigate(subframe, params, &details));
+ EXPECT_EQ(0U, notifications.size());
+ }
+
+ const GURL url3("http://foo3");
FrameHostMsg_DidCommitProvisionalLoad_Params params;
- params.page_id = 1;
- params.url = url2;
+ params.page_id = -1;
+ params.url = url3;
params.transition = ui::PAGE_TRANSITION_MANUAL_SUBFRAME;
params.should_update_history = false;
params.gesture = NavigationGestureUser;
params.is_post = false;
- params.page_state = PageState::CreateFromURL(url2);
+ params.page_state = PageState::CreateFromURL(url3);
LoadCommittedDetails details;
- EXPECT_TRUE(controller.RendererDidNavigate(main_test_rfh(), params,
- &details));
+ EXPECT_TRUE(controller.RendererDidNavigate(subframe, params, &details));
EXPECT_EQ(1U, navigation_entry_committed_counter_);
navigation_entry_committed_counter_ = 0;
EXPECT_EQ(url1, details.previous_url);
@@ -1958,10 +1974,19 @@ TEST_F(NavigationControllerTest, NewSubframe) {
// The new entry should be appended.
EXPECT_EQ(2, controller.GetEntryCount());
- // New entry should refer to the new page, but the old URL (entries only
- // reflect the toplevel URL).
- EXPECT_EQ(url1, details.entry->GetURL());
- EXPECT_EQ(params.page_id, details.entry->GetPageID());
+ // The new entry should have a page ID for the new page, but the entry's URL
+ // is for the top level and shouldn't change.
+ NavigationEntryImpl* entry = static_cast<NavigationEntryImpl*>(details.entry);
+ EXPECT_EQ(url1, entry->GetURL());
+ EXPECT_EQ(2, entry->GetPageID());
+ FrameNavigationEntry* root_entry = entry->root_node()->frame_entry.get();
+ EXPECT_EQ(url1, root_entry->url());
+
+ // The subframe's FrameNavigationEntry should have the new URL.
+ ASSERT_EQ(1U, entry->root_node()->children.size());
+ FrameNavigationEntry* frame_entry =
+ entry->root_node()->children[0]->frame_entry.get();
+ EXPECT_EQ(url3, frame_entry->url());
}
// Auto subframes are ones the page loads automatically like ads. They should
@@ -1971,14 +1996,21 @@ TEST_F(NavigationControllerTest, AutoSubframe) {
TestNotificationTracker notifications;
RegisterForAllNavNotifications(&notifications, &controller);
- const GURL url1("http://foo1");
- main_test_rfh()->SendNavigate(0, url1);
+ const GURL url1("http://foo/1");
+ main_test_rfh()->SendNavigate(-1, url1);
EXPECT_EQ(1U, navigation_entry_committed_counter_);
navigation_entry_committed_counter_ = 0;
+ EXPECT_EQ(1, controller.GetLastCommittedEntry()->GetPageID());
- const GURL url2("http://foo2");
+ // Add a subframe to navigate.
+ main_test_rfh()->OnCreateChildFrame(MSG_ROUTING_NONE, std::string(),
+ SandboxFlags::NONE);
+ RenderFrameHostImpl* subframe =
+ contents()->GetFrameTree()->root()->child_at(0)->current_frame_host();
+
+ const GURL url2("http://foo/2");
FrameHostMsg_DidCommitProvisionalLoad_Params params;
- params.page_id = 0;
+ params.page_id = 1;
params.url = url2;
params.transition = ui::PAGE_TRANSITION_AUTO_SUBFRAME;
params.should_update_history = false;
@@ -1988,12 +2020,22 @@ TEST_F(NavigationControllerTest, AutoSubframe) {
// Navigating should do nothing.
LoadCommittedDetails details;
- EXPECT_FALSE(controller.RendererDidNavigate(main_test_rfh(), params,
- &details));
+ EXPECT_FALSE(controller.RendererDidNavigate(subframe, params, &details));
EXPECT_EQ(0U, notifications.size());
// There should still be only one entry.
EXPECT_EQ(1, controller.GetEntryCount());
+ NavigationEntryImpl* entry = controller.GetLastCommittedEntry();
+ EXPECT_EQ(url1, entry->GetURL());
+ EXPECT_EQ(1, entry->GetPageID());
+
+ // The entry should now have a subframe FrameNavigationEntry.
+ FrameNavigationEntry* root_entry = entry->root_node()->frame_entry.get();
+ EXPECT_EQ(url1, root_entry->url());
+ ASSERT_EQ(1U, entry->root_node()->children.size());
+ FrameNavigationEntry* frame_entry =
+ entry->root_node()->children[0]->frame_entry.get();
+ EXPECT_EQ(url2, frame_entry->url());
}
// Tests navigation and then going back to a subframe navigation.
@@ -2004,68 +2046,88 @@ TEST_F(NavigationControllerTest, BackSubframe) {
// Main page.
const GURL url1("http://foo1");
- main_test_rfh()->SendNavigate(0, url1);
+ main_test_rfh()->SendNavigate(-1, url1);
EXPECT_EQ(1U, navigation_entry_committed_counter_);
navigation_entry_committed_counter_ = 0;
+ EXPECT_EQ(1, controller.GetLastCommittedEntry()->GetPageID());
+
+ // Add a subframe with an initial page to navigate.
+ main_test_rfh()->OnCreateChildFrame(MSG_ROUTING_NONE, std::string(),
+ SandboxFlags::NONE);
+ RenderFrameHostImpl* subframe =
+ contents()->GetFrameTree()->root()->child_at(0)->current_frame_host();
+ const GURL init_subframe_url("http://foo1/subframe");
+ FrameHostMsg_DidCommitProvisionalLoad_Params params;
+ params.page_id = -1;
+ params.url = init_subframe_url;
+ params.transition = ui::PAGE_TRANSITION_AUTO_SUBFRAME;
+ params.should_update_history = false;
+ params.gesture = NavigationGestureUser;
+ params.is_post = false;
+ params.page_state = PageState::CreateFromURL(init_subframe_url);
+
+ // This auto-subframe should not create a new entry.
+ LoadCommittedDetails details;
+ EXPECT_TRUE(controller.RendererDidNavigate(subframe, params, &details));
+ EXPECT_EQ(1U, navigation_entry_committed_counter_);
+ navigation_entry_committed_counter_ = 0;
+ EXPECT_EQ(1, controller.GetEntryCount());
+ EXPECT_EQ(1, controller.GetLastCommittedEntry()->GetPageID());
// First manual subframe navigation.
const GURL url2("http://foo2");
- FrameHostMsg_DidCommitProvisionalLoad_Params params;
- params.page_id = 1;
+ params.page_id = -1;
params.url = url2;
params.transition = ui::PAGE_TRANSITION_MANUAL_SUBFRAME;
- params.should_update_history = false;
- params.gesture = NavigationGestureUser;
- params.is_post = false;
params.page_state = PageState::CreateFromURL(url2);
// This should generate a new entry.
- LoadCommittedDetails details;
- EXPECT_TRUE(controller.RendererDidNavigate(main_test_rfh(), params,
- &details));
+ EXPECT_TRUE(controller.RendererDidNavigate(subframe, params, &details));
EXPECT_EQ(1U, navigation_entry_committed_counter_);
navigation_entry_committed_counter_ = 0;
EXPECT_EQ(2, controller.GetEntryCount());
+ EXPECT_EQ(2, controller.GetLastCommittedEntry()->GetPageID());
// Second manual subframe navigation should also make a new entry.
const GURL url3("http://foo3");
- params.page_id = 2;
+ params.page_id = -1;
params.url = url3;
params.transition = ui::PAGE_TRANSITION_MANUAL_SUBFRAME;
- EXPECT_TRUE(controller.RendererDidNavigate(main_test_rfh(), params,
- &details));
+ EXPECT_TRUE(controller.RendererDidNavigate(subframe, params, &details));
EXPECT_EQ(1U, navigation_entry_committed_counter_);
navigation_entry_committed_counter_ = 0;
EXPECT_EQ(3, controller.GetEntryCount());
EXPECT_EQ(2, controller.GetCurrentEntryIndex());
+ EXPECT_EQ(3, controller.GetLastCommittedEntry()->GetPageID());
// Go back one.
controller.GoBack();
+ // TODO(creis): Verify shape of the pending entry's tree.
params.page_id = 1;
params.url = url2;
params.transition = ui::PAGE_TRANSITION_AUTO_SUBFRAME;
- EXPECT_TRUE(controller.RendererDidNavigate(main_test_rfh(), params,
- &details));
+ EXPECT_TRUE(controller.RendererDidNavigate(subframe, params, &details));
EXPECT_EQ(1U, navigation_entry_committed_counter_);
navigation_entry_committed_counter_ = 0;
EXPECT_EQ(3, controller.GetEntryCount());
EXPECT_EQ(1, controller.GetCurrentEntryIndex());
EXPECT_EQ(-1, controller.GetPendingEntryIndex());
EXPECT_FALSE(controller.GetPendingEntry());
+ EXPECT_EQ(2, controller.GetLastCommittedEntry()->GetPageID());
// Go back one more.
controller.GoBack();
params.page_id = 0;
params.url = url1;
params.transition = ui::PAGE_TRANSITION_AUTO_SUBFRAME;
- EXPECT_TRUE(controller.RendererDidNavigate(main_test_rfh(), params,
- &details));
+ EXPECT_TRUE(controller.RendererDidNavigate(subframe, params, &details));
EXPECT_EQ(1U, navigation_entry_committed_counter_);
navigation_entry_committed_counter_ = 0;
EXPECT_EQ(3, controller.GetEntryCount());
EXPECT_EQ(0, controller.GetCurrentEntryIndex());
EXPECT_EQ(-1, controller.GetPendingEntryIndex());
EXPECT_FALSE(controller.GetPendingEntry());
+ EXPECT_EQ(1, controller.GetLastCommittedEntry()->GetPageID());
}
TEST_F(NavigationControllerTest, LinkClick) {
@@ -3281,29 +3343,43 @@ TEST_F(NavigationControllerTest, SameSubframe) {
NavigationControllerImpl& controller = controller_impl();
// Navigate the main frame.
const GURL url("http://www.google.com/");
- main_test_rfh()->SendNavigate(0, url);
+ main_test_rfh()->SendNavigate(-1, url);
// We should be at the first navigation entry.
- EXPECT_EQ(controller.GetEntryCount(), 1);
- EXPECT_EQ(controller.GetLastCommittedEntryIndex(), 0);
+ EXPECT_EQ(1, controller.GetEntryCount());
+ EXPECT_EQ(0, controller.GetLastCommittedEntryIndex());
+
+ // Add a subframe to navigate.
+ main_test_rfh()->OnCreateChildFrame(MSG_ROUTING_NONE, std::string(),
+ SandboxFlags::NONE);
+ RenderFrameHostImpl* subframe =
+ contents()->GetFrameTree()->root()->child_at(0)->current_frame_host();
// Navigate a subframe that would normally count as in-page.
- const GURL subframe("http://www.google.com/#");
+ const GURL subframe_url("http://www.google.com/#");
FrameHostMsg_DidCommitProvisionalLoad_Params params;
- params.page_id = 0;
- params.url = subframe;
+ params.page_id = 1;
+ params.url = subframe_url;
params.transition = ui::PAGE_TRANSITION_AUTO_SUBFRAME;
params.should_update_history = false;
params.gesture = NavigationGestureAuto;
params.is_post = false;
- params.page_state = PageState::CreateFromURL(subframe);
+ params.page_state = PageState::CreateFromURL(subframe_url);
LoadCommittedDetails details;
- EXPECT_FALSE(controller.RendererDidNavigate(main_test_rfh(), params,
- &details));
+ EXPECT_FALSE(controller.RendererDidNavigate(subframe, params, &details));
- // Nothing should have changed.
- EXPECT_EQ(controller.GetEntryCount(), 1);
- EXPECT_EQ(controller.GetLastCommittedEntryIndex(), 0);
+ // Nothing should have changed at the top level.
+ EXPECT_EQ(1, controller.GetEntryCount());
+ EXPECT_EQ(0, controller.GetLastCommittedEntryIndex());
+
+ // The entry should now have a subframe FrameNavigationEntry.
+ NavigationEntryImpl* entry = controller.GetLastCommittedEntry();
+ FrameNavigationEntry* root_entry = entry->root_node()->frame_entry.get();
+ EXPECT_EQ(url, root_entry->url());
+ ASSERT_EQ(1U, entry->root_node()->children.size());
+ FrameNavigationEntry* frame_entry =
+ entry->root_node()->children[0]->frame_entry.get();
+ EXPECT_EQ(subframe_url, frame_entry->url());
}
// Make sure that on cloning a WebContentsImpl and going back needs_reload is
« no previous file with comments | « content/browser/frame_host/navigation_controller_impl.cc ('k') | content/browser/frame_host/navigation_entry_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698