Chromium Code Reviews| Index: cc/output/overlay_unittest.cc |
| diff --git a/cc/output/overlay_unittest.cc b/cc/output/overlay_unittest.cc |
| index 46826799c95d6354abfbc93b079029da1f0c5b35..4bb6521299ab9dfcfb9dbed0bde7615b9aa0d43c 100644 |
| --- a/cc/output/overlay_unittest.cc |
| +++ b/cc/output/overlay_unittest.cc |
| @@ -156,6 +156,17 @@ ResourceProvider::ResourceId CreateResource( |
| mailbox, release_callback.Pass()); |
| } |
| +SolidColorDrawQuad* CreateSolidColorQuadAt( |
| + const SharedQuadState* shared_quad_state, |
| + SkColor color, |
| + RenderPass* render_pass, |
| + const gfx::Rect& rect) { |
| + SolidColorDrawQuad* quad = |
| + render_pass->CreateAndAppendDrawQuad<SolidColorDrawQuad>(); |
| + quad->SetNew(shared_quad_state, rect, rect, color, false); |
| + return quad; |
| +} |
| + |
| TextureDrawQuad* CreateCandidateQuadAt(ResourceProvider* resource_provider, |
| const SharedQuadState* shared_quad_state, |
| RenderPass* render_pass, |
| @@ -571,13 +582,55 @@ TEST_F(SingleOverlayOnTopTest, AllowPositiveScaleTransform) { |
| TEST_F(SingleOverlayOnTopTest, AllowNotTopIfNotOccluded) { |
| scoped_ptr<RenderPass> pass = CreateRenderPass(); |
| + CreateCandidateQuadAt(resource_provider_.get(), |
|
danakj
2015/02/05 17:27:02
you moved the candidate on top? thats not what the
achaulk
2015/02/05 18:12:19
Oh oops, this one wasn't supposed to move
|
| + pass->shared_quad_state_list.back(), pass.get(), |
| + kOverlayBottomRightRect); |
| CreateCheckeredQuadAt(resource_provider_.get(), |
| pass->shared_quad_state_list.back(), |
| pass.get(), |
| kOverlayTopLeftRect); |
| + |
| + RenderPassList pass_list; |
| + pass_list.push_back(pass.Pass()); |
| + |
| + RenderPassList original_pass_list; |
| + RenderPass::CopyAll(pass_list, &original_pass_list); |
| + |
| + OverlayCandidateList candidate_list; |
| + overlay_processor_->ProcessForOverlays(&pass_list, &candidate_list); |
| + EXPECT_EQ(1U, pass_list.size()); |
| + EXPECT_EQ(2U, candidate_list.size()); |
| +} |
| + |
| +TEST_F(SingleOverlayOnTopTest, AllowTransparentOnTop) { |
| + scoped_ptr<RenderPass> pass = CreateRenderPass(); |
| + SharedQuadState* current = pass->shared_quad_state_list.back(); |
| + SharedQuadState* shared_state = pass->CreateAndAppendSharedQuadState(); |
| + shared_state->opacity = 0.f; |
| + CreateCandidateQuadAt(resource_provider_.get(), current, pass.get(), |
| + kOverlayBottomRightRect); |
| + CreateSolidColorQuadAt(shared_state, SK_ColorBLACK, pass.get(), |
|
danakj
2015/02/05 17:27:02
now the transparent is below?
achaulk
2015/02/05 18:12:19
It was always below, that's what this was supposed
|
| + kOverlayBottomRightRect); |
| + |
| + RenderPassList pass_list; |
| + pass_list.push_back(pass.Pass()); |
| + |
| + RenderPassList original_pass_list; |
| + RenderPass::CopyAll(pass_list, &original_pass_list); |
| + |
| + OverlayCandidateList candidate_list; |
| + overlay_processor_->ProcessForOverlays(&pass_list, &candidate_list); |
| + EXPECT_EQ(1U, pass_list.size()); |
| + EXPECT_EQ(2U, candidate_list.size()); |
| +} |
| + |
| +TEST_F(SingleOverlayOnTopTest, AllowTransparentColorOnTop) { |
| + scoped_ptr<RenderPass> pass = CreateRenderPass(); |
| + CreateSolidColorQuadAt(pass->shared_quad_state_list.back(), |
| + SK_ColorTRANSPARENT, pass.get(), |
| + kOverlayBottomRightRect); |
| CreateCandidateQuadAt(resource_provider_.get(), |
| - pass->shared_quad_state_list.back(), |
| - pass.get(), |
| + pass->shared_quad_state_list.back(), pass.get(), |
| kOverlayBottomRightRect); |
| RenderPassList pass_list; |
| @@ -592,6 +645,26 @@ TEST_F(SingleOverlayOnTopTest, AllowNotTopIfNotOccluded) { |
| EXPECT_EQ(2U, candidate_list.size()); |
| } |
| +TEST_F(SingleOverlayOnTopTest, RejectOpaqueColorOnTop) { |
|
danakj
2015/02/05 17:28:25
this new test is good for testing the color checks
achaulk
2015/02/05 18:12:19
I'm not sure what you mean. You want a transparent
danakj
2015/02/05 18:18:37
yes. that's the reason the needsblending check is
achaulk
2015/02/05 19:32:58
Done.
|
| + scoped_ptr<RenderPass> pass = CreateRenderPass(); |
| + CreateSolidColorQuadAt(pass->shared_quad_state_list.back(), SK_ColorBLACK, |
| + pass.get(), kOverlayBottomRightRect); |
| + CreateCandidateQuadAt(resource_provider_.get(), |
| + pass->shared_quad_state_list.back(), pass.get(), |
| + kOverlayBottomRightRect); |
| + |
| + RenderPassList pass_list; |
| + pass_list.push_back(pass.Pass()); |
| + |
| + RenderPassList original_pass_list; |
| + RenderPass::CopyAll(pass_list, &original_pass_list); |
| + |
| + OverlayCandidateList candidate_list; |
| + overlay_processor_->ProcessForOverlays(&pass_list, &candidate_list); |
| + EXPECT_EQ(1U, pass_list.size()); |
| + EXPECT_EQ(0U, candidate_list.size()); |
| +} |
| + |
| TEST_F(SingleOverlayOnTopTest, RejectVideoSwapTransform) { |
| scoped_ptr<RenderPass> pass = CreateRenderPass(); |
| CreateFullscreenCandidateVideoQuad(resource_provider_.get(), |