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

Unified Diff: content/renderer/render_view_browsertest.cc

Issue 1427633004: Send navigation_start to the browser in DidStartProvisionalLoad IPC (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@navigation_start_renderer
Patch Set: ASSERT => EXPECT and comment change Created 5 years, 1 month 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
« no previous file with comments | « content/renderer/render_frame_impl.cc ('k') | content/test/test_render_frame_host.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/renderer/render_view_browsertest.cc
diff --git a/content/renderer/render_view_browsertest.cc b/content/renderer/render_view_browsertest.cc
index 3783e905dec877e5290a037b27410839a66608b9..927c81bc3ae195154abde28a4dfa06c0ef107459 100644
--- a/content/renderer/render_view_browsertest.cc
+++ b/content/renderer/render_view_browsertest.cc
@@ -137,6 +137,13 @@ class WebUITestWebUIControllerFactory : public WebUIControllerFactory {
}
};
+// Timestamps logged close to each other under low resolution timers
+// are more likely to record the same value. Allow for this by relaxing
+// constraints o systems with these timers.
Avi (use Gerrit) 2015/11/14 01:08:34 s/o/on/
+bool TimeTicksGT(const base::TimeTicks& x, const base::TimeTicks& y) {
+ return base::TimeTicks::IsHighResolution() ? x > y : x >= y;
+}
+
} // namespace
class RenderViewImplTest : public RenderViewTest {
@@ -168,6 +175,39 @@ class RenderViewImplTest : public RenderViewTest {
return static_cast<TestRenderFrame*>(view()->GetMainRenderFrame());
}
+ void GoToOffsetWithParams(int offset,
+ const PageState& state,
+ const CommonNavigationParams common_params,
+ const StartNavigationParams start_params,
+ RequestNavigationParams request_params) {
+ EXPECT_TRUE(common_params.transition & ui::PAGE_TRANSITION_FORWARD_BACK);
+ int history_list_length = view()->historyBackListCount() +
+ view()->historyForwardListCount() + 1;
Avi (use Gerrit) 2015/11/14 01:08:34 If you're going into the RenderViewImpl and pullin
+ int pending_offset = offset + view()->history_list_offset_;
+
+ request_params.page_state = state;
+ request_params.page_id = view()->page_id_ + offset;
+ request_params.nav_entry_id = pending_offset + 1;
+ request_params.pending_history_list_offset = pending_offset;
+ request_params.current_history_list_offset = view()->history_list_offset_;
+ request_params.current_history_list_length = history_list_length;
+ frame()->Navigate(common_params, start_params, request_params);
+
+ // The load actually happens asynchronously, so we pump messages to process
+ // the pending continuation.
+ FrameLoadWaiter(frame()).Wait();
+ }
+
+ template<class T>
+ typename T::Param ProcessAndReadIPC() {
+ ProcessPendingMessages();
+ const IPC::Message* message =
+ render_thread_->sink().GetUniqueMessageMatching(T::ID);
+ typename T::Param param;
+ T::Read(message, &param);
+ return param;
+ }
+
// Sends IPC messages that emulates a key-press event.
int SendKeyEvent(MockKeyboard::Layout layout,
int key_code,
@@ -2284,6 +2324,91 @@ TEST_F(RenderViewImplTest, NavigationStartOverride) {
EXPECT_LE(late_nav_reported_start, after_navigation);
}
+TEST_F(RenderViewImplTest, RendererNavigationStartTransmittedToBrowser) {
+ base::TimeTicks lower_bound_navigation_start;
+ frame()->GetWebFrame()->loadHTMLString(
+ "hello world", blink::WebURL(GURL("data:text/html,")));
+ ProcessPendingMessages();
+ const IPC::Message* frame_navigate_msg =
+ render_thread_->sink().GetUniqueMessageMatching(
+ FrameHostMsg_DidStartProvisionalLoadForFrame::ID);
+ FrameHostMsg_DidStartProvisionalLoadForFrame::Param host_nav_params;
+ FrameHostMsg_DidStartProvisionalLoadForFrame::Read(frame_navigate_msg,
+ &host_nav_params);
+ base::TimeTicks transmitted_start = base::get<1>(host_nav_params);
+ EXPECT_FALSE(transmitted_start.is_null());
+ EXPECT_LT(lower_bound_navigation_start, transmitted_start);
+}
+
+TEST_F(RenderViewImplTest, BrowserNavigationStartNotUsedForReload) {
+ const char url_string[] = "data:text/html,<div>Page</div>";
+ // Navigate once, then reload.
+ LoadHTML(url_string);
+ ProcessPendingMessages();
+ render_thread_->sink().ClearMessages();
+
+ CommonNavigationParams common_params;
+ common_params.url = GURL(url_string);
+ common_params.navigation_type =
+ FrameMsg_Navigate_Type::RELOAD_ORIGINAL_REQUEST_URL;
+ common_params.transition = ui::PAGE_TRANSITION_RELOAD;
+
+ frame()->Navigate(common_params, StartNavigationParams(),
+ RequestNavigationParams());
+
+ FrameHostMsg_DidStartProvisionalLoadForFrame::Param host_nav_params =
+ ProcessAndReadIPC<FrameHostMsg_DidStartProvisionalLoadForFrame>();
+ // The true timestamp is later than the browser initiated one.
+ EXPECT_PRED2(TimeTicksGT, base::get<1>(host_nav_params),
+ common_params.navigation_start);
+}
+
+TEST_F(RenderViewImplTest, BrowserNavigationStartNotUsedForHistoryNavigation) {
+ LoadHTML("<div id=pagename>Page A</div>");
+ LoadHTML("<div id=pagename>Page B</div>");
+ PageState back_state =
+ HistoryEntryToPageState(view()->history_controller()->GetCurrentEntry());
+ LoadHTML("<div id=pagename>Page C</div>");
+ PageState forward_state =
+ HistoryEntryToPageState(view()->history_controller()->GetCurrentEntry());
+ ProcessPendingMessages();
+ render_thread_->sink().ClearMessages();
+
+ CommonNavigationParams common_params;
+ common_params.transition = ui::PAGE_TRANSITION_FORWARD_BACK;
+ // Go back.
+ GoToOffsetWithParams(-1, back_state, common_params, StartNavigationParams(),
+ RequestNavigationParams());
+ FrameHostMsg_DidStartProvisionalLoadForFrame::Param host_nav_params =
+ ProcessAndReadIPC<FrameHostMsg_DidStartProvisionalLoadForFrame>();
+ EXPECT_PRED2(TimeTicksGT, base::get<1>(host_nav_params),
+ common_params.navigation_start);
+ render_thread_->sink().ClearMessages();
+
+ // Go forward.
+ GoToOffsetWithParams(1, forward_state, common_params,
+ StartNavigationParams(),
+ RequestNavigationParams());
+ FrameHostMsg_DidStartProvisionalLoadForFrame::Param host_nav_params2 =
+ ProcessAndReadIPC<FrameHostMsg_DidStartProvisionalLoadForFrame>();
+ EXPECT_PRED2(TimeTicksGT, base::get<1>(host_nav_params2),
+ common_params.navigation_start);
+}
+
+TEST_F(RenderViewImplTest, BrowserNavigationStartSuccessfullyTransmitted) {
+ CommonNavigationParams common_params;
+ common_params.url = GURL("data:text/html,<div>Page</div>");
+ common_params.navigation_type = FrameMsg_Navigate_Type::NORMAL;
+ common_params.transition = ui::PAGE_TRANSITION_TYPED;
+
+ frame()->Navigate(common_params, StartNavigationParams(),
+ RequestNavigationParams());
+
+ FrameHostMsg_DidStartProvisionalLoadForFrame::Param host_nav_params =
+ ProcessAndReadIPC<FrameHostMsg_DidStartProvisionalLoadForFrame>();
+ EXPECT_EQ(base::get<1>(host_nav_params), common_params.navigation_start);
+}
+
TEST_F(RenderViewImplTest, PreferredSizeZoomed) {
LoadHTML("<body style='margin:0;'><div style='display:inline-block; "
"width:400px; height:400px;'/></body>");
« no previous file with comments | « content/renderer/render_frame_impl.cc ('k') | content/test/test_render_frame_host.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698