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

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

Issue 1142343008: cc: Rework overlays to not use the ResourceProvider and pass texture size (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fix more tests Created 5 years, 6 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/base/scoped_ptr_vector.h" 5 #include "cc/base/scoped_ptr_vector.h"
6 #include "cc/output/compositor_frame_metadata.h" 6 #include "cc/output/compositor_frame_metadata.h"
7 #include "cc/output/gl_renderer.h" 7 #include "cc/output/gl_renderer.h"
8 #include "cc/output/output_surface.h" 8 #include "cc/output/output_surface.h"
9 #include "cc/output/output_surface_client.h" 9 #include "cc/output/output_surface_client.h"
10 #include "cc/output/overlay_candidate_validator.h" 10 #include "cc/output/overlay_candidate_validator.h"
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after
71 EXPECT_NEAR(kOverlayRect.height(), candidate.display_rect.height(), 0.01f); 71 EXPECT_NEAR(kOverlayRect.height(), candidate.display_rect.height(), 0.01f);
72 } 72 }
73 EXPECT_EQ(BoundingRect(kUVTopLeft, kUVBottomRight).ToString(), 73 EXPECT_EQ(BoundingRect(kUVTopLeft, kUVBottomRight).ToString(),
74 candidate.uv_rect.ToString()); 74 candidate.uv_rect.ToString());
75 candidate.overlay_handled = true; 75 candidate.overlay_handled = true;
76 } 76 }
77 77
78 template <typename OverlayStrategyType> 78 template <typename OverlayStrategyType>
79 class SingleOverlayProcessor : public OverlayProcessor { 79 class SingleOverlayProcessor : public OverlayProcessor {
80 public: 80 public:
81 SingleOverlayProcessor(OutputSurface* surface, 81 explicit SingleOverlayProcessor(OutputSurface* surface)
82 ResourceProvider* resource_provider) 82 : OverlayProcessor(surface) {
83 : OverlayProcessor(surface, resource_provider) {
84 EXPECT_EQ(surface, surface_); 83 EXPECT_EQ(surface, surface_);
85 EXPECT_EQ(resource_provider, resource_provider_);
86 } 84 }
87 85
88 // Virtual to allow testing different strategies. 86 // Virtual to allow testing different strategies.
89 void Initialize() override { 87 void Initialize() override {
90 OverlayCandidateValidator* candidates = 88 OverlayCandidateValidator* candidates =
91 surface_->GetOverlayCandidateValidator(); 89 surface_->GetOverlayCandidateValidator();
92 ASSERT_TRUE(candidates != NULL); 90 ASSERT_TRUE(candidates != NULL);
93 strategies_.push_back(scoped_ptr<Strategy>( 91 strategies_.push_back(
94 new OverlayStrategyType(candidates, resource_provider_))); 92 scoped_ptr<Strategy>(new OverlayStrategyType(candidates)));
95 } 93 }
96 }; 94 };
97 95
98 class DefaultOverlayProcessor : public OverlayProcessor { 96 class DefaultOverlayProcessor : public OverlayProcessor {
99 public: 97 public:
100 DefaultOverlayProcessor(OutputSurface* surface, 98 explicit DefaultOverlayProcessor(OutputSurface* surface);
101 ResourceProvider* resource_provider);
102 size_t GetStrategyCount(); 99 size_t GetStrategyCount();
103 }; 100 };
104 101
105 DefaultOverlayProcessor::DefaultOverlayProcessor( 102 DefaultOverlayProcessor::DefaultOverlayProcessor(OutputSurface* surface)
106 OutputSurface* surface, 103 : OverlayProcessor(surface) {
107 ResourceProvider* resource_provider) 104 }
108 : OverlayProcessor(surface, resource_provider) {}
109 105
110 size_t DefaultOverlayProcessor::GetStrategyCount() { 106 size_t DefaultOverlayProcessor::GetStrategyCount() {
111 return strategies_.size(); 107 return strategies_.size();
112 } 108 }
113 109
114 class OverlayOutputSurface : public OutputSurface { 110 class OverlayOutputSurface : public OutputSurface {
115 public: 111 public:
116 explicit OverlayOutputSurface(scoped_refptr<ContextProvider> context_provider) 112 explicit OverlayOutputSurface(scoped_refptr<ContextProvider> context_provider)
117 : OutputSurface(context_provider) {} 113 : OutputSurface(context_provider) {}
118 114
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
150 146
151 SharedQuadState* shared_state = pass->CreateAndAppendSharedQuadState(); 147 SharedQuadState* shared_state = pass->CreateAndAppendSharedQuadState();
152 shared_state->opacity = 1.f; 148 shared_state->opacity = 1.f;
153 return pass.Pass(); 149 return pass.Pass();
154 } 150 }
155 151
156 ResourceId CreateResource(ResourceProvider* resource_provider) { 152 ResourceId CreateResource(ResourceProvider* resource_provider) {
157 unsigned sync_point = 0; 153 unsigned sync_point = 0;
158 TextureMailbox mailbox = 154 TextureMailbox mailbox =
159 TextureMailbox(gpu::Mailbox::Generate(), GL_TEXTURE_2D, sync_point); 155 TextureMailbox(gpu::Mailbox::Generate(), GL_TEXTURE_2D, sync_point);
160 mailbox.set_allow_overlay(true);
161 scoped_ptr<SingleReleaseCallbackImpl> release_callback = 156 scoped_ptr<SingleReleaseCallbackImpl> release_callback =
162 SingleReleaseCallbackImpl::Create(base::Bind(&MailboxReleased)); 157 SingleReleaseCallbackImpl::Create(base::Bind(&MailboxReleased));
163 158
164 return resource_provider->CreateResourceFromTextureMailbox( 159 return resource_provider->CreateResourceFromTextureMailbox(
165 mailbox, release_callback.Pass()); 160 mailbox, release_callback.Pass());
166 } 161 }
167 162
168 SolidColorDrawQuad* CreateSolidColorQuadAt( 163 SolidColorDrawQuad* CreateSolidColorQuadAt(
169 const SharedQuadState* shared_quad_state, 164 const SharedQuadState* shared_quad_state,
170 SkColor color, 165 SkColor color,
171 RenderPass* render_pass, 166 RenderPass* render_pass,
172 const gfx::Rect& rect) { 167 const gfx::Rect& rect) {
173 SolidColorDrawQuad* quad = 168 SolidColorDrawQuad* quad =
174 render_pass->CreateAndAppendDrawQuad<SolidColorDrawQuad>(); 169 render_pass->CreateAndAppendDrawQuad<SolidColorDrawQuad>();
175 quad->SetNew(shared_quad_state, rect, rect, color, false); 170 quad->SetNew(shared_quad_state, rect, rect, color, false);
176 return quad; 171 return quad;
177 } 172 }
178 173
179 TextureDrawQuad* CreateCandidateQuadAt(ResourceProvider* resource_provider, 174 TextureDrawQuad* CreateCandidateQuadAt(ResourceProvider* resource_provider,
180 const SharedQuadState* shared_quad_state, 175 const SharedQuadState* shared_quad_state,
181 RenderPass* render_pass, 176 RenderPass* render_pass,
182 const gfx::Rect& rect) { 177 const gfx::Rect& rect) {
183 ResourceId resource_id = CreateResource(resource_provider); 178 ResourceId resource_id = CreateResource(resource_provider);
184 bool premultiplied_alpha = false; 179 bool premultiplied_alpha = false;
185 bool flipped = false; 180 bool flipped = false;
186 bool nearest_neighbor = false; 181 bool nearest_neighbor = false;
187 float vertex_opacity[4] = {1.0f, 1.0f, 1.0f, 1.0f}; 182 float vertex_opacity[4] = {1.0f, 1.0f, 1.0f, 1.0f};
183 gfx::Size resource_size_in_pixels = gfx::Size(64, 64);
184 bool allow_overlay = true;
188 185
189 TextureDrawQuad* overlay_quad = 186 TextureDrawQuad* overlay_quad =
190 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>(); 187 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>();
191 overlay_quad->SetNew(shared_quad_state, 188 overlay_quad->SetNew(shared_quad_state,
192 rect, 189 rect,
193 rect, 190 rect,
194 rect, 191 rect,
195 resource_id, 192 resource_id,
196 premultiplied_alpha, 193 premultiplied_alpha,
197 kUVTopLeft, 194 kUVTopLeft,
198 kUVBottomRight, 195 kUVBottomRight,
199 SK_ColorTRANSPARENT, 196 SK_ColorTRANSPARENT,
200 vertex_opacity, 197 vertex_opacity,
201 flipped, 198 flipped,
202 nearest_neighbor); 199 nearest_neighbor);
200 overlay_quad->set_allow_overlay(allow_overlay);
201 overlay_quad->set_resource_size_in_pixels(resource_size_in_pixels);
203 202
204 return overlay_quad; 203 return overlay_quad;
205 } 204 }
206 205
207 StreamVideoDrawQuad* CreateCandidateVideoQuadAt( 206 StreamVideoDrawQuad* CreateCandidateVideoQuadAt(
208 ResourceProvider* resource_provider, 207 ResourceProvider* resource_provider,
209 const SharedQuadState* shared_quad_state, 208 const SharedQuadState* shared_quad_state,
210 RenderPass* render_pass, 209 RenderPass* render_pass,
211 const gfx::Rect& rect, 210 const gfx::Rect& rect,
212 const gfx::Transform& transform) { 211 const gfx::Transform& transform) {
213 ResourceId resource_id = CreateResource(resource_provider); 212 ResourceId resource_id = CreateResource(resource_provider);
213 gfx::Size resource_size_in_pixels = gfx::Size(64, 64);
214 bool allow_overlay = true;
214 215
215 StreamVideoDrawQuad* overlay_quad = 216 StreamVideoDrawQuad* overlay_quad =
216 render_pass->CreateAndAppendDrawQuad<StreamVideoDrawQuad>(); 217 render_pass->CreateAndAppendDrawQuad<StreamVideoDrawQuad>();
217 overlay_quad->SetNew(shared_quad_state, rect, rect, rect, resource_id, 218 overlay_quad->SetNew(shared_quad_state, rect, rect, rect, resource_id,
218 transform); 219 resource_size_in_pixels, allow_overlay, transform);
219 220
220 return overlay_quad; 221 return overlay_quad;
221 } 222 }
222 223
223 TextureDrawQuad* CreateFullscreenCandidateQuad( 224 TextureDrawQuad* CreateFullscreenCandidateQuad(
224 ResourceProvider* resource_provider, 225 ResourceProvider* resource_provider,
225 const SharedQuadState* shared_quad_state, 226 const SharedQuadState* shared_quad_state,
226 RenderPass* render_pass) { 227 RenderPass* render_pass) {
227 return CreateCandidateQuadAt( 228 return CreateCandidateQuadAt(
228 resource_provider, shared_quad_state, render_pass, kOverlayRect); 229 resource_provider, shared_quad_state, render_pass, kOverlayRect);
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after
299 EXPECT_TRUE(output_surface.BindToClient(&client)); 300 EXPECT_TRUE(output_surface.BindToClient(&client));
300 output_surface.InitWithSingleOverlayValidator(); 301 output_surface.InitWithSingleOverlayValidator();
301 EXPECT_TRUE(output_surface.GetOverlayCandidateValidator() != NULL); 302 EXPECT_TRUE(output_surface.GetOverlayCandidateValidator() != NULL);
302 303
303 scoped_ptr<SharedBitmapManager> shared_bitmap_manager( 304 scoped_ptr<SharedBitmapManager> shared_bitmap_manager(
304 new TestSharedBitmapManager()); 305 new TestSharedBitmapManager());
305 scoped_ptr<ResourceProvider> resource_provider = FakeResourceProvider::Create( 306 scoped_ptr<ResourceProvider> resource_provider = FakeResourceProvider::Create(
306 &output_surface, shared_bitmap_manager.get()); 307 &output_surface, shared_bitmap_manager.get());
307 308
308 scoped_ptr<DefaultOverlayProcessor> overlay_processor( 309 scoped_ptr<DefaultOverlayProcessor> overlay_processor(
309 new DefaultOverlayProcessor(&output_surface, resource_provider.get())); 310 new DefaultOverlayProcessor(&output_surface));
310 overlay_processor->Initialize(); 311 overlay_processor->Initialize();
311 EXPECT_GE(2U, overlay_processor->GetStrategyCount()); 312 EXPECT_GE(2U, overlay_processor->GetStrategyCount());
312 } 313 }
313 314
314 template <typename OverlayStrategyType> 315 template <typename OverlayStrategyType>
315 class OverlayTest : public testing::Test { 316 class OverlayTest : public testing::Test {
316 protected: 317 protected:
317 void SetUp() override { 318 void SetUp() override {
318 provider_ = TestContextProvider::Create(); 319 provider_ = TestContextProvider::Create();
319 output_surface_.reset(new OverlayOutputSurface(provider_)); 320 output_surface_.reset(new OverlayOutputSurface(provider_));
320 EXPECT_TRUE(output_surface_->BindToClient(&client_)); 321 EXPECT_TRUE(output_surface_->BindToClient(&client_));
321 output_surface_->InitWithSingleOverlayValidator(); 322 output_surface_->InitWithSingleOverlayValidator();
322 EXPECT_TRUE(output_surface_->GetOverlayCandidateValidator() != NULL); 323 EXPECT_TRUE(output_surface_->GetOverlayCandidateValidator() != NULL);
323 324
324 shared_bitmap_manager_.reset(new TestSharedBitmapManager()); 325 shared_bitmap_manager_.reset(new TestSharedBitmapManager());
325 resource_provider_ = FakeResourceProvider::Create( 326 resource_provider_ = FakeResourceProvider::Create(
326 output_surface_.get(), shared_bitmap_manager_.get()); 327 output_surface_.get(), shared_bitmap_manager_.get());
327 328
328 overlay_processor_.reset(new SingleOverlayProcessor<OverlayStrategyType>( 329 overlay_processor_.reset(
329 output_surface_.get(), resource_provider_.get())); 330 new SingleOverlayProcessor<OverlayStrategyType>(output_surface_.get()));
330 overlay_processor_->Initialize(); 331 overlay_processor_->Initialize();
331 } 332 }
332 333
333 scoped_refptr<TestContextProvider> provider_; 334 scoped_refptr<TestContextProvider> provider_;
334 scoped_ptr<OverlayOutputSurface> output_surface_; 335 scoped_ptr<OverlayOutputSurface> output_surface_;
335 FakeOutputSurfaceClient client_; 336 FakeOutputSurfaceClient client_;
336 scoped_ptr<SharedBitmapManager> shared_bitmap_manager_; 337 scoped_ptr<SharedBitmapManager> shared_bitmap_manager_;
337 scoped_ptr<ResourceProvider> resource_provider_; 338 scoped_ptr<ResourceProvider> resource_provider_;
338 scoped_ptr<SingleOverlayProcessor<OverlayStrategyType>> overlay_processor_; 339 scoped_ptr<SingleOverlayProcessor<OverlayStrategyType>> overlay_processor_;
339 }; 340 };
(...skipping 841 matching lines...) Expand 10 before | Expand all | Expand 10 after
1181 renderer_->BeginDrawingFrame(&frame3); 1182 renderer_->BeginDrawingFrame(&frame3);
1182 renderer_->FinishDrawingFrame(&frame3); 1183 renderer_->FinishDrawingFrame(&frame3);
1183 EXPECT_TRUE(resource_provider_->InUseByConsumer(resource1)); 1184 EXPECT_TRUE(resource_provider_->InUseByConsumer(resource1));
1184 SwapBuffers(); 1185 SwapBuffers();
1185 EXPECT_FALSE(resource_provider_->InUseByConsumer(resource1)); 1186 EXPECT_FALSE(resource_provider_->InUseByConsumer(resource1));
1186 Mock::VerifyAndClearExpectations(&scheduler_); 1187 Mock::VerifyAndClearExpectations(&scheduler_);
1187 } 1188 }
1188 1189
1189 } // namespace 1190 } // namespace
1190 } // namespace cc 1191 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698