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

Side by Side Diff: content/browser/frame_host/navigator_impl_unittest.cc

Issue 701953006: PlzNavigate: Speculatively spawns a renderer process for navigations. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Updated tests and refactored code based on CR comments. Created 6 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
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "base/macros.h" 5 #include "base/macros.h"
6 #include "base/time/time.h" 6 #include "base/time/time.h"
7 #include "content/browser/frame_host/navigation_controller_impl.h" 7 #include "content/browser/frame_host/navigation_controller_impl.h"
8 #include "content/browser/frame_host/navigation_entry_impl.h" 8 #include "content/browser/frame_host/navigation_entry_impl.h"
9 #include "content/browser/frame_host/navigation_request.h" 9 #include "content/browser/frame_host/navigation_request.h"
10 #include "content/browser/frame_host/navigation_request_info.h" 10 #include "content/browser/frame_host/navigation_request_info.h"
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after
72 controller().GetBrowserContext()))); 72 controller().GetBrowserContext())));
73 static_cast<NavigatorImpl*>(node->navigator())->RequestNavigation( 73 static_cast<NavigatorImpl*>(node->navigator())->RequestNavigation(
74 node, *entry, reload_type, base::TimeTicks::Now()); 74 node, *entry, reload_type, base::TimeTicks::Now());
75 } 75 }
76 76
77 NavigationRequest* GetNavigationRequestForFrameTreeNode( 77 NavigationRequest* GetNavigationRequestForFrameTreeNode(
78 FrameTreeNode* frame_tree_node) { 78 FrameTreeNode* frame_tree_node) {
79 return static_cast<NavigatorImpl*>(frame_tree_node->navigator()) 79 return static_cast<NavigatorImpl*>(frame_tree_node->navigator())
80 ->GetNavigationRequestForNodeForTesting(frame_tree_node); 80 ->GetNavigationRequestForNodeForTesting(frame_tree_node);
81 } 81 }
82
83 RenderFrameHost* GetSpeculativeRenderFrameHost(RenderFrameHostManager* rfhm) {
84 return rfhm->speculative_render_frame_host_.get();
85 }
82 }; 86 };
83 87
84 // PlzNavigate: Test that a proper NavigationRequest is created by 88 // PlzNavigate: Test that a proper NavigationRequest is created by
85 // BeginNavigation. 89 // BeginNavigation.
86 // Note that all PlzNavigate methods on the browser side require the use of the 90 // Note that all PlzNavigate methods on the browser side require the use of the
87 // flag kEnableBrowserSideNavigation. 91 // flag kEnableBrowserSideNavigation.
88 TEST_F(NavigatorTestWithBrowserSideNavigation, BeginNavigation) { 92 TEST_F(NavigatorTestWithBrowserSideNavigation, BeginNavigation) {
89 const GURL kUrl1("http://www.google.com/"); 93 const GURL kUrl1("http://www.google.com/");
90 const GURL kUrl2("http://www.chromium.org/"); 94 const GURL kUrl2("http://www.chromium.org/");
91 const GURL kUrl3("http://www.gmail.com/"); 95 const GURL kUrl3("http://www.gmail.com/");
92 96
93 contents()->NavigateAndCommit(kUrl1); 97 contents()->NavigateAndCommit(kUrl1);
98 FrameTreeNode* root = contents()->GetFrameTree()->root();
99 RenderFrameHostManager* root_rfhm = root->render_manager();
clamy 2014/12/09 15:09:52 nit: Please add an empty line here.
carlosk 2014/12/16 01:53:47 This part was moved to another test.
100 // After a navigation is committed no speculative RenderFrameHost should
101 // exist.
102 EXPECT_FALSE(GetSpeculativeRenderFrameHost(root_rfhm));
94 103
95 // Add a subframe. 104 // Add a subframe.
96 FrameTreeNode* root = contents()->GetFrameTree()->root();
97 TestRenderFrameHost* subframe_rfh = static_cast<TestRenderFrameHost*>( 105 TestRenderFrameHost* subframe_rfh = static_cast<TestRenderFrameHost*>(
98 contents()->GetFrameTree()->AddFrame( 106 contents()->GetFrameTree()->AddFrame(
99 root, root->current_frame_host()->GetProcess()->GetID(), 14, 107 root, root->current_frame_host()->GetProcess()->GetID(), 14,
100 "Child")); 108 "Child"));
101 EXPECT_TRUE(subframe_rfh); 109 EXPECT_TRUE(subframe_rfh);
102 110
103 FrameTreeNode* subframe_node = subframe_rfh->frame_tree_node(); 111 FrameTreeNode* subframe_node = subframe_rfh->frame_tree_node();
112 RenderFrameHostManager* subframe_rfhm = subframe_node->render_manager();
113 EXPECT_NE(root_rfhm, subframe_rfhm);
104 SendRequestNavigation(subframe_rfh->frame_tree_node(), kUrl2); 114 SendRequestNavigation(subframe_rfh->frame_tree_node(), kUrl2);
105 // There is no previous renderer in the subframe, so BeginNavigation is 115 // There is no previous renderer in the subframe, so BeginNavigation is
106 // handled already. 116 // handled already.
107 NavigationRequest* subframe_request = 117 NavigationRequest* subframe_request =
108 GetNavigationRequestForFrameTreeNode(subframe_node); 118 GetNavigationRequestForFrameTreeNode(subframe_node);
109 TestNavigationURLLoader* subframe_loader = 119 TestNavigationURLLoader* subframe_loader =
110 GetLoaderForNavigationRequest(subframe_request); 120 GetLoaderForNavigationRequest(subframe_request);
111 ASSERT_TRUE(subframe_request); 121 ASSERT_TRUE(subframe_request);
112 EXPECT_EQ(kUrl2, subframe_request->common_params().url); 122 EXPECT_EQ(kUrl2, subframe_request->common_params().url);
113 EXPECT_EQ(kUrl2, subframe_loader->common_params().url); 123 EXPECT_EQ(kUrl2, subframe_loader->common_params().url);
114 // First party for cookies url should be that of the main frame. 124 // First party for cookies url should be that of the main frame.
115 EXPECT_EQ(kUrl1, subframe_loader->request_info()->first_party_for_cookies); 125 EXPECT_EQ(kUrl1, subframe_loader->request_info()->first_party_for_cookies);
116 EXPECT_FALSE(subframe_loader->request_info()->is_main_frame); 126 EXPECT_FALSE(subframe_loader->request_info()->is_main_frame);
117 EXPECT_TRUE(subframe_loader->request_info()->parent_is_main_frame); 127 EXPECT_TRUE(subframe_loader->request_info()->parent_is_main_frame);
128 // Subframe navigations should not create a speculative RenderFrameHost.
clamy 2014/12/09 15:09:52 nit: Please add an empty line before this comment.
carlosk 2014/12/16 01:53:47 Done.
129 // (unless site-per-process is enabled)
Charlie Reis 2014/12/10 22:37:45 nit: Period goes after the the close paren, not af
carlosk 2014/12/16 01:53:48 Done.
130 EXPECT_FALSE(GetSpeculativeRenderFrameHost(root_rfhm));
131 EXPECT_FALSE(GetSpeculativeRenderFrameHost(subframe_rfhm));
118 132
119 SendRequestNavigation(root, kUrl3); 133 SendRequestNavigation(root, kUrl3);
120 // Simulate a BeginNavigation IPC on the main frame. 134 // Simulate a BeginNavigation IPC on the main frame.
121 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl3); 135 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl3);
122 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(root); 136 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(root);
123 TestNavigationURLLoader* main_loader = 137 TestNavigationURLLoader* main_loader =
124 GetLoaderForNavigationRequest(main_request); 138 GetLoaderForNavigationRequest(main_request);
125 ASSERT_TRUE(main_request); 139 ASSERT_TRUE(main_request);
126 EXPECT_EQ(kUrl3, main_request->common_params().url); 140 EXPECT_EQ(kUrl3, main_request->common_params().url);
127 EXPECT_EQ(kUrl3, main_loader->common_params().url); 141 EXPECT_EQ(kUrl3, main_loader->common_params().url);
128 EXPECT_EQ(kUrl3, main_loader->request_info()->first_party_for_cookies); 142 EXPECT_EQ(kUrl3, main_loader->request_info()->first_party_for_cookies);
129 EXPECT_TRUE(main_loader->request_info()->is_main_frame); 143 EXPECT_TRUE(main_loader->request_info()->is_main_frame);
130 EXPECT_FALSE(main_loader->request_info()->parent_is_main_frame); 144 EXPECT_FALSE(main_loader->request_info()->parent_is_main_frame);
145 // Main frame navigations to different sites should use a speculative
clamy 2014/12/09 15:09:52 nit: Please add an empty line before this comment.
carlosk 2014/12/16 01:53:48 Done.
146 // RenderFrameHost.
147 EXPECT_TRUE(GetSpeculativeRenderFrameHost(root_rfhm));
148 EXPECT_FALSE(GetSpeculativeRenderFrameHost(subframe_rfhm));
131 } 149 }
132 150
133 // PlzNavigate: Test that RequestNavigation creates a NavigationRequest and that 151 // PlzNavigate: Test that RequestNavigation creates a NavigationRequest and that
134 // RenderFrameHost is not modified when the navigation commits. 152 // RenderFrameHost is not modified when the navigation commits.
135 TEST_F(NavigatorTestWithBrowserSideNavigation, NoLiveRenderer) { 153 TEST_F(NavigatorTestWithBrowserSideNavigation, NoLiveRenderer) {
136 const GURL kUrl("http://www.google.com/"); 154 const GURL kUrl("http://www.google.com/");
137 155
138 EXPECT_FALSE(main_test_rfh()->render_view_host()->IsRenderViewLive()); 156 EXPECT_FALSE(main_test_rfh()->render_view_host()->IsRenderViewLive());
139 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 157 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
158 RenderFrameHostManager* rfhm = node->render_manager();
140 SendRequestNavigation(node, kUrl); 159 SendRequestNavigation(node, kUrl);
141 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node); 160 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node);
142 // A NavigationRequest should have been generated. 161 // A NavigationRequest should have been generated.
143 EXPECT_TRUE(main_request != NULL); 162 EXPECT_TRUE(main_request != NULL);
163 // As we're re-using the current RenderFrameHost, no speculative one should be
clamy 2014/12/09 15:09:52 nit: Please add an empty line before this comment.
carlosk 2014/12/16 01:53:48 Done.
164 // created.
165 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
144 RenderFrameHostImpl* rfh = main_test_rfh(); 166 RenderFrameHostImpl* rfh = main_test_rfh();
145 167
146 // Now return the response without any redirects. This will cause the 168 // Now return the response without any redirects. This will cause the
147 // navigation to commit at the same URL. 169 // navigation to commit at the same URL.
148 scoped_refptr<ResourceResponse> response(new ResourceResponse); 170 scoped_refptr<ResourceResponse> response(new ResourceResponse);
149 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted( 171 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted(
150 response, MakeEmptyStream()); 172 response, MakeEmptyStream());
151 main_request = GetNavigationRequestForFrameTreeNode(node); 173 main_request = GetNavigationRequestForFrameTreeNode(node);
152 174
153 // The main RFH should not have been changed, and the renderer should have 175 // The main RFH should not have been changed, and the renderer should have
154 // been initialized. 176 // been initialized.
155 EXPECT_EQ(rfh, main_test_rfh()); 177 EXPECT_EQ(rfh, main_test_rfh());
156 EXPECT_TRUE(main_test_rfh()->IsRenderFrameLive()); 178 EXPECT_TRUE(main_test_rfh()->IsRenderFrameLive());
157 EXPECT_TRUE(main_test_rfh()->render_view_host()->IsRenderViewLive()); 179 EXPECT_TRUE(main_test_rfh()->render_view_host()->IsRenderViewLive());
158 } 180 }
159 181
160 // PlzNavigate: Test that commiting an HTTP 204 or HTTP 205 response cancels the 182 // PlzNavigate: Test that committing an HTTP 204 or HTTP 205 response cancels
161 // navigation. 183 // the navigation.
162 TEST_F(NavigatorTestWithBrowserSideNavigation, NoContent) { 184 TEST_F(NavigatorTestWithBrowserSideNavigation, NoContent) {
163 const GURL kUrl1("http://www.chromium.org/"); 185 const GURL kUrl1("http://www.chromium.org/");
164 const GURL kUrl2("http://www.google.com/"); 186 const GURL kUrl2("http://www.google.com/");
165 187
166 // Load a URL. 188 // Load a URL.
167 contents()->NavigateAndCommit(kUrl1); 189 contents()->NavigateAndCommit(kUrl1);
168 RenderFrameHostImpl* rfh = main_test_rfh(); 190 RenderFrameHostImpl* rfh = main_test_rfh();
169 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, rfh->rfh_state()); 191 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, rfh->rfh_state());
170 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 192 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
193 RenderFrameHostManager* rfhm = node->render_manager();
171 194
172 // Navigate to a different site. 195 // Navigate to a different site.
173 SendRequestNavigation(node, kUrl2); 196 SendRequestNavigation(node, kUrl2);
174 main_test_rfh()->SendBeginNavigationWithURL(kUrl2); 197 main_test_rfh()->SendBeginNavigationWithURL(kUrl2);
175 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node); 198 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node);
176 ASSERT_TRUE(main_request); 199 ASSERT_TRUE(main_request);
200 // Navigations to a different site do create a speculative RenderFrameHost.
clamy 2014/12/09 15:09:52 nit: Please add an empty line before this comment.
carlosk 2014/12/16 01:53:48 Done.
201 EXPECT_TRUE(GetSpeculativeRenderFrameHost(rfhm));
177 202
178 // Commit an HTTP 204 response. 203 // Commit an HTTP 204 response.
179 scoped_refptr<ResourceResponse> response(new ResourceResponse); 204 scoped_refptr<ResourceResponse> response(new ResourceResponse);
180 const char kNoContentHeaders[] = "HTTP/1.1 204 No Content\0\0"; 205 const char kNoContentHeaders[] = "HTTP/1.1 204 No Content\0\0";
181 response->head.headers = new net::HttpResponseHeaders( 206 response->head.headers = new net::HttpResponseHeaders(
182 std::string(kNoContentHeaders, arraysize(kNoContentHeaders))); 207 std::string(kNoContentHeaders, arraysize(kNoContentHeaders)));
183 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted( 208 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted(
184 response, MakeEmptyStream()); 209 response, MakeEmptyStream());
185 210
186 // There should be no pending RenderFrameHost; the navigation was aborted. 211 // There should be no pending nor speculative RenderFrameHost; the navigation
212 // was aborted.
187 EXPECT_FALSE(GetNavigationRequestForFrameTreeNode(node)); 213 EXPECT_FALSE(GetNavigationRequestForFrameTreeNode(node));
188 EXPECT_FALSE(node->render_manager()->pending_frame_host()); 214 EXPECT_FALSE(node->render_manager()->pending_frame_host());
215 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
189 216
190 // Now, repeat the test with 205 Reset Content. 217 // Now, repeat the test with 205 Reset Content.
191 218
192 // Navigate to a different site again. 219 // Navigate to a different site again.
193 SendRequestNavigation(node, kUrl2); 220 SendRequestNavigation(node, kUrl2);
194 main_test_rfh()->SendBeginNavigationWithURL(kUrl2); 221 main_test_rfh()->SendBeginNavigationWithURL(kUrl2);
195 main_request = GetNavigationRequestForFrameTreeNode(node); 222 main_request = GetNavigationRequestForFrameTreeNode(node);
196 ASSERT_TRUE(main_request); 223 ASSERT_TRUE(main_request);
224 EXPECT_TRUE(GetSpeculativeRenderFrameHost(rfhm));
197 225
198 // Commit an HTTP 205 response. 226 // Commit an HTTP 205 response.
199 response = new ResourceResponse; 227 response = new ResourceResponse;
200 const char kResetContentHeaders[] = "HTTP/1.1 205 Reset Content\0\0"; 228 const char kResetContentHeaders[] = "HTTP/1.1 205 Reset Content\0\0";
201 response->head.headers = new net::HttpResponseHeaders( 229 response->head.headers = new net::HttpResponseHeaders(
202 std::string(kResetContentHeaders, arraysize(kResetContentHeaders))); 230 std::string(kResetContentHeaders, arraysize(kResetContentHeaders)));
203 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted( 231 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted(
204 response, MakeEmptyStream()); 232 response, MakeEmptyStream());
205 233
206 // There should be no pending RenderFrameHost; the navigation was aborted. 234 // There should be no pending nor speculative RenderFrameHost; the navigation
235 // was aborted.
207 EXPECT_FALSE(GetNavigationRequestForFrameTreeNode(node)); 236 EXPECT_FALSE(GetNavigationRequestForFrameTreeNode(node));
208 EXPECT_FALSE(node->render_manager()->pending_frame_host()); 237 EXPECT_FALSE(node->render_manager()->pending_frame_host());
238 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
209 } 239 }
210 240
211 // PlzNavigate: Test that a new RenderFrameHost is created when doing a cross 241 // PlzNavigate: Test that a new RenderFrameHost is created when doing a cross
212 // site navigation. 242 // site navigation.
213 TEST_F(NavigatorTestWithBrowserSideNavigation, CrossSiteNavigation) { 243 TEST_F(NavigatorTestWithBrowserSideNavigation, CrossSiteNavigation) {
214 const GURL kUrl1("http://www.chromium.org/"); 244 const GURL kUrl1("http://www.chromium.org/");
215 const GURL kUrl2("http://www.google.com/"); 245 const GURL kUrl2("http://www.google.com/");
216 246
217 contents()->NavigateAndCommit(kUrl1); 247 contents()->NavigateAndCommit(kUrl1);
218 RenderFrameHostImpl* rfh = main_test_rfh(); 248 RenderFrameHostImpl* rfh = main_test_rfh();
219 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, rfh->rfh_state()); 249 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, rfh->rfh_state());
220 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 250 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
251 RenderFrameHostManager* rfhm = node->render_manager();
221 252
222 // Navigate to a different site. 253 // Navigate to a different site.
223 SendRequestNavigation(node, kUrl2); 254 SendRequestNavigation(node, kUrl2);
224 main_test_rfh()->SendBeginNavigationWithURL(kUrl2); 255 main_test_rfh()->SendBeginNavigationWithURL(kUrl2);
225 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node); 256 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node);
226 ASSERT_TRUE(main_request); 257 ASSERT_TRUE(main_request);
258 EXPECT_TRUE(GetSpeculativeRenderFrameHost(rfhm));
227 259
228 scoped_refptr<ResourceResponse> response(new ResourceResponse); 260 scoped_refptr<ResourceResponse> response(new ResourceResponse);
229 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted( 261 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted(
230 response, MakeEmptyStream()); 262 response, MakeEmptyStream());
231 RenderFrameHostImpl* pending_rfh = 263 RenderFrameHostImpl* final_rfh = main_test_rfh();
232 node->render_manager()->pending_frame_host(); 264 ASSERT_TRUE(final_rfh);
233 ASSERT_TRUE(pending_rfh); 265 EXPECT_NE(final_rfh, rfh);
234 EXPECT_NE(pending_rfh, rfh); 266 EXPECT_TRUE(final_rfh->IsRenderFrameLive());
235 EXPECT_TRUE(pending_rfh->IsRenderFrameLive()); 267 EXPECT_TRUE(final_rfh->render_view_host()->IsRenderViewLive());
236 EXPECT_TRUE(pending_rfh->render_view_host()->IsRenderViewLive()); 268 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
237 } 269 }
238 270
239 // PlzNavigate: Test that redirects are followed. 271 // PlzNavigate: Test that redirects are followed and the speculative renderer
272 // logic behaves as expected.
240 TEST_F(NavigatorTestWithBrowserSideNavigation, RedirectCrossSite) { 273 TEST_F(NavigatorTestWithBrowserSideNavigation, RedirectCrossSite) {
241 const GURL kUrl1("http://www.chromium.org/"); 274 const GURL kUrl1("http://www.chromium.org/");
242 const GURL kUrl2("http://www.google.com/"); 275 const GURL kUrl2("http://www.google.com/");
243 276
244 contents()->NavigateAndCommit(kUrl1); 277 contents()->NavigateAndCommit(kUrl1);
245 RenderFrameHostImpl* rfh = main_test_rfh(); 278 RenderFrameHostImpl* rfh = main_test_rfh();
246 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, rfh->rfh_state()); 279 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, rfh->rfh_state());
247 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 280 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
281 RenderFrameHostManager* rfhm = node->render_manager();
248 282
249 // Navigate to a URL on the same site. 283 // Navigate to a URL on the same site.
250 SendRequestNavigation(node, kUrl1); 284 SendRequestNavigation(node, kUrl1);
251 main_test_rfh()->SendBeginNavigationWithURL(kUrl1); 285 main_test_rfh()->SendBeginNavigationWithURL(kUrl1);
252 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node); 286 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node);
253 ASSERT_TRUE(main_request); 287 ASSERT_TRUE(main_request);
288 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
254 289
255 // It then redirects to another site. 290 // It then redirects to another site.
256 net::RedirectInfo redirect_info; 291 net::RedirectInfo redirect_info;
257 redirect_info.status_code = 302; 292 redirect_info.status_code = 302;
258 redirect_info.new_method = "GET"; 293 redirect_info.new_method = "GET";
259 redirect_info.new_url = kUrl2; 294 redirect_info.new_url = kUrl2;
260 redirect_info.new_first_party_for_cookies = kUrl2; 295 redirect_info.new_first_party_for_cookies = kUrl2;
261 scoped_refptr<ResourceResponse> response(new ResourceResponse); 296 scoped_refptr<ResourceResponse> response(new ResourceResponse);
262 GetLoaderForNavigationRequest(main_request)->CallOnRequestRedirected( 297 GetLoaderForNavigationRequest(main_request)->CallOnRequestRedirected(
263 redirect_info, response); 298 redirect_info, response);
264 299
265 // The redirect should have been followed. 300 // The redirect should have been followed.
266 EXPECT_EQ(1, GetLoaderForNavigationRequest(main_request)->redirect_count()); 301 EXPECT_EQ(1, GetLoaderForNavigationRequest(main_request)->redirect_count());
302 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
267 303
268 // Then it commits. 304 // Then it commits.
269 response = new ResourceResponse; 305 response = new ResourceResponse;
270 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted( 306 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted(
271 response, MakeEmptyStream()); 307 response, MakeEmptyStream());
272 RenderFrameHostImpl* pending_rfh = 308 RenderFrameHostImpl* final_rfh = main_test_rfh();
273 node->render_manager()->pending_frame_host(); 309 ASSERT_TRUE(final_rfh);
274 ASSERT_TRUE(pending_rfh); 310 EXPECT_NE(final_rfh, rfh);
275 EXPECT_NE(pending_rfh, rfh); 311 EXPECT_TRUE(final_rfh->IsRenderFrameLive());
276 EXPECT_TRUE(pending_rfh->IsRenderFrameLive()); 312 EXPECT_TRUE(final_rfh->render_view_host()->IsRenderViewLive());
277 EXPECT_TRUE(pending_rfh->render_view_host()->IsRenderViewLive()); 313 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
278 } 314 }
279 315
280 // PlzNavigate: Test that a navigation is cancelled if another request has been 316 // PlzNavigate: Test that a navigation is canceled if another request has been
281 // issued in the meantime. 317 // issued in the meantime. Also confirms that the speculative renderer is
318 // correctly updated in the process.
282 TEST_F(NavigatorTestWithBrowserSideNavigation, ReplacePendingNavigation) { 319 TEST_F(NavigatorTestWithBrowserSideNavigation, ReplacePendingNavigation) {
283 const GURL kUrl0("http://www.wikipedia.org/"); 320 const GURL kUrl0("http://www.wikipedia.org/");
284 const GURL kUrl0_site = SiteInstance::GetSiteForURL(browser_context(), kUrl0); 321 const GURL kUrl0_site = SiteInstance::GetSiteForURL(browser_context(), kUrl0);
285 const GURL kUrl1("http://www.chromium.org/"); 322 const GURL kUrl1("http://www.chromium.org/");
323 const GURL kUrl1_site = SiteInstance::GetSiteForURL(browser_context(), kUrl1);
286 const GURL kUrl2("http://www.google.com/"); 324 const GURL kUrl2("http://www.google.com/");
287 const GURL kUrl2_site = SiteInstance::GetSiteForURL(browser_context(), kUrl2); 325 const GURL kUrl2_site = SiteInstance::GetSiteForURL(browser_context(), kUrl2);
288 326
289 // Initialization. 327 // Initialization.
290 contents()->NavigateAndCommit(kUrl0); 328 contents()->NavigateAndCommit(kUrl0);
291 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 329 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
330 RenderFrameHostManager* rfhm = node->render_manager();
292 EXPECT_EQ(kUrl0_site, main_test_rfh()->GetSiteInstance()->GetSiteURL()); 331 EXPECT_EQ(kUrl0_site, main_test_rfh()->GetSiteInstance()->GetSiteURL());
293 332
294 // Request navigation to the 1st URL. 333 // Request navigation to the 1st URL.
295 SendRequestNavigation(node, kUrl1); 334 SendRequestNavigation(node, kUrl1);
296 main_test_rfh()->SendBeginNavigationWithURL(kUrl1); 335 main_test_rfh()->SendBeginNavigationWithURL(kUrl1);
297 NavigationRequest* request1 = GetNavigationRequestForFrameTreeNode(node); 336 NavigationRequest* request1 = GetNavigationRequestForFrameTreeNode(node);
298 ASSERT_TRUE(request1); 337 ASSERT_TRUE(request1);
299 EXPECT_EQ(kUrl1, request1->common_params().url); 338 EXPECT_EQ(kUrl1, request1->common_params().url);
300 base::WeakPtr<TestNavigationURLLoader> loader1 = 339 base::WeakPtr<TestNavigationURLLoader> loader1 =
301 GetLoaderForNavigationRequest(request1)->AsWeakPtr(); 340 GetLoaderForNavigationRequest(request1)->AsWeakPtr();
302 341
342 // Confirm a speculative RFH was created.
343 ASSERT_TRUE(GetSpeculativeRenderFrameHost(rfhm));
344 int32 site_instance_id_1 =
345 GetSpeculativeRenderFrameHost(rfhm)->GetSiteInstance()->GetId();
346 EXPECT_EQ(
347 kUrl1_site,
348 GetSpeculativeRenderFrameHost(rfhm)->GetSiteInstance()->GetSiteURL());
349
303 // Request navigation to the 2nd URL; the NavigationRequest must have been 350 // Request navigation to the 2nd URL; the NavigationRequest must have been
304 // replaced by a new one with a different URL. 351 // replaced by a new one with a different URL.
305 SendRequestNavigation(node, kUrl2); 352 SendRequestNavigation(node, kUrl2);
306 main_test_rfh()->SendBeginNavigationWithURL(kUrl2); 353 main_test_rfh()->SendBeginNavigationWithURL(kUrl2);
307 NavigationRequest* request2 = GetNavigationRequestForFrameTreeNode(node); 354 NavigationRequest* request2 = GetNavigationRequestForFrameTreeNode(node);
308 ASSERT_TRUE(request2); 355 ASSERT_TRUE(request2);
309 EXPECT_EQ(kUrl2, request2->common_params().url); 356 EXPECT_EQ(kUrl2, request2->common_params().url);
310 357
311 // Confirm that the first loader got destroyed. 358 // Confirm that the first loader got destroyed.
312 EXPECT_FALSE(loader1); 359 EXPECT_FALSE(loader1);
313 360
361 // Confirm that a new speculative RFH was created.
362 ASSERT_TRUE(GetSpeculativeRenderFrameHost(rfhm));
363 int32 site_instance_id_2 =
364 GetSpeculativeRenderFrameHost(rfhm)->GetSiteInstance()->GetId();
365 EXPECT_NE(site_instance_id_1, site_instance_id_2);
366
314 // Confirm that the commit corresponds to the new request. 367 // Confirm that the commit corresponds to the new request.
315 scoped_refptr<ResourceResponse> response(new ResourceResponse); 368 scoped_refptr<ResourceResponse> response(new ResourceResponse);
316 GetLoaderForNavigationRequest(request2)->CallOnResponseStarted( 369 GetLoaderForNavigationRequest(request2)->CallOnResponseStarted(
317 response, MakeEmptyStream()); 370 response, MakeEmptyStream());
318 RenderFrameHostImpl* pending_rfh = 371 ASSERT_TRUE(main_test_rfh());
319 node->render_manager()->pending_frame_host(); 372 EXPECT_EQ(kUrl2_site, main_test_rfh()->GetSiteInstance()->GetSiteURL());
320 ASSERT_TRUE(pending_rfh); 373
321 EXPECT_EQ(kUrl2_site, pending_rfh->GetSiteInstance()->GetSiteURL()); 374 // Confirm that the committed RFH is the new speculative one.
375 EXPECT_EQ(site_instance_id_2, main_test_rfh()->GetSiteInstance()->GetId());
322 } 376 }
323 377
324 // PlzNavigate: Test that a reload navigation is properly signaled to the 378 // PlzNavigate: Test that a reload navigation is properly signaled to the
325 // renderer when the navigation can commit. 379 // renderer when the navigation can commit. Speculative renderers should not be
380 // created at any step.
326 TEST_F(NavigatorTestWithBrowserSideNavigation, Reload) { 381 TEST_F(NavigatorTestWithBrowserSideNavigation, Reload) {
327 const GURL kUrl("http://www.google.com/"); 382 const GURL kUrl("http://www.google.com/");
328 contents()->NavigateAndCommit(kUrl); 383 contents()->NavigateAndCommit(kUrl);
329 384
330 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 385 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
386 RenderFrameHostManager* rfhm = node->render_manager();
331 SendRequestNavigationWithParameters( 387 SendRequestNavigationWithParameters(
332 node, kUrl, Referrer(), ui::PAGE_TRANSITION_LINK, 388 node, kUrl, Referrer(), ui::PAGE_TRANSITION_LINK,
333 NavigationController::RELOAD); 389 NavigationController::RELOAD);
334 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl); 390 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl);
335 // A NavigationRequest should have been generated. 391 // A NavigationRequest should have been generated.
336 NavigationRequest* main_request = 392 NavigationRequest* main_request =
337 GetNavigationRequestForFrameTreeNode(node); 393 GetNavigationRequestForFrameTreeNode(node);
338 ASSERT_TRUE(main_request != NULL); 394 ASSERT_TRUE(main_request != NULL);
339 EXPECT_EQ(FrameMsg_Navigate_Type::RELOAD, 395 EXPECT_EQ(FrameMsg_Navigate_Type::RELOAD,
340 main_request->common_params().navigation_type); 396 main_request->common_params().navigation_type);
397 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
398
341 int page_id = contents()->GetMaxPageIDForSiteInstance( 399 int page_id = contents()->GetMaxPageIDForSiteInstance(
342 main_test_rfh()->GetSiteInstance()) + 1; 400 main_test_rfh()->GetSiteInstance()) + 1;
343 main_test_rfh()->SendNavigate(page_id, kUrl); 401 main_test_rfh()->SendNavigate(page_id, kUrl);
402 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
344 403
345 // Now do a shift+reload. 404 // Now do a shift+reload.
346 SendRequestNavigationWithParameters( 405 SendRequestNavigationWithParameters(
347 node, kUrl, Referrer(), ui::PAGE_TRANSITION_LINK, 406 node, kUrl, Referrer(), ui::PAGE_TRANSITION_LINK,
348 NavigationController::RELOAD_IGNORING_CACHE); 407 NavigationController::RELOAD_IGNORING_CACHE);
349 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl); 408 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl);
350 // A NavigationRequest should have been generated. 409 // A NavigationRequest should have been generated.
351 main_request = GetNavigationRequestForFrameTreeNode(node); 410 main_request = GetNavigationRequestForFrameTreeNode(node);
352 ASSERT_TRUE(main_request != NULL); 411 ASSERT_TRUE(main_request != NULL);
353 EXPECT_EQ(FrameMsg_Navigate_Type::RELOAD_IGNORING_CACHE, 412 EXPECT_EQ(FrameMsg_Navigate_Type::RELOAD_IGNORING_CACHE,
354 main_request->common_params().navigation_type); 413 main_request->common_params().navigation_type);
414 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
415 }
416
417 // PlzNavigate: Confirm that a speculative RenderFrameHost is used when
418 // navigating from one site to the another.
419 TEST_F(NavigatorTestWithBrowserSideNavigation,
420 SpeculativeRendererWorksBaseCase) {
421 // Navigate to an initial site.
422 const GURL kUrlInit("http://wikipedia.org/");
423 contents()->NavigateAndCommit(kUrlInit);
424 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
425 RenderFrameHostManager* rfhm = node->render_manager();
426 ASSERT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
427
428 // Begin navigating to another site.
429 const GURL kUrl("http://google.com/");
430 SendRequestNavigation(node, kUrl);
431 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl);
432 ASSERT_TRUE(GetSpeculativeRenderFrameHost(rfhm));
433 EXPECT_NE(GetSpeculativeRenderFrameHost(rfhm), main_test_rfh());
434 EXPECT_EQ(
435 SiteInstanceImpl::GetSiteForURL(browser_context(), kUrl),
436 GetSpeculativeRenderFrameHost(rfhm)->GetSiteInstance()->GetSiteURL());
437 int32 site_instance_id =
438 GetSpeculativeRenderFrameHost(rfhm)->GetSiteInstance()->GetId();
439
440 // Commit the navigation with Navigator by simulating the call to
Charlie Reis 2014/12/10 22:37:45 How about: "Ask Navigator to commit the navigation
carlosk 2014/12/16 01:53:48 Done.
441 // OnResponseStarted.
442 scoped_refptr<ResourceResponse> response(new ResourceResponse);
443 GetLoaderForNavigationRequest(GetNavigationRequestForFrameTreeNode(node))
444 ->CallOnResponseStarted(response, MakeEmptyStream());
445 EXPECT_EQ(site_instance_id, main_test_rfh()->GetSiteInstance()->GetId());
446 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
447
448 // And just for completeness invoke OnDidCommitProvisionalLoad which
449 // shouldn't change anything in RFHM.
450 FrameHostMsg_DidCommitProvisionalLoad_Params params;
451 params.page_id = 1;
452 params.url = kUrl;
453 params.was_within_same_page = false;
454 params.is_post = false;
455 params.post_id = -1;
456 params.page_state = PageState::CreateForTesting(kUrl, false, 0, 0);
457 main_test_rfh()->SendNavigateWithParams(&params);
458 EXPECT_EQ(site_instance_id, main_test_rfh()->GetSiteInstance()->GetId());
459 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
460 }
461
462 // PlzNavigate: Confirm that a speculative RenderFrameHost is thrown away when
463 // the final URL's site differs from the initial one due to redirects.
464 TEST_F(NavigatorTestWithBrowserSideNavigation,
465 SpeculativeRendererDiscardedAfterRedirectToAnotherSite) {
466 // Navigate to an initial site.
467 const GURL kUrlInit("http://wikipedia.org/");
468 contents()->NavigateAndCommit(kUrlInit);
469 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
470 RenderFrameHostManager* rfhm = node->render_manager();
471 ASSERT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
472
473 // Begin navigating to another site.
474 const GURL kUrl("http://google.com/");
475 SendRequestNavigation(node, kUrl);
476 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl);
477 int32 site_instance_id =
478 GetSpeculativeRenderFrameHost(rfhm)->GetSiteInstance()->GetId();
479 ASSERT_TRUE(GetSpeculativeRenderFrameHost(rfhm));
480 EXPECT_NE(GetSpeculativeRenderFrameHost(rfhm), main_test_rfh());
481 EXPECT_EQ(
482 SiteInstanceImpl::GetSiteForURL(browser_context(), kUrl),
483 GetSpeculativeRenderFrameHost(rfhm)->GetSiteInstance()->GetSiteURL());
484
485 // It then redirects to yet another site.
486 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node);
487 ASSERT_TRUE(main_request);
488 const GURL kUrlRedirect("https://www.google.com/");
489 net::RedirectInfo redirect_info;
490 redirect_info.status_code = 302;
491 redirect_info.new_method = "GET";
492 redirect_info.new_url = kUrlRedirect;
493 redirect_info.new_first_party_for_cookies = kUrlRedirect;
494 scoped_refptr<ResourceResponse> response(new ResourceResponse);
495 GetLoaderForNavigationRequest(main_request)
496 ->CallOnRequestRedirected(redirect_info, response);
497 ASSERT_TRUE(GetSpeculativeRenderFrameHost(rfhm));
498 EXPECT_EQ(site_instance_id,
Charlie Reis 2014/12/10 22:37:45 Please add a TODO, given that the behavior (stale
carlosk 2014/12/16 01:53:48 Done.
499 GetSpeculativeRenderFrameHost(rfhm)->GetSiteInstance()->GetId());
500
501 // Commit the navigation with Navigator by simulating the call to
502 // OnResponseStarted.
503 response = new ResourceResponse;
504 GetLoaderForNavigationRequest(main_request)
505 ->CallOnResponseStarted(response, MakeEmptyStream());
506 EXPECT_NE(site_instance_id, main_test_rfh()->GetSiteInstance()->GetId());
507 EXPECT_EQ(SiteInstanceImpl::GetSiteForURL(browser_context(), kUrlRedirect),
508 main_test_rfh()->GetSiteInstance()->GetSiteURL());
509 EXPECT_FALSE(GetSpeculativeRenderFrameHost(rfhm));
510 }
511
512 // PlzNavigate: Verify a previously swapped-out RenderFrameHost is correctly
clamy 2014/12/09 15:09:52 s/Verify/Verify that I would also rephrase as "is
carlosk 2014/12/16 01:53:48 Done.
513 // activated when speculatively selected.
514 TEST_F(NavigatorTestWithBrowserSideNavigation,
515 SpeculativeRendererReuseSwappedOutRFH) {
516 FAIL() << "Must be implemented";
carlosk 2014/12/09 07:55:43 Failing test that I will implement in the next Pat
clamy 2014/12/09 15:09:52 Acknowledged.
355 } 517 }
356 518
357 } // namespace content 519 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698