| Index: content/renderer/render_view_browsertest.cc | 
| diff --git a/content/renderer/render_view_browsertest.cc b/content/renderer/render_view_browsertest.cc | 
| index 31e6b1f8c3372de5b3f0b9e112b800707e477088..7cebe1ca0e42d6db3952be7c2c18eef4a52ff42c 100644 | 
| --- a/content/renderer/render_view_browsertest.cc | 
| +++ b/content/renderer/render_view_browsertest.cc | 
| @@ -20,6 +20,7 @@ | 
| #include "content/child/request_extra_data.h" | 
| #include "content/child/service_worker/service_worker_network_provider.h" | 
| #include "content/common/frame_messages.h" | 
| +#include "content/common/frame_replication_state.h" | 
| #include "content/common/site_isolation_policy.h" | 
| #include "content/common/ssl_status_serialization.h" | 
| #include "content/common/view_messages.h" | 
| @@ -154,6 +155,31 @@ bool TimeTicksGT(const base::TimeTicks& x, const base::TimeTicks& y) { | 
| return base::TimeTicks::IsHighResolution() ? x > y : x >= y; | 
| } | 
|  | 
| +// FrameReplicationState is normally maintained in the browser process, | 
| +// but the function below provides a way for tests to construct a partial | 
| +// FrameReplicationState within the renderer process.  We say "partial", | 
| +// because some fields of FrameReplicationState cannot be filled out | 
| +// by content-layer, renderer code (still the constructed, partial | 
| +// FrameReplicationState is sufficiently complete to avoid trigerring | 
| +// asserts that a default/empty FrameReplicationState would). | 
| +FrameReplicationState ReconstructReplicationStateForTesting( | 
| +    TestRenderFrame* test_render_frame) { | 
| +  blink::WebLocalFrame* frame = test_render_frame->GetWebFrame(); | 
| + | 
| +  FrameReplicationState result; | 
| +  // can't recover result.scope - no way to get WebTreeScopeType via public | 
| +  // blink API... | 
| +  result.name = base::UTF16ToUTF8(base::StringPiece16(frame->assignedName())); | 
| +  result.unique_name = | 
| +      base::UTF16ToUTF8(base::StringPiece16(frame->uniqueName())); | 
| +  result.sandbox_flags = frame->effectiveSandboxFlags(); | 
| +  // result.should_enforce_strict_mixed_content_checking is calculated in the | 
| +  // browser... | 
| +  result.origin = frame->securityOrigin(); | 
| + | 
| +  return result; | 
| +} | 
| + | 
| }  // namespace | 
|  | 
| class RenderViewImplTest : public RenderViewTest { | 
| @@ -722,7 +748,8 @@ TEST_F(RenderViewImplTest, SendSwapOutACK) { | 
| RenderProcess::current()->AddRefProcess(); | 
|  | 
| // Respond to a swap out request. | 
| -  frame()->SwapOut(kProxyRoutingId, true, content::FrameReplicationState()); | 
| +  frame()->SwapOut(kProxyRoutingId, true, | 
| +                   ReconstructReplicationStateForTesting(frame())); | 
|  | 
| // Ensure the swap out commits synchronously. | 
| EXPECT_NE(initial_page_id, view_page_id()); | 
| @@ -735,7 +762,8 @@ TEST_F(RenderViewImplTest, SendSwapOutACK) { | 
| // It is possible to get another swap out request.  Ensure that we send | 
| // an ACK, even if we don't have to do anything else. | 
| render_thread_->sink().ClearMessages(); | 
| -  frame()->SwapOut(kProxyRoutingId, false, content::FrameReplicationState()); | 
| +  frame()->SwapOut(kProxyRoutingId, false, | 
| +                   ReconstructReplicationStateForTesting(frame())); | 
| const IPC::Message* msg2 = render_thread_->sink().GetUniqueMessageMatching( | 
| FrameHostMsg_SwapOut_ACK::ID); | 
| ASSERT_TRUE(msg2); | 
| @@ -803,7 +831,8 @@ TEST_F(RenderViewImplTest, ReloadWhileSwappedOut) { | 
| ProcessPendingMessages(); | 
|  | 
| // Respond to a swap out request. | 
| -  frame()->SwapOut(kProxyRoutingId, true, content::FrameReplicationState()); | 
| +  frame()->SwapOut(kProxyRoutingId, true, | 
| +                   ReconstructReplicationStateForTesting(frame())); | 
|  | 
| // Check for a OnSwapOutACK. | 
| const IPC::Message* msg = render_thread_->sink().GetUniqueMessageMatching( | 
| @@ -859,7 +888,8 @@ TEST_F(RenderViewImplTest, OriginReplicationForSwapOut) { | 
|  | 
| // Swap the child frame out and pass a replicated origin to be set for | 
| // WebRemoteFrame. | 
| -  content::FrameReplicationState replication_state; | 
| +  content::FrameReplicationState replication_state = | 
| +      ReconstructReplicationStateForTesting(child_frame); | 
| replication_state.origin = url::Origin(GURL("http://foo.com")); | 
| child_frame->SwapOut(kProxyRoutingId, true, replication_state); | 
|  | 
| @@ -897,7 +927,9 @@ TEST_F(RenderViewImplTest, NavigateProxyAndDetachBeforeOnNavigate) { | 
| RenderFrame::FromWebFrame(web_frame->firstChild())); | 
|  | 
| // Swap the child frame out. | 
| -  child_frame->SwapOut(kProxyRoutingId, true, content::FrameReplicationState()); | 
| +  FrameReplicationState replication_state = | 
| +      ReconstructReplicationStateForTesting(child_frame); | 
| +  child_frame->SwapOut(kProxyRoutingId, true, replication_state); | 
| EXPECT_TRUE(web_frame->firstChild()->isWebRemoteFrame()); | 
|  | 
| // Do the first step of a remote-to-local transition for the child proxy, | 
| @@ -908,8 +940,8 @@ TEST_F(RenderViewImplTest, NavigateProxyAndDetachBeforeOnNavigate) { | 
| widget_params.hidden = false; | 
| RenderFrameImpl::CreateFrame(routing_id, kProxyRoutingId, MSG_ROUTING_NONE, | 
| frame()->GetRoutingID(), MSG_ROUTING_NONE, | 
| -                               content::FrameReplicationState(), nullptr, | 
| -                               widget_params, blink::WebFrameOwnerProperties()); | 
| +                               replication_state, nullptr, widget_params, | 
| +                               blink::WebFrameOwnerProperties()); | 
| TestRenderFrame* provisional_frame = | 
| static_cast<TestRenderFrame*>(RenderFrameImpl::FromRoutingID(routing_id)); | 
| EXPECT_TRUE(provisional_frame); | 
| @@ -956,8 +988,9 @@ TEST_F(RenderViewImplTest, PaintAfterSwapOut) { | 
| // Respond to a swap out request. | 
| TestRenderFrame* new_main_frame = | 
| static_cast<TestRenderFrame*>(new_view->GetMainRenderFrame()); | 
| -  new_main_frame->SwapOut(kProxyRoutingId, true, | 
| -                          content::FrameReplicationState()); | 
| +  new_main_frame->SwapOut( | 
| +      kProxyRoutingId, true, | 
| +      ReconstructReplicationStateForTesting(new_main_frame)); | 
|  | 
| // Simulate getting painted after swapping out. | 
| new_view->DidFlushPaint(); | 
| @@ -983,7 +1016,8 @@ TEST_F(RenderViewImplTest, SetZoomLevelAfterCrossProcessNavigation) { | 
| // Swap the main frame out after which it should become a WebRemoteFrame. | 
| TestRenderFrame* main_frame = | 
| static_cast<TestRenderFrame*>(view()->GetMainRenderFrame()); | 
| -  main_frame->SwapOut(kProxyRoutingId, true, content::FrameReplicationState()); | 
| +  main_frame->SwapOut(kProxyRoutingId, true, | 
| +                      ReconstructReplicationStateForTesting(main_frame)); | 
| EXPECT_TRUE(view()->webview()->mainFrame()->isWebRemoteFrame()); | 
|  | 
| // This should not cause a crash. | 
|  |