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

Side by Side Diff: cc/output/renderer_unittest.cc

Issue 1985973002: Defer compositor context creation to the thread. Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: contextfactory: . Created 4 years, 7 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 "cc/output/delegating_renderer.h" 5 #include "cc/output/delegating_renderer.h"
6 #include "cc/output/gl_renderer.h" 6 #include "cc/output/gl_renderer.h"
7 #include "cc/output/output_surface.h" 7 #include "cc/output/output_surface.h"
8 #include "cc/test/fake_output_surface_client.h" 8 #include "cc/test/fake_output_surface_client.h"
9 #include "cc/test/fake_renderer_client.h" 9 #include "cc/test/fake_renderer_client.h"
10 #include "cc/test/fake_resource_provider.h" 10 #include "cc/test/fake_resource_provider.h"
11 #include "cc/test/test_context_provider.h" 11 #include "cc/test/test_context_provider.h"
12 #include "cc/test/test_web_graphics_context_3d.h" 12 #include "cc/test/test_web_graphics_context_3d.h"
13 #include "testing/gmock/include/gmock/gmock.h" 13 #include "testing/gmock/include/gmock/gmock.h"
14 #include "testing/gtest/include/gtest/gtest.h" 14 #include "testing/gtest/include/gtest/gtest.h"
15 15
16 namespace cc { 16 namespace cc {
17 namespace { 17 namespace {
18 18
19 class TestOutputSurface : public OutputSurface { 19 class TestOutputSurface : public OutputSurface {
20 public: 20 public:
21 explicit TestOutputSurface(scoped_refptr<ContextProvider> context_provider); 21 explicit TestOutputSurface(
22 ~TestOutputSurface() override; 22 std::unique_ptr<ContextProvider::Factory> compositor_context_factory)
23 : OutputSurface(std::move(compositor_context_factory)) {}
24 ~TestOutputSurface() override = default;
23 25
24 // OutputSurface implementation 26 // OutputSurface implementation.
25 void SwapBuffers(CompositorFrame* frame) override; 27 void SwapBuffers(CompositorFrame* frame) override {
28 client_->DidSwapBuffers();
29 client_->DidSwapBuffersComplete();
30 }
26 }; 31 };
27 32
28 TestOutputSurface::TestOutputSurface(
29 scoped_refptr<ContextProvider> context_provider)
30 : OutputSurface(std::move(context_provider)) {}
31
32 TestOutputSurface::~TestOutputSurface() {
33 }
34
35 void TestOutputSurface::SwapBuffers(CompositorFrame* frame) {
36 client_->DidSwapBuffers();
37 client_->DidSwapBuffersComplete();
38 }
39
40 class MockContextProvider : public TestContextProvider { 33 class MockContextProvider : public TestContextProvider {
41 public: 34 public:
42 explicit MockContextProvider( 35 MockContextProvider()
43 std::unique_ptr<TestWebGraphicsContext3D> context) 36 : TestContextProvider(TestWebGraphicsContext3D::Create()) {}
44 : TestContextProvider(std::move(context)) {} 37
38 class Factory : public ContextProvider::Factory {
39 public:
40 explicit Factory(scoped_refptr<MockContextProvider> provider)
41 : provider_(provider) {}
42
43 scoped_refptr<ContextProvider> CreateContext() override {
44 return std::move(provider_);
45 }
46
47 private:
48 scoped_refptr<MockContextProvider> provider_;
49 };
50
45 MOCK_METHOD0(DeleteCachedResources, void()); 51 MOCK_METHOD0(DeleteCachedResources, void());
46 52
47 protected: 53 protected:
48 ~MockContextProvider() {} 54 ~MockContextProvider() = default;
49 }; 55 };
50 56
51 template <class T> 57 template <class T>
52 std::unique_ptr<Renderer> CreateRenderer(RendererClient* client, 58 std::unique_ptr<Renderer> CreateRenderer(RendererClient* client,
53 const RendererSettings* settings, 59 const RendererSettings* settings,
54 OutputSurface* output_surface, 60 OutputSurface* output_surface,
55 ResourceProvider* resource_provider); 61 ResourceProvider* resource_provider);
56 62
57 template <> 63 template <>
58 std::unique_ptr<Renderer> CreateRenderer<DelegatingRenderer>( 64 std::unique_ptr<Renderer> CreateRenderer<DelegatingRenderer>(
(...skipping 12 matching lines...) Expand all
71 OutputSurface* output_surface, 77 OutputSurface* output_surface,
72 ResourceProvider* resource_provider) { 78 ResourceProvider* resource_provider) {
73 return GLRenderer::Create( 79 return GLRenderer::Create(
74 client, settings, output_surface, resource_provider, NULL, 0); 80 client, settings, output_surface, resource_provider, NULL, 0);
75 } 81 }
76 82
77 template <typename T> 83 template <typename T>
78 class RendererTest : public ::testing::Test { 84 class RendererTest : public ::testing::Test {
79 protected: 85 protected:
80 virtual void SetUp() { 86 virtual void SetUp() {
81 context_provider_ = 87 context_provider_ = new MockContextProvider;
82 new MockContextProvider(TestWebGraphicsContext3D::Create()); 88 output_surface_.reset(new TestOutputSurface(
83 output_surface_.reset(new TestOutputSurface(context_provider_)); 89 base::MakeUnique<MockContextProvider::Factory>(context_provider_)));
84 output_surface_->BindToClient(&output_surface_client_); 90 output_surface_->BindToClient(&output_surface_client_);
85 resource_provider_ = 91 resource_provider_ =
86 FakeResourceProvider::Create(output_surface_.get(), nullptr); 92 FakeResourceProvider::Create(output_surface_.get(), nullptr);
87 renderer_ = CreateRenderer<T>(&renderer_client_, 93 renderer_ = CreateRenderer<T>(&renderer_client_,
88 &tree_settings_, 94 &tree_settings_,
89 output_surface_.get(), 95 output_surface_.get(),
90 resource_provider_.get()); 96 resource_provider_.get());
91 } 97 }
92 98
93 FakeRendererClient renderer_client_; 99 FakeRendererClient renderer_client_;
94 RendererSettings tree_settings_; 100 RendererSettings tree_settings_;
95 FakeOutputSurfaceClient output_surface_client_; 101 FakeOutputSurfaceClient output_surface_client_;
96 scoped_refptr<MockContextProvider> context_provider_; 102 scoped_refptr<MockContextProvider> context_provider_;
97 std::unique_ptr<OutputSurface> output_surface_; 103 std::unique_ptr<OutputSurface> output_surface_;
98 std::unique_ptr<ResourceProvider> resource_provider_; 104 std::unique_ptr<ResourceProvider> resource_provider_;
99 std::unique_ptr<Renderer> renderer_; 105 std::unique_ptr<Renderer> renderer_;
100 }; 106 };
101 107
102 typedef ::testing::Types<DelegatingRenderer, GLRenderer> RendererTypes; 108 typedef ::testing::Types<DelegatingRenderer, GLRenderer> RendererTypes;
103 TYPED_TEST_CASE(RendererTest, RendererTypes); 109 TYPED_TEST_CASE(RendererTest, RendererTypes);
104 110
105 TYPED_TEST(RendererTest, ContextPurgedWhenRendererBecomesInvisible) { 111 TYPED_TEST(RendererTest, ContextPurgedWhenRendererBecomesInvisible) {
106 EXPECT_CALL(*(this->context_provider_.get()), DeleteCachedResources()) 112 EXPECT_CALL(*this->context_provider_, DeleteCachedResources()).Times(1);
107 .Times(1);
108 113
109 EXPECT_TRUE(this->renderer_->visible()); 114 EXPECT_TRUE(this->renderer_->visible());
110 this->renderer_->SetVisible(false); 115 this->renderer_->SetVisible(false);
111 EXPECT_FALSE(this->renderer_->visible()); 116 EXPECT_FALSE(this->renderer_->visible());
112 } 117 }
113 118
114 } // namespace 119 } // namespace
115 } // namespace cc 120 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698