Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 Loading... | |
| 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 |
| OLD | NEW |