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

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: Latest changes due to review comments. Created 5 years, 11 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 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/command_line.h"
5 #include "base/macros.h" 6 #include "base/macros.h"
6 #include "base/time/time.h" 7 #include "base/time/time.h"
7 #include "content/browser/frame_host/navigation_controller_impl.h" 8 #include "content/browser/frame_host/navigation_controller_impl.h"
8 #include "content/browser/frame_host/navigation_entry_impl.h" 9 #include "content/browser/frame_host/navigation_entry_impl.h"
9 #include "content/browser/frame_host/navigation_request.h" 10 #include "content/browser/frame_host/navigation_request.h"
10 #include "content/browser/frame_host/navigation_request_info.h" 11 #include "content/browser/frame_host/navigation_request_info.h"
11 #include "content/browser/frame_host/navigator.h" 12 #include "content/browser/frame_host/navigator.h"
12 #include "content/browser/frame_host/navigator_impl.h" 13 #include "content/browser/frame_host/navigator_impl.h"
13 #include "content/browser/frame_host/render_frame_host_manager.h" 14 #include "content/browser/frame_host/render_frame_host_manager.h"
14 #include "content/browser/site_instance_impl.h" 15 #include "content/browser/site_instance_impl.h"
15 #include "content/browser/streams/stream.h" 16 #include "content/browser/streams/stream.h"
16 #include "content/common/navigation_params.h" 17 #include "content/common/navigation_params.h"
17 #include "content/public/browser/stream_handle.h" 18 #include "content/public/browser/stream_handle.h"
19 #include "content/public/common/content_switches.h"
18 #include "content/public/common/url_constants.h" 20 #include "content/public/common/url_constants.h"
19 #include "content/public/common/url_utils.h" 21 #include "content/public/common/url_utils.h"
22 #include "content/public/test/mock_render_process_host.h"
20 #include "content/test/browser_side_navigation_test_utils.h" 23 #include "content/test/browser_side_navigation_test_utils.h"
21 #include "content/test/test_navigation_url_loader.h" 24 #include "content/test/test_navigation_url_loader.h"
22 #include "content/test/test_render_frame_host.h" 25 #include "content/test/test_render_frame_host.h"
23 #include "content/test/test_web_contents.h" 26 #include "content/test/test_web_contents.h"
24 #include "net/base/load_flags.h" 27 #include "net/base/load_flags.h"
25 #include "net/http/http_response_headers.h" 28 #include "net/http/http_response_headers.h"
26 #include "net/url_request/redirect_info.h" 29 #include "net/url_request/redirect_info.h"
27 #include "ui/base/page_transition_types.h" 30 #include "ui/base/page_transition_types.h"
28 #include "url/url_constants.h" 31 #include "url/url_constants.h"
29 32
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
66 controller().GetBrowserContext()))); 69 controller().GetBrowserContext())));
67 static_cast<NavigatorImpl*>(node->navigator())->RequestNavigation( 70 static_cast<NavigatorImpl*>(node->navigator())->RequestNavigation(
68 node, *entry, reload_type, base::TimeTicks::Now()); 71 node, *entry, reload_type, base::TimeTicks::Now());
69 } 72 }
70 73
71 NavigationRequest* GetNavigationRequestForFrameTreeNode( 74 NavigationRequest* GetNavigationRequestForFrameTreeNode(
72 FrameTreeNode* frame_tree_node) { 75 FrameTreeNode* frame_tree_node) {
73 return static_cast<NavigatorImpl*>(frame_tree_node->navigator()) 76 return static_cast<NavigatorImpl*>(frame_tree_node->navigator())
74 ->GetNavigationRequestForNodeForTesting(frame_tree_node); 77 ->GetNavigationRequestForNodeForTesting(frame_tree_node);
75 } 78 }
79
80 TestRenderFrameHost* GetSpeculativeRenderFrameHost(FrameTreeNode* node) {
81 return static_cast<TestRenderFrameHost*>(
82 node->render_manager()->speculative_render_frame_host_.get());
83 }
84
85 // Checks if this RenderFrameHost sent a single FrameMsg_CommitNavigation
86 // since the last clearing of the sink.
87 // Note: caller must invoke ClearMessages on the sink at some point before
88 // the tracked commit happens to clear up commit messages from previous
89 // navigations.
90 bool DidRenderFrameHostCommit(RenderFrameHostImpl* rfh) {
91 MockRenderProcessHost* rph =
92 static_cast<MockRenderProcessHost*>(rfh->GetProcess());
93 const FrameMsg_CommitNavigation* commit_message =
94 static_cast<const FrameMsg_CommitNavigation*>(
95 rph->sink().GetUniqueMessageMatching(
96 FrameMsg_CommitNavigation::ID));
97 return commit_message &&
98 rfh->GetRoutingID() == commit_message->routing_id();
Charlie Reis 2015/01/12 23:30:51 nit: Wrong indent (should be 4 spaces). I'll defe
carlosk 2015/01/13 15:54:12 It disagrees. :) I've been trying to run it alway
Charlie Reis 2015/01/13 18:48:21 Acknowledged.
99 }
76 }; 100 };
77 101
102 // PlzNavigate: Test final state after a complete navigation (to avoid repeating
103 // these checks in other tests).
104 TEST_F(NavigatorTestWithBrowserSideNavigation, NavigationFinishedState) {
105 const GURL kUrl("http://chromium.org/");
106 contents()->NavigateAndCommit(kUrl);
107 ASSERT_TRUE(main_test_rfh());
108 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, main_test_rfh()->rfh_state());
109 EXPECT_EQ(SiteInstanceImpl::GetSiteForURL(browser_context(), kUrl),
Charlie Reis 2015/01/12 23:30:52 This is a good idea to test, but it's equally impo
carlosk 2015/01/13 15:54:12 Done. I wanted to be sure with this expectation t
110 main_test_rfh()->GetSiteInstance()->GetSiteURL());
111
112 // After a navigation is finished no speculative RenderFrameHost should
113 // exist.
114 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
115 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
116
117 // With PlzNavigate enabled a pending RenderFrameHost should never exist.
118 EXPECT_FALSE(node->render_manager()->pending_frame_host());
119 }
120
78 // PlzNavigate: Test that a proper NavigationRequest is created by 121 // PlzNavigate: Test that a proper NavigationRequest is created by
79 // BeginNavigation. 122 // BeginNavigation.
80 // Note that all PlzNavigate methods on the browser side require the use of the 123 // Note that all PlzNavigate methods on the browser side require the use of the
81 // flag kEnableBrowserSideNavigation. 124 // flag kEnableBrowserSideNavigation.
82 TEST_F(NavigatorTestWithBrowserSideNavigation, BeginNavigation) { 125 TEST_F(NavigatorTestWithBrowserSideNavigation, BeginNavigation) {
83 const GURL kUrl1("http://www.google.com/"); 126 const GURL kUrl1("http://www.google.com/");
84 const GURL kUrl2("http://www.chromium.org/"); 127 const GURL kUrl2("http://www.chromium.org/");
85 const GURL kUrl3("http://www.gmail.com/"); 128 const GURL kUrl3("http://www.gmail.com/");
86 129
87 contents()->NavigateAndCommit(kUrl1); 130 contents()->NavigateAndCommit(kUrl1);
88 131
89 // Add a subframe. 132 // Add a subframe.
90 FrameTreeNode* root = contents()->GetFrameTree()->root(); 133 FrameTreeNode* root_node = contents()->GetFrameTree()->root();
91 TestRenderFrameHost* subframe_rfh = static_cast<TestRenderFrameHost*>( 134 TestRenderFrameHost* subframe_rfh =
92 contents()->GetFrameTree()->AddFrame( 135 static_cast<TestRenderFrameHost*>(contents()->GetFrameTree()->AddFrame(
93 root, root->current_frame_host()->GetProcess()->GetID(), 14, 136 root_node, root_node->current_frame_host()->GetProcess()->GetID(), 14,
94 "Child")); 137 "Child"));
95 EXPECT_TRUE(subframe_rfh); 138 ASSERT_TRUE(subframe_rfh);
96 139
97 FrameTreeNode* subframe_node = subframe_rfh->frame_tree_node(); 140 FrameTreeNode* subframe_node = subframe_rfh->frame_tree_node();
98 SendRequestNavigation(subframe_rfh->frame_tree_node(), kUrl2); 141 SendRequestNavigation(subframe_node, kUrl2);
99 // There is no previous renderer in the subframe, so BeginNavigation is 142 // There is no previous renderer in the subframe, so BeginNavigation is
100 // handled already. 143 // handled already.
101 NavigationRequest* subframe_request = 144 NavigationRequest* subframe_request =
102 GetNavigationRequestForFrameTreeNode(subframe_node); 145 GetNavigationRequestForFrameTreeNode(subframe_node);
103 TestNavigationURLLoader* subframe_loader = 146 TestNavigationURLLoader* subframe_loader =
104 GetLoaderForNavigationRequest(subframe_request); 147 GetLoaderForNavigationRequest(subframe_request);
105 ASSERT_TRUE(subframe_request); 148 ASSERT_TRUE(subframe_request);
106 EXPECT_EQ(kUrl2, subframe_request->common_params().url); 149 EXPECT_EQ(kUrl2, subframe_request->common_params().url);
107 EXPECT_EQ(kUrl2, subframe_loader->common_params().url); 150 EXPECT_EQ(kUrl2, subframe_loader->common_params().url);
108 // First party for cookies url should be that of the main frame. 151 // First party for cookies url should be that of the main frame.
109 EXPECT_EQ(kUrl1, subframe_loader->request_info()->first_party_for_cookies); 152 EXPECT_EQ(kUrl1, subframe_loader->request_info()->first_party_for_cookies);
110 EXPECT_FALSE(subframe_loader->request_info()->is_main_frame); 153 EXPECT_FALSE(subframe_loader->request_info()->is_main_frame);
111 EXPECT_TRUE(subframe_loader->request_info()->parent_is_main_frame); 154 EXPECT_TRUE(subframe_loader->request_info()->parent_is_main_frame);
155 EXPECT_FALSE(GetSpeculativeRenderFrameHost(root_node));
112 156
113 SendRequestNavigation(root, kUrl3); 157 // Subframe navigations should never create a speculative RenderFrameHost,
158 // unless site-per-process is enabled. In that case as the subframe navigation
Charlie Reis 2015/01/12 23:30:51 nit: Comma after "In that case"
carlosk 2015/01/13 15:54:12 Done.
159 // is to a different site and is still ongoing, it should have one.
160 if (base::CommandLine::ForCurrentProcess()->HasSwitch(
161 switches::kSitePerProcess)) {
162 EXPECT_TRUE(GetSpeculativeRenderFrameHost(subframe_node));
163 } else {
164 EXPECT_FALSE(GetSpeculativeRenderFrameHost(subframe_node));
165 }
166
167 SendRequestNavigation(root_node, kUrl3);
114 // Simulate a BeginNavigation IPC on the main frame. 168 // Simulate a BeginNavigation IPC on the main frame.
115 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl3); 169 main_test_rfh()->SendBeginNavigationWithURL(kUrl3);
116 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(root); 170 NavigationRequest* main_request =
171 GetNavigationRequestForFrameTreeNode(root_node);
117 TestNavigationURLLoader* main_loader = 172 TestNavigationURLLoader* main_loader =
118 GetLoaderForNavigationRequest(main_request); 173 GetLoaderForNavigationRequest(main_request);
119 ASSERT_TRUE(main_request); 174 ASSERT_TRUE(main_request);
120 EXPECT_EQ(kUrl3, main_request->common_params().url); 175 EXPECT_EQ(kUrl3, main_request->common_params().url);
121 EXPECT_EQ(kUrl3, main_loader->common_params().url); 176 EXPECT_EQ(kUrl3, main_loader->common_params().url);
122 EXPECT_EQ(kUrl3, main_loader->request_info()->first_party_for_cookies); 177 EXPECT_EQ(kUrl3, main_loader->request_info()->first_party_for_cookies);
123 EXPECT_TRUE(main_loader->request_info()->is_main_frame); 178 EXPECT_TRUE(main_loader->request_info()->is_main_frame);
124 EXPECT_FALSE(main_loader->request_info()->parent_is_main_frame); 179 EXPECT_FALSE(main_loader->request_info()->parent_is_main_frame);
180
181 // Main frame navigation to a different site should use a speculative
182 // RenderFrameHost.
183 EXPECT_TRUE(GetSpeculativeRenderFrameHost(root_node));
184
185 // As the main frame hasn't yet committed the subframe still exists. So the
Charlie Reis 2015/01/12 23:30:52 nit: The second sentence is a sentence fragment. s
carlosk 2015/01/13 15:54:12 Done.
186 // above situation regarding subframe navigations is valid here.
187 if (base::CommandLine::ForCurrentProcess()->HasSwitch(
188 switches::kSitePerProcess)) {
189 EXPECT_TRUE(GetSpeculativeRenderFrameHost(subframe_node));
190 } else {
191 EXPECT_FALSE(GetSpeculativeRenderFrameHost(subframe_node));
192 }
125 } 193 }
126 194
127 // PlzNavigate: Test that RequestNavigation creates a NavigationRequest and that 195 // PlzNavigate: Test that RequestNavigation creates a NavigationRequest and that
128 // RenderFrameHost is not modified when the navigation commits. 196 // RenderFrameHost is not modified when the navigation commits.
129 TEST_F(NavigatorTestWithBrowserSideNavigation, NoLiveRenderer) { 197 TEST_F(NavigatorTestWithBrowserSideNavigation, NoLiveRenderer) {
130 const GURL kUrl("http://www.google.com/"); 198 const GURL kUrl("http://www.google.com/");
131 199
132 EXPECT_FALSE(main_test_rfh()->render_view_host()->IsRenderViewLive()); 200 EXPECT_FALSE(main_test_rfh()->render_view_host()->IsRenderViewLive());
133 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 201 RenderFrameHostImpl* rfh = main_test_rfh();
202 FrameTreeNode* node = rfh->frame_tree_node();
134 SendRequestNavigation(node, kUrl); 203 SendRequestNavigation(node, kUrl);
204
205 // A NavigationRequest should have been generated.
135 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node); 206 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node);
136 // A NavigationRequest should have been generated.
137 EXPECT_TRUE(main_request != NULL); 207 EXPECT_TRUE(main_request != NULL);
138 RenderFrameHostImpl* rfh = main_test_rfh(); 208
209 // As we're re-using the current RenderFrameHost, no speculative one should be
Charlie Reis 2015/01/12 23:30:52 English nit: "Since" or "Because" would be easier
carlosk 2015/01/13 15:54:12 Done. You didn't invent it (I assume) so no reason
210 // created.
211 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
139 212
140 // Now return the response without any redirects. This will cause the 213 // Now return the response without any redirects. This will cause the
141 // navigation to commit at the same URL. 214 // navigation to commit at the same URL.
142 scoped_refptr<ResourceResponse> response(new ResourceResponse); 215 scoped_refptr<ResourceResponse> response(new ResourceResponse);
143 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted( 216 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted(
144 response, MakeEmptyStream()); 217 response, MakeEmptyStream());
145 main_request = GetNavigationRequestForFrameTreeNode(node); 218 main_request = GetNavigationRequestForFrameTreeNode(node);
146 219
147 // The main RFH should not have been changed, and the renderer should have 220 // The main RFH should not have been changed, and the renderer should have
148 // been initialized. 221 // been initialized.
149 EXPECT_EQ(rfh, main_test_rfh()); 222 EXPECT_EQ(rfh, main_test_rfh());
150 EXPECT_TRUE(main_test_rfh()->IsRenderFrameLive()); 223 EXPECT_TRUE(main_test_rfh()->IsRenderFrameLive());
151 EXPECT_TRUE(main_test_rfh()->render_view_host()->IsRenderViewLive()); 224 EXPECT_TRUE(main_test_rfh()->render_view_host()->IsRenderViewLive());
152 } 225 }
153 226
154 // PlzNavigate: Test that commiting an HTTP 204 or HTTP 205 response cancels the 227 // PlzNavigate: Test that committing an HTTP 204 or HTTP 205 response cancels
155 // navigation. 228 // the navigation.
156 TEST_F(NavigatorTestWithBrowserSideNavigation, NoContent) { 229 TEST_F(NavigatorTestWithBrowserSideNavigation, NoContent) {
157 const GURL kUrl1("http://www.chromium.org/"); 230 const GURL kUrl1("http://www.chromium.org/");
158 const GURL kUrl2("http://www.google.com/"); 231 const GURL kUrl2("http://www.google.com/");
159 232
160 // Load a URL. 233 // Load a URL.
161 contents()->NavigateAndCommit(kUrl1); 234 contents()->NavigateAndCommit(kUrl1);
162 RenderFrameHostImpl* rfh = main_test_rfh();
163 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, rfh->rfh_state());
164 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 235 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
165 236
166 // Navigate to a different site. 237 // Navigate to a different site.
238 process()->sink().ClearMessages();
167 SendRequestNavigation(node, kUrl2); 239 SendRequestNavigation(node, kUrl2);
168 main_test_rfh()->SendBeginNavigationWithURL(kUrl2); 240 main_test_rfh()->SendBeginNavigationWithURL(kUrl2);
241
169 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node); 242 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node);
170 ASSERT_TRUE(main_request); 243 ASSERT_TRUE(main_request);
171 244
245 // Navigations to a different site do create a speculative RenderFrameHost.
246 EXPECT_TRUE(GetSpeculativeRenderFrameHost(node));
247
172 // Commit an HTTP 204 response. 248 // Commit an HTTP 204 response.
173 scoped_refptr<ResourceResponse> response(new ResourceResponse); 249 scoped_refptr<ResourceResponse> response(new ResourceResponse);
174 const char kNoContentHeaders[] = "HTTP/1.1 204 No Content\0\0"; 250 const char kNoContentHeaders[] = "HTTP/1.1 204 No Content\0\0";
175 response->head.headers = new net::HttpResponseHeaders( 251 response->head.headers = new net::HttpResponseHeaders(
176 std::string(kNoContentHeaders, arraysize(kNoContentHeaders))); 252 std::string(kNoContentHeaders, arraysize(kNoContentHeaders)));
177 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted( 253 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted(
178 response, MakeEmptyStream()); 254 response, MakeEmptyStream());
179 255
180 // There should be no pending RenderFrameHost; the navigation was aborted. 256 // There should be no pending nor speculative RenderFrameHost; the navigation
257 // was aborted.
258 EXPECT_FALSE(DidRenderFrameHostCommit(main_test_rfh()));
181 EXPECT_FALSE(GetNavigationRequestForFrameTreeNode(node)); 259 EXPECT_FALSE(GetNavigationRequestForFrameTreeNode(node));
182 EXPECT_FALSE(node->render_manager()->pending_frame_host()); 260 EXPECT_FALSE(node->render_manager()->pending_frame_host());
261 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
183 262
184 // Now, repeat the test with 205 Reset Content. 263 // Now, repeat the test with 205 Reset Content.
185 264
186 // Navigate to a different site again. 265 // Navigate to a different site again.
266 process()->sink().ClearMessages();
187 SendRequestNavigation(node, kUrl2); 267 SendRequestNavigation(node, kUrl2);
188 main_test_rfh()->SendBeginNavigationWithURL(kUrl2); 268 main_test_rfh()->SendBeginNavigationWithURL(kUrl2);
269
189 main_request = GetNavigationRequestForFrameTreeNode(node); 270 main_request = GetNavigationRequestForFrameTreeNode(node);
190 ASSERT_TRUE(main_request); 271 ASSERT_TRUE(main_request);
272 EXPECT_TRUE(GetSpeculativeRenderFrameHost(node));
191 273
192 // Commit an HTTP 205 response. 274 // Commit an HTTP 205 response.
193 response = new ResourceResponse; 275 response = new ResourceResponse;
194 const char kResetContentHeaders[] = "HTTP/1.1 205 Reset Content\0\0"; 276 const char kResetContentHeaders[] = "HTTP/1.1 205 Reset Content\0\0";
195 response->head.headers = new net::HttpResponseHeaders( 277 response->head.headers = new net::HttpResponseHeaders(
196 std::string(kResetContentHeaders, arraysize(kResetContentHeaders))); 278 std::string(kResetContentHeaders, arraysize(kResetContentHeaders)));
197 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted( 279 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted(
198 response, MakeEmptyStream()); 280 response, MakeEmptyStream());
199 281
200 // There should be no pending RenderFrameHost; the navigation was aborted. 282 // There should be no pending nor speculative RenderFrameHost; the navigation
283 // was aborted.
284 EXPECT_FALSE(DidRenderFrameHostCommit(main_test_rfh()));
201 EXPECT_FALSE(GetNavigationRequestForFrameTreeNode(node)); 285 EXPECT_FALSE(GetNavigationRequestForFrameTreeNode(node));
202 EXPECT_FALSE(node->render_manager()->pending_frame_host()); 286 EXPECT_FALSE(node->render_manager()->pending_frame_host());
287 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
203 } 288 }
204 289
205 // PlzNavigate: Test that a new RenderFrameHost is created when doing a cross 290 // PlzNavigate: Test that a new RenderFrameHost is created when doing a cross
206 // site navigation. 291 // site navigation.
207 TEST_F(NavigatorTestWithBrowserSideNavigation, CrossSiteNavigation) { 292 TEST_F(NavigatorTestWithBrowserSideNavigation, CrossSiteNavigation) {
208 const GURL kUrl1("http://www.chromium.org/"); 293 const GURL kUrl1("http://www.chromium.org/");
209 const GURL kUrl2("http://www.google.com/"); 294 const GURL kUrl2("http://www.google.com/");
210 295
211 contents()->NavigateAndCommit(kUrl1); 296 contents()->NavigateAndCommit(kUrl1);
212 RenderFrameHostImpl* rfh = main_test_rfh(); 297 RenderFrameHostImpl* initial_rfh = main_test_rfh();
213 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, rfh->rfh_state());
214 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 298 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
215 299
216 // Navigate to a different site. 300 // Navigate to a different site.
301 process()->sink().ClearMessages();
217 SendRequestNavigation(node, kUrl2); 302 SendRequestNavigation(node, kUrl2);
218 main_test_rfh()->SendBeginNavigationWithURL(kUrl2); 303 main_test_rfh()->SendBeginNavigationWithURL(kUrl2);
219 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node); 304 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node);
220 ASSERT_TRUE(main_request); 305 ASSERT_TRUE(main_request);
306 EXPECT_TRUE(GetSpeculativeRenderFrameHost(node));
221 307
222 scoped_refptr<ResourceResponse> response(new ResourceResponse); 308 scoped_refptr<ResourceResponse> response(new ResourceResponse);
223 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted( 309 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted(
224 response, MakeEmptyStream()); 310 response, MakeEmptyStream());
225 RenderFrameHostImpl* pending_rfh = 311 TestRenderFrameHost* speculative_rfh = GetSpeculativeRenderFrameHost(node);
226 node->render_manager()->pending_frame_host(); 312 ASSERT_TRUE(speculative_rfh);
227 ASSERT_TRUE(pending_rfh); 313 EXPECT_TRUE(DidRenderFrameHostCommit(speculative_rfh));
228 EXPECT_NE(pending_rfh, rfh); 314 EXPECT_FALSE(DidRenderFrameHostCommit(main_test_rfh()));
Charlie Reis 2015/01/12 23:30:52 This is very confusing for those of us familiar wi
carlosk 2015/01/13 15:54:12 Agreed and done. I was confused because the metho
229 EXPECT_TRUE(pending_rfh->IsRenderFrameLive()); 315
230 EXPECT_TRUE(pending_rfh->render_view_host()->IsRenderViewLive()); 316 speculative_rfh->SendNavigate(0, kUrl2);
317
318 RenderFrameHostImpl* final_rfh = main_test_rfh();
319 EXPECT_EQ(speculative_rfh, final_rfh);
320 EXPECT_NE(initial_rfh, final_rfh);
321 EXPECT_TRUE(final_rfh->IsRenderFrameLive());
322 EXPECT_TRUE(final_rfh->render_view_host()->IsRenderViewLive());
323 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
231 } 324 }
232 325
233 // PlzNavigate: Test that redirects are followed. 326 // PlzNavigate: Test that redirects are followed and the speculative renderer
327 // logic behaves as expected.
234 TEST_F(NavigatorTestWithBrowserSideNavigation, RedirectCrossSite) { 328 TEST_F(NavigatorTestWithBrowserSideNavigation, RedirectCrossSite) {
235 const GURL kUrl1("http://www.chromium.org/"); 329 const GURL kUrl1("http://www.chromium.org/");
236 const GURL kUrl2("http://www.google.com/"); 330 const GURL kUrl2("http://www.google.com/");
237 331
238 contents()->NavigateAndCommit(kUrl1); 332 contents()->NavigateAndCommit(kUrl1);
239 RenderFrameHostImpl* rfh = main_test_rfh(); 333 RenderFrameHostImpl* rfh = main_test_rfh();
240 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, rfh->rfh_state());
241 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 334 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
242 335
243 // Navigate to a URL on the same site. 336 // Navigate to a URL on the same site.
337 process()->sink().ClearMessages();
244 SendRequestNavigation(node, kUrl1); 338 SendRequestNavigation(node, kUrl1);
245 main_test_rfh()->SendBeginNavigationWithURL(kUrl1); 339 main_test_rfh()->SendBeginNavigationWithURL(kUrl1);
246 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node); 340 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node);
247 ASSERT_TRUE(main_request); 341 ASSERT_TRUE(main_request);
342 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
248 343
249 // It then redirects to another site. 344 // It then redirects to another site.
250 net::RedirectInfo redirect_info; 345 net::RedirectInfo redirect_info;
251 redirect_info.status_code = 302; 346 redirect_info.status_code = 302;
252 redirect_info.new_method = "GET"; 347 redirect_info.new_method = "GET";
253 redirect_info.new_url = kUrl2; 348 redirect_info.new_url = kUrl2;
254 redirect_info.new_first_party_for_cookies = kUrl2; 349 redirect_info.new_first_party_for_cookies = kUrl2;
255 scoped_refptr<ResourceResponse> response(new ResourceResponse); 350 scoped_refptr<ResourceResponse> response(new ResourceResponse);
256 GetLoaderForNavigationRequest(main_request)->CallOnRequestRedirected( 351 GetLoaderForNavigationRequest(main_request)->CallOnRequestRedirected(
257 redirect_info, response); 352 redirect_info, response);
258 353
259 // The redirect should have been followed. 354 // The redirect should have been followed.
260 EXPECT_EQ(1, GetLoaderForNavigationRequest(main_request)->redirect_count()); 355 EXPECT_EQ(1, GetLoaderForNavigationRequest(main_request)->redirect_count());
356 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
261 357
262 // Then it commits. 358 // Then it commits.
Charlie Reis 2015/01/12 23:30:52 This adds to my confusion. The navigation has not
carlosk 2015/01/13 15:54:12 Changed to: Request the RenderFrameHost to commit.
263 response = new ResourceResponse; 359 response = new ResourceResponse;
264 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted( 360 GetLoaderForNavigationRequest(main_request)->CallOnResponseStarted(
265 response, MakeEmptyStream()); 361 response, MakeEmptyStream());
266 RenderFrameHostImpl* pending_rfh = 362 TestRenderFrameHost* final_speculative_rfh =
267 node->render_manager()->pending_frame_host(); 363 GetSpeculativeRenderFrameHost(node);
268 ASSERT_TRUE(pending_rfh); 364 EXPECT_TRUE(final_speculative_rfh);
269 EXPECT_NE(pending_rfh, rfh); 365 EXPECT_TRUE(DidRenderFrameHostCommit(final_speculative_rfh));
270 EXPECT_TRUE(pending_rfh->IsRenderFrameLive()); 366
271 EXPECT_TRUE(pending_rfh->render_view_host()->IsRenderViewLive()); 367 // And commits provisional load.
368 final_speculative_rfh->SendNavigate(0, kUrl2);
369 RenderFrameHostImpl* final_rfh = main_test_rfh();
370 ASSERT_TRUE(final_rfh);
371 EXPECT_NE(rfh, final_rfh);
372 EXPECT_EQ(final_speculative_rfh, final_rfh);
373 EXPECT_TRUE(final_rfh->IsRenderFrameLive());
374 EXPECT_TRUE(final_rfh->render_view_host()->IsRenderViewLive());
375 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
272 } 376 }
273 377
274 // PlzNavigate: Test that a navigation is cancelled if another request has been 378 // PlzNavigate: Test that a navigation is canceled if another request has been
275 // issued in the meantime. 379 // issued in the meantime. Also confirms that the speculative renderer is
380 // correctly updated in the process.
276 TEST_F(NavigatorTestWithBrowserSideNavigation, ReplacePendingNavigation) { 381 TEST_F(NavigatorTestWithBrowserSideNavigation, ReplacePendingNavigation) {
277 const GURL kUrl0("http://www.wikipedia.org/"); 382 const GURL kUrl0("http://www.wikipedia.org/");
278 const GURL kUrl0_site = SiteInstance::GetSiteForURL(browser_context(), kUrl0);
279 const GURL kUrl1("http://www.chromium.org/"); 383 const GURL kUrl1("http://www.chromium.org/");
384 const GURL kUrl1_site = SiteInstance::GetSiteForURL(browser_context(), kUrl1);
280 const GURL kUrl2("http://www.google.com/"); 385 const GURL kUrl2("http://www.google.com/");
281 const GURL kUrl2_site = SiteInstance::GetSiteForURL(browser_context(), kUrl2); 386 const GURL kUrl2_site = SiteInstance::GetSiteForURL(browser_context(), kUrl2);
282 387
283 // Initialization. 388 // Initialization.
284 contents()->NavigateAndCommit(kUrl0); 389 contents()->NavigateAndCommit(kUrl0);
285 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 390 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
286 EXPECT_EQ(kUrl0_site, main_test_rfh()->GetSiteInstance()->GetSiteURL());
287 391
288 // Request navigation to the 1st URL. 392 // Request navigation to the 1st URL.
393 process()->sink().ClearMessages();
289 SendRequestNavigation(node, kUrl1); 394 SendRequestNavigation(node, kUrl1);
290 main_test_rfh()->SendBeginNavigationWithURL(kUrl1); 395 main_test_rfh()->SendBeginNavigationWithURL(kUrl1);
291 NavigationRequest* request1 = GetNavigationRequestForFrameTreeNode(node); 396 NavigationRequest* request1 = GetNavigationRequestForFrameTreeNode(node);
292 ASSERT_TRUE(request1); 397 ASSERT_TRUE(request1);
293 EXPECT_EQ(kUrl1, request1->common_params().url); 398 EXPECT_EQ(kUrl1, request1->common_params().url);
294 base::WeakPtr<TestNavigationURLLoader> loader1 = 399 base::WeakPtr<TestNavigationURLLoader> loader1 =
295 GetLoaderForNavigationRequest(request1)->AsWeakPtr(); 400 GetLoaderForNavigationRequest(request1)->AsWeakPtr();
296 401
402 // Confirm a speculative RFH was created.
403 TestRenderFrameHost* speculative_rfh = GetSpeculativeRenderFrameHost(node);
404 ASSERT_TRUE(speculative_rfh);
405 int32 site_instance_id_1 = speculative_rfh->GetSiteInstance()->GetId();
406 EXPECT_EQ(kUrl1_site, speculative_rfh->GetSiteInstance()->GetSiteURL());
407
297 // Request navigation to the 2nd URL; the NavigationRequest must have been 408 // Request navigation to the 2nd URL; the NavigationRequest must have been
298 // replaced by a new one with a different URL. 409 // replaced by a new one with a different URL.
299 SendRequestNavigation(node, kUrl2); 410 SendRequestNavigation(node, kUrl2);
300 main_test_rfh()->SendBeginNavigationWithURL(kUrl2); 411 main_test_rfh()->SendBeginNavigationWithURL(kUrl2);
301 NavigationRequest* request2 = GetNavigationRequestForFrameTreeNode(node); 412 NavigationRequest* request2 = GetNavigationRequestForFrameTreeNode(node);
302 ASSERT_TRUE(request2); 413 ASSERT_TRUE(request2);
303 EXPECT_EQ(kUrl2, request2->common_params().url); 414 EXPECT_EQ(kUrl2, request2->common_params().url);
304 415
305 // Confirm that the first loader got destroyed. 416 // Confirm that the first loader got destroyed.
306 EXPECT_FALSE(loader1); 417 EXPECT_FALSE(loader1);
307 418
308 // Confirm that the commit corresponds to the new request. 419 // Confirm that a new speculative RFH was created.
420 speculative_rfh = GetSpeculativeRenderFrameHost(node);
421 ASSERT_TRUE(speculative_rfh);
422 int32 site_instance_id_2 = speculative_rfh->GetSiteInstance()->GetId();
423 EXPECT_NE(site_instance_id_1, site_instance_id_2);
424
425 // Commit.
309 scoped_refptr<ResourceResponse> response(new ResourceResponse); 426 scoped_refptr<ResourceResponse> response(new ResourceResponse);
310 GetLoaderForNavigationRequest(request2)->CallOnResponseStarted( 427 GetLoaderForNavigationRequest(request2)->CallOnResponseStarted(
311 response, MakeEmptyStream()); 428 response, MakeEmptyStream());
312 RenderFrameHostImpl* pending_rfh = 429 EXPECT_TRUE(DidRenderFrameHostCommit(speculative_rfh));
313 node->render_manager()->pending_frame_host(); 430 EXPECT_FALSE(DidRenderFrameHostCommit(main_test_rfh()));
314 ASSERT_TRUE(pending_rfh); 431
315 EXPECT_EQ(kUrl2_site, pending_rfh->GetSiteInstance()->GetSiteURL()); 432 // And commit provisional load.
433 speculative_rfh->SendNavigate(0, kUrl2);
434
435 // Confirm that the commit corresponds to the new request.
436 ASSERT_TRUE(main_test_rfh());
437 EXPECT_EQ(kUrl2_site, main_test_rfh()->GetSiteInstance()->GetSiteURL());
438
439 // Confirm that the committed RFH is the new speculative one.
440 EXPECT_EQ(site_instance_id_2, main_test_rfh()->GetSiteInstance()->GetId());
316 } 441 }
317 442
318 // PlzNavigate: Test that a reload navigation is properly signaled to the 443 // PlzNavigate: Test that a reload navigation is properly signaled to the
319 // renderer when the navigation can commit. 444 // renderer when the navigation can commit. Speculative renderers should not be
445 // created at any step.
320 TEST_F(NavigatorTestWithBrowserSideNavigation, Reload) { 446 TEST_F(NavigatorTestWithBrowserSideNavigation, Reload) {
321 const GURL kUrl("http://www.google.com/"); 447 const GURL kUrl("http://www.google.com/");
322 contents()->NavigateAndCommit(kUrl); 448 contents()->NavigateAndCommit(kUrl);
323 449
324 FrameTreeNode* node = main_test_rfh()->frame_tree_node(); 450 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
325 SendRequestNavigationWithParameters( 451 SendRequestNavigationWithParameters(
326 node, kUrl, Referrer(), ui::PAGE_TRANSITION_LINK, 452 node, kUrl, Referrer(), ui::PAGE_TRANSITION_LINK,
327 NavigationController::RELOAD); 453 NavigationController::RELOAD);
328 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl); 454 main_test_rfh()->SendBeginNavigationWithURL(kUrl);
329 // A NavigationRequest should have been generated. 455 // A NavigationRequest should have been generated.
330 NavigationRequest* main_request = 456 NavigationRequest* main_request =
331 GetNavigationRequestForFrameTreeNode(node); 457 GetNavigationRequestForFrameTreeNode(node);
332 ASSERT_TRUE(main_request != NULL); 458 ASSERT_TRUE(main_request != NULL);
333 EXPECT_EQ(FrameMsg_Navigate_Type::RELOAD, 459 EXPECT_EQ(FrameMsg_Navigate_Type::RELOAD,
334 main_request->common_params().navigation_type); 460 main_request->common_params().navigation_type);
335 int page_id = contents()->GetMaxPageIDForSiteInstance( 461 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
336 main_test_rfh()->GetSiteInstance()) + 1; 462
337 main_test_rfh()->SendNavigate(page_id, kUrl); 463 main_test_rfh()->SendNavigate(0, kUrl);
464 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
338 465
339 // Now do a shift+reload. 466 // Now do a shift+reload.
340 SendRequestNavigationWithParameters( 467 SendRequestNavigationWithParameters(
341 node, kUrl, Referrer(), ui::PAGE_TRANSITION_LINK, 468 node, kUrl, Referrer(), ui::PAGE_TRANSITION_LINK,
342 NavigationController::RELOAD_IGNORING_CACHE); 469 NavigationController::RELOAD_IGNORING_CACHE);
343 contents()->GetMainFrame()->SendBeginNavigationWithURL(kUrl); 470 main_test_rfh()->SendBeginNavigationWithURL(kUrl);
344 // A NavigationRequest should have been generated. 471 // A NavigationRequest should have been generated.
345 main_request = GetNavigationRequestForFrameTreeNode(node); 472 main_request = GetNavigationRequestForFrameTreeNode(node);
346 ASSERT_TRUE(main_request != NULL); 473 ASSERT_TRUE(main_request != NULL);
347 EXPECT_EQ(FrameMsg_Navigate_Type::RELOAD_IGNORING_CACHE, 474 EXPECT_EQ(FrameMsg_Navigate_Type::RELOAD_IGNORING_CACHE,
348 main_request->common_params().navigation_type); 475 main_request->common_params().navigation_type);
476 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
477 }
478
479 // PlzNavigate: Confirm that a speculative RenderFrameHost is used when
480 // navigating from one site to the another.
Charlie Reis 2015/01/12 23:30:52 nit: Drop "the"
carlosk 2015/01/13 15:54:12 Done.
481 TEST_F(NavigatorTestWithBrowserSideNavigation,
482 SpeculativeRendererWorksBaseCase) {
483 // Navigate to an initial site.
484 const GURL kUrlInit("http://wikipedia.org/");
485 contents()->NavigateAndCommit(kUrlInit);
486 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
487
488 // Begin navigating to another site.
489 const GURL kUrl("http://google.com/");
490 process()->sink().ClearMessages();
491 SendRequestNavigation(node, kUrl);
492 main_test_rfh()->SendBeginNavigationWithURL(kUrl);
493 TestRenderFrameHost* speculative_rfh = GetSpeculativeRenderFrameHost(node);
494 ASSERT_TRUE(speculative_rfh);
495 EXPECT_NE(speculative_rfh, main_test_rfh());
496 EXPECT_EQ(SiteInstanceImpl::GetSiteForURL(browser_context(), kUrl),
497 speculative_rfh->GetSiteInstance()->GetSiteURL());
498 EXPECT_FALSE(node->render_manager()->pending_frame_host());
499 int32 site_instance_id = speculative_rfh->GetSiteInstance()->GetId();
500
501 // Ask Navigator to commit the navigation by simulating a call to
502 // OnResponseStarted.
503 scoped_refptr<ResourceResponse> response(new ResourceResponse);
504 GetLoaderForNavigationRequest(GetNavigationRequestForFrameTreeNode(node))
505 ->CallOnResponseStarted(response, MakeEmptyStream());
506 speculative_rfh = GetSpeculativeRenderFrameHost(node);
507 ASSERT_TRUE(speculative_rfh);
508 EXPECT_TRUE(DidRenderFrameHostCommit(speculative_rfh));
509 EXPECT_EQ(site_instance_id, speculative_rfh->GetSiteInstance()->GetId());
510 EXPECT_FALSE(node->render_manager()->pending_frame_host());
511
512 // Invoke OnDidCommitProvisionalLoad.
513 speculative_rfh->SendNavigate(0, kUrl);
514 EXPECT_EQ(site_instance_id, main_test_rfh()->GetSiteInstance()->GetId());
515 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
516 EXPECT_FALSE(node->render_manager()->pending_frame_host());
517 }
518
519 // PlzNavigate: Confirm that a speculative RenderFrameHost is thrown away when
520 // the final URL's site differs from the initial one due to redirects.
521 TEST_F(NavigatorTestWithBrowserSideNavigation,
522 SpeculativeRendererDiscardedAfterRedirectToAnotherSite) {
523 // Navigate to an initial site.
524 const GURL kUrlInit("http://wikipedia.org/");
525 contents()->NavigateAndCommit(kUrlInit);
526 FrameTreeNode* node = main_test_rfh()->frame_tree_node();
527 int32 init_site_instance_id = main_test_rfh()->GetSiteInstance()->GetId();
528
529 // Begin navigating to another site.
530 const GURL kUrl("http://google.com/");
531 process()->sink().ClearMessages();
532 SendRequestNavigation(node, kUrl);
533 main_test_rfh()->SendBeginNavigationWithURL(kUrl);
534 TestRenderFrameHost* speculative_rfh = GetSpeculativeRenderFrameHost(node);
535 int32 site_instance_id = speculative_rfh->GetSiteInstance()->GetId();
536 EXPECT_EQ(init_site_instance_id, main_test_rfh()->GetSiteInstance()->GetId());
Charlie Reis 2015/01/12 23:30:52 Please verify that init_site_instance_id and site_
carlosk 2015/01/13 15:54:12 Done. Good one. Also added a couple of these belo
537 ASSERT_TRUE(speculative_rfh);
538 EXPECT_NE(speculative_rfh, main_test_rfh());
539 EXPECT_EQ(SiteInstanceImpl::GetSiteForURL(browser_context(), kUrl),
540 speculative_rfh->GetSiteInstance()->GetSiteURL());
541
542 // It then redirects to yet another site.
543 NavigationRequest* main_request = GetNavigationRequestForFrameTreeNode(node);
544 ASSERT_TRUE(main_request);
545 const GURL kUrlRedirect("https://www.google.com/");
546 net::RedirectInfo redirect_info;
547 redirect_info.status_code = 302;
548 redirect_info.new_method = "GET";
549 redirect_info.new_url = kUrlRedirect;
550 redirect_info.new_first_party_for_cookies = kUrlRedirect;
551 scoped_refptr<ResourceResponse> response(new ResourceResponse);
552 GetLoaderForNavigationRequest(main_request)
553 ->CallOnRequestRedirected(redirect_info, response);
554 EXPECT_EQ(init_site_instance_id, main_test_rfh()->GetSiteInstance()->GetId());
555 speculative_rfh = GetSpeculativeRenderFrameHost(node);
556 ASSERT_TRUE(speculative_rfh);
557
558 // TODO(carlosk): once the speculative RenderFrameHost updates with redirects
Charlie Reis 2015/01/12 23:30:52 I agree with the TODO, but it's hard to follow wha
carlosk 2015/01/13 15:54:12 Done.
559 // this next check will be changed to verify that it actually happens.
560 EXPECT_EQ(site_instance_id, speculative_rfh->GetSiteInstance()->GetId());
561
562 // Commit the navigation with Navigator by simulating the call to
563 // OnResponseStarted.
564 response = new ResourceResponse;
565 GetLoaderForNavigationRequest(main_request)
566 ->CallOnResponseStarted(response, MakeEmptyStream());
567 speculative_rfh = GetSpeculativeRenderFrameHost(node);
568 EXPECT_TRUE(DidRenderFrameHostCommit(speculative_rfh));
569 EXPECT_EQ(init_site_instance_id, main_test_rfh()->GetSiteInstance()->GetId());
570
571 // Once commit happens the speculative RenderFrameHost is already updated to
Charlie Reis 2015/01/12 23:30:52 Drop "already," since this seems to be the point i
carlosk 2015/01/13 15:54:12 Done.
572 // match the known final SiteInstance.
573 ASSERT_TRUE(speculative_rfh);
574 EXPECT_EQ(SiteInstanceImpl::GetSiteForURL(browser_context(), kUrlRedirect),
575 speculative_rfh->GetSiteInstance()->GetSiteURL());
576 int32 redirect_site_instance_id = speculative_rfh->GetSiteInstance()->GetId();
577
578 // Invoke OnDidCommitProvisionalLoad.
579 speculative_rfh->SendNavigate(0, kUrlRedirect);
580
581 // Check that the speculative RenderFrameHost was swapped in.
582 EXPECT_EQ(redirect_site_instance_id,
583 main_test_rfh()->GetSiteInstance()->GetId());
584 EXPECT_FALSE(GetSpeculativeRenderFrameHost(node));
585 }
586
587 // PlzNavigate: Verify that a previously swapped out RenderFrameHost is
588 // correctly reused when spawning a speculative RenderFrameHost in a navigation
589 // using the same SiteInstance.
590 TEST_F(NavigatorTestWithBrowserSideNavigation,
591 SpeculativeRendererReuseSwappedOutRFH) {
592 // Navigate to an initial site.
593 const GURL kUrl1("http://wikipedia.org/");
594 contents()->NavigateAndCommit(kUrl1);
595 TestRenderFrameHost* rfh1 = main_test_rfh();
596 FrameTreeNode* node = rfh1->frame_tree_node();
597 RenderFrameHostManager* rfhm = node->render_manager();
598
599 // Increment active frame count to cause the RenderFrameHost to be swapped out
600 // (instead of immediately destroyed).
601 rfh1->GetSiteInstance()->increment_active_frame_count();
602
603 // Navigate to another site to swap out the initial RenderFrameHost.
604 const GURL kUrl2("http://chromium.org/");
605 contents()->NavigateAndCommit(kUrl2);
606 ASSERT_NE(rfh1, main_test_rfh());
607 EXPECT_NE(RenderFrameHostImpl::STATE_DEFAULT, rfh1->rfh_state());
608 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, main_test_rfh()->rfh_state());
609 EXPECT_TRUE(rfhm->IsOnSwappedOutList(rfh1));
610
611 // Now go back to the initial site so that the swapped out RenderFrameHost
612 // should be reused.
613 process()->sink().ClearMessages();
614 static_cast<MockRenderProcessHost*>(rfh1->GetProcess())
615 ->sink()
616 .ClearMessages();
617 SendRequestNavigation(node, kUrl1);
618 main_test_rfh()->SendBeginNavigationWithURL(kUrl1);
619 EXPECT_EQ(rfh1, GetSpeculativeRenderFrameHost(node));
620 EXPECT_NE(RenderFrameHostImpl::STATE_DEFAULT,
621 GetSpeculativeRenderFrameHost(node)->rfh_state());
622
623 scoped_refptr<ResourceResponse> response(new ResourceResponse);
624 GetLoaderForNavigationRequest(GetNavigationRequestForFrameTreeNode(node))
625 ->CallOnResponseStarted(response, MakeEmptyStream());
626 EXPECT_EQ(rfh1, GetSpeculativeRenderFrameHost(node));
627 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT,
628 GetSpeculativeRenderFrameHost(node)->rfh_state());
629 EXPECT_TRUE(DidRenderFrameHostCommit(rfh1));
630 EXPECT_FALSE(DidRenderFrameHostCommit(main_test_rfh()));
631
632 rfh1->SendNavigate(1, kUrl1);
633 EXPECT_EQ(rfh1, main_test_rfh());
634 EXPECT_EQ(RenderFrameHostImpl::STATE_DEFAULT, rfh1->rfh_state());
635 EXPECT_FALSE(rfhm->IsOnSwappedOutList(rfh1));
349 } 636 }
350 637
351 } // namespace content 638 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698