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

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

Powered by Google App Engine
This is Rietveld 408576698