Chromium Code Reviews| Index: content/browser/frame_host/render_widget_host_view_guest_unittest.cc |
| diff --git a/content/browser/frame_host/render_widget_host_view_guest_unittest.cc b/content/browser/frame_host/render_widget_host_view_guest_unittest.cc |
| index 88bbfefce1a06cc1427b3b9d74831f116b227f77..1ac655e6f431cb3e346450192bd84d778b9fa2ef 100644 |
| --- a/content/browser/frame_host/render_widget_host_view_guest_unittest.cc |
| +++ b/content/browser/frame_host/render_widget_host_view_guest_unittest.cc |
| @@ -6,14 +6,23 @@ |
| #include "base/basictypes.h" |
| #include "base/message_loop/message_loop.h" |
| +#include "base/run_loop.h" |
| +#include "cc/surfaces/surface.h" |
| +#include "cc/surfaces/surface_factory.h" |
| +#include "cc/surfaces/surface_manager.h" |
| +#include "cc/surfaces/surface_sequence.h" |
| +#include "content/browser/browser_plugin/browser_plugin_guest.h" |
| #include "content/browser/compositor/test/no_transport_image_transport_factory.h" |
| +#include "content/browser/gpu/compositor_util.h" |
| #include "content/browser/renderer_host/render_widget_host_delegate.h" |
| #include "content/browser/renderer_host/render_widget_host_impl.h" |
| #include "content/common/view_messages.h" |
| +#include "content/public/browser/browser_plugin_guest_delegate.h" |
| #include "content/public/browser/render_widget_host_view.h" |
| #include "content/public/test/mock_render_process_host.h" |
| #include "content/public/test/test_browser_context.h" |
| #include "content/test/test_render_view_host.h" |
| +#include "content/test/test_web_contents.h" |
| #include "testing/gtest/include/gtest/gtest.h" |
| namespace content { |
| @@ -82,4 +91,172 @@ TEST_F(RenderWidgetHostViewGuestTest, VisibilityTest) { |
| ASSERT_FALSE(view_->IsShowing()); |
| } |
| +class TestBrowserPluginGuest : public BrowserPluginGuest { |
| + public: |
| + TestBrowserPluginGuest(WebContentsImpl* web_contents, |
| + BrowserPluginGuestDelegate* delegate): |
| + BrowserPluginGuest(web_contents->HasOpener(), web_contents, delegate), |
| + last_scale_factor_received_(0.f), |
| + update_scale_factor_received_(0.f), |
| + received_delegated_frame_(false) {} |
| + ~TestBrowserPluginGuest() override {} |
| + |
| + void UpdateGuestSizeIfNecessary(const gfx::Size& frame_size, |
| + float scale_factor) override { |
| + update_frame_size_received_= frame_size; |
| + update_scale_factor_received_ = scale_factor; |
| + } |
| + |
| + void SwapCompositorFrame(uint32 output_surface_id, |
| + int host_process_id, |
| + int host_routing_id, |
| + scoped_ptr<cc::CompositorFrame> frame) override { |
| + received_delegated_frame_ = true; |
| + last_frame_size_received_ = |
| + frame->delegated_frame_data->render_pass_list.back() |
| + ->output_rect.size(); |
| + last_scale_factor_received_ = frame->metadata.device_scale_factor; |
| + } |
| + |
| + void SetChildFrameSurface(const cc::SurfaceId& surface_id, |
| + const gfx::Size& frame_size, |
| + float scale_factor, |
| + const cc::SurfaceSequence& sequence) override { |
| + last_surface_id_received_ = surface_id; |
| + last_frame_size_received_ = frame_size; |
| + last_scale_factor_received_ = scale_factor; |
| + } |
| + |
| + cc::SurfaceId last_surface_id_received_; |
| + gfx::Size last_frame_size_received_; |
| + gfx::Size update_frame_size_received_; |
| + float last_scale_factor_received_; |
| + float update_scale_factor_received_; |
| + |
| + bool received_delegated_frame_; |
| +}; |
| + |
| +// TODO(wjmaclean): we should restructure RenderWidgetHostViewChildFrameTest to |
| +// look more like this one, and then this one could be derived from it. Also, |
| +// include CreateDelegatedFrame as part of the test class so we don't have to |
| +// repeat it here. |
| +class RenderWidgetHostViewGuestSurfaceTest |
| + : public testing::Test { |
| + public: |
| + RenderWidgetHostViewGuestSurfaceTest() |
| + : widget_host_(nullptr), view_(nullptr) {} |
| + |
| + void SetUp() override { |
| +#if !defined(OS_ANDROID) |
| + ImageTransportFactory::InitializeForUnitTests( |
| + scoped_ptr<ImageTransportFactory>( |
| + new NoTransportImageTransportFactory)); |
| +#endif |
| + browser_context_.reset(new TestBrowserContext); |
| + MockRenderProcessHost* process_host = |
| + new MockRenderProcessHost(browser_context_.get()); |
| + web_contents_.reset( |
| + TestWebContents::Create(browser_context_.get(), nullptr)); |
| + // We don't own the BPG, the WebContents does. |
| + browser_plugin_guest_ = new TestBrowserPluginGuest( |
| + web_contents_.get(), &browser_plugin_guest_delegate_); |
| + |
| + widget_host_ = new RenderWidgetHostImpl(&delegate_, process_host, |
| + MSG_ROUTING_NONE, false); |
| + view_ = new RenderWidgetHostViewGuest( |
| + widget_host_, browser_plugin_guest_, |
| + (new TestRenderWidgetHostView(widget_host_))->GetWeakPtr()); |
| + } |
| + |
| + void TearDown() override { |
| + if (view_) |
| + view_->Destroy(); |
| + delete widget_host_; |
| + |
| + base::RunLoop().RunUntilIdle(); |
|
wjmaclean
2015/06/12 21:00:35
I'm going to add a comment about why this line is
|
| +#if !defined(OS_ANDROID) |
| + ImageTransportFactory::Terminate(); |
| +#endif |
| + } |
| + |
| + cc::SurfaceId surface_id() { |
| + DCHECK(view_); |
| + return static_cast<RenderWidgetHostViewChildFrame*>(view_)->surface_id_; |
| + } |
| + |
| + protected: |
| + TestBrowserThreadBundle thread_bundle_; |
| + scoped_ptr<BrowserContext> browser_context_; |
| + MockRenderWidgetHostDelegate delegate_; |
| + BrowserPluginGuestDelegate browser_plugin_guest_delegate_; |
| + scoped_ptr<TestWebContents> web_contents_; |
| + TestBrowserPluginGuest* browser_plugin_guest_; |
| + |
| + // Tests should set these to NULL if they've already triggered their |
| + // destruction. |
| + RenderWidgetHostImpl* widget_host_; |
| + RenderWidgetHostViewGuest* view_; |
| + |
| + private: |
| + DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostViewGuestSurfaceTest); |
| +}; |
| + |
| +namespace { |
| +scoped_ptr<cc::CompositorFrame> CreateDelegatedFrame(float scale_factor, |
| + gfx::Size size, |
| + const gfx::Rect& damage) { |
| + scoped_ptr<cc::CompositorFrame> frame(new cc::CompositorFrame); |
| + frame->metadata.device_scale_factor = scale_factor; |
| + frame->delegated_frame_data.reset(new cc::DelegatedFrameData); |
| + |
| + scoped_ptr<cc::RenderPass> pass = cc::RenderPass::Create(); |
| + pass->SetNew(cc::RenderPassId(1, 1), gfx::Rect(size), damage, |
| + gfx::Transform()); |
| + frame->delegated_frame_data->render_pass_list.push_back(pass.Pass()); |
| + return frame; |
| +} |
| +} // anonymous namespace |
| + |
| +TEST_F(RenderWidgetHostViewGuestSurfaceTest, TestGuestSurface) { |
| + gfx::Size view_size(100, 100); |
| + gfx::Rect view_rect(view_size); |
| + float scale_factor = 1.f; |
| + |
| + ASSERT_TRUE(browser_plugin_guest_); |
| + |
| + view_->SetSize(view_size); |
| + view_->Show(); |
| + |
| + view_->OnSwapCompositorFrame( |
| + 0, CreateDelegatedFrame(scale_factor, view_size, view_rect)); |
| + |
| + EXPECT_EQ(view_size, browser_plugin_guest_->update_frame_size_received_); |
| + EXPECT_EQ(scale_factor, |
| + browser_plugin_guest_->update_scale_factor_received_); |
| + |
| + if (UseSurfacesEnabled()) { |
| + cc::SurfaceId id = surface_id(); |
| + if (!id.is_null()) { |
| +#if !defined(OS_ANDROID) |
| + ImageTransportFactory* factory = ImageTransportFactory::GetInstance(); |
| + cc::SurfaceManager* manager = factory->GetSurfaceManager(); |
| + cc::Surface* surface = manager->GetSurfaceForId(id); |
| + EXPECT_TRUE(surface); |
| + // There should be a SurfaceSequence created by the RWHVGuest. |
| + EXPECT_EQ(1u, surface->GetDestructionDependencyCount()); |
| +#endif |
| + // Surface ID should have been passed to BrowserPluginGuest to |
| + // be sent to the embedding renderer. |
| + EXPECT_EQ(id, browser_plugin_guest_->last_surface_id_received_); |
| + EXPECT_EQ(view_size, browser_plugin_guest_->last_frame_size_received_); |
| + EXPECT_EQ(scale_factor, |
| + browser_plugin_guest_->last_scale_factor_received_); |
| + } |
| + } else { |
| + EXPECT_TRUE(browser_plugin_guest_->received_delegated_frame_); |
| + EXPECT_EQ(view_size, browser_plugin_guest_->last_frame_size_received_); |
| + EXPECT_EQ(scale_factor, browser_plugin_guest_->last_scale_factor_received_); |
| + } |
| +} |
| + |
| } // namespace content |