Index: cc/quads/draw_quad_unittest.cc |
diff --git a/cc/quads/draw_quad_unittest.cc b/cc/quads/draw_quad_unittest.cc |
deleted file mode 100644 |
index 5b5f0b9291a7db397946a74c36485525c4877f02..0000000000000000000000000000000000000000 |
--- a/cc/quads/draw_quad_unittest.cc |
+++ /dev/null |
@@ -1,1038 +0,0 @@ |
-// Copyright 2012 The Chromium Authors. All rights reserved. |
-// Use of this source code is governed by a BSD-style license that can be |
-// found in the LICENSE file. |
- |
-#include "cc/quads/draw_quad.h" |
- |
-#include <algorithm> |
- |
-#include "base/bind.h" |
-#include "base/compiler_specific.h" |
-#include "cc/base/math_util.h" |
-#include "cc/output/filter_operations.h" |
-#include "cc/quads/checkerboard_draw_quad.h" |
-#include "cc/quads/debug_border_draw_quad.h" |
-#include "cc/quads/io_surface_draw_quad.h" |
-#include "cc/quads/largest_draw_quad.h" |
-#include "cc/quads/picture_draw_quad.h" |
-#include "cc/quads/render_pass.h" |
-#include "cc/quads/render_pass_draw_quad.h" |
-#include "cc/quads/solid_color_draw_quad.h" |
-#include "cc/quads/stream_video_draw_quad.h" |
-#include "cc/quads/surface_draw_quad.h" |
-#include "cc/quads/texture_draw_quad.h" |
-#include "cc/quads/tile_draw_quad.h" |
-#include "cc/quads/yuv_video_draw_quad.h" |
-#include "cc/test/fake_picture_pile_impl.h" |
-#include "cc/test/geometry_test_utils.h" |
-#include "testing/gtest/include/gtest/gtest.h" |
-#include "third_party/skia/include/effects/SkBlurImageFilter.h" |
-#include "ui/gfx/transform.h" |
- |
-namespace cc { |
-namespace { |
- |
-TEST(DrawQuadTest, CopySharedQuadState) { |
- gfx::Transform quad_transform = gfx::Transform(1.0, 0.0, 0.5, 1.0, 0.5, 0.0); |
- gfx::Size content_bounds(26, 28); |
- gfx::Rect visible_content_rect(10, 12, 14, 16); |
- gfx::Rect clip_rect(19, 21, 23, 25); |
- bool is_clipped = true; |
- float opacity = 0.25f; |
- SkXfermode::Mode blend_mode = SkXfermode::kMultiply_Mode; |
- int sorting_context_id = 65536; |
- |
- scoped_ptr<SharedQuadState> state(new SharedQuadState); |
- state->SetAll(quad_transform, |
- content_bounds, |
- visible_content_rect, |
- clip_rect, |
- is_clipped, |
- opacity, |
- blend_mode, |
- sorting_context_id); |
- |
- scoped_ptr<SharedQuadState> copy(new SharedQuadState); |
- copy->CopyFrom(state.get()); |
- EXPECT_EQ(quad_transform, copy->content_to_target_transform); |
- EXPECT_EQ(visible_content_rect, copy->visible_content_rect); |
- EXPECT_EQ(opacity, copy->opacity); |
- EXPECT_EQ(clip_rect, copy->clip_rect); |
- EXPECT_EQ(is_clipped, copy->is_clipped); |
- EXPECT_EQ(blend_mode, copy->blend_mode); |
-} |
- |
-SharedQuadState* CreateSharedQuadState(RenderPass* render_pass) { |
- gfx::Transform quad_transform = gfx::Transform(1.0, 0.0, 0.5, 1.0, 0.5, 0.0); |
- gfx::Size content_bounds(26, 28); |
- gfx::Rect visible_content_rect(10, 12, 14, 16); |
- gfx::Rect clip_rect(19, 21, 23, 25); |
- bool is_clipped = false; |
- float opacity = 1.f; |
- int sorting_context_id = 65536; |
- SkXfermode::Mode blend_mode = SkXfermode::kSrcOver_Mode; |
- |
- SharedQuadState* state = render_pass->CreateAndAppendSharedQuadState(); |
- state->SetAll(quad_transform, |
- content_bounds, |
- visible_content_rect, |
- clip_rect, |
- is_clipped, |
- opacity, |
- blend_mode, |
- sorting_context_id); |
- return state; |
-} |
- |
-void CompareDrawQuad(DrawQuad* quad, |
- DrawQuad* copy, |
- SharedQuadState* copy_shared_state) { |
- EXPECT_EQ(quad->material, copy->material); |
- EXPECT_EQ(quad->rect, copy->rect); |
- EXPECT_EQ(quad->visible_rect, copy->visible_rect); |
- EXPECT_EQ(quad->opaque_rect, copy->opaque_rect); |
- EXPECT_EQ(quad->needs_blending, copy->needs_blending); |
- EXPECT_EQ(copy_shared_state, copy->shared_quad_state); |
-} |
- |
-#define CREATE_SHARED_STATE() \ |
- scoped_ptr<RenderPass> render_pass = RenderPass::Create(); \ |
- SharedQuadState* shared_state(CreateSharedQuadState(render_pass.get())); \ |
- SharedQuadState* copy_shared_state = \ |
- render_pass->CreateAndAppendSharedQuadState(); \ |
- copy_shared_state->CopyFrom(shared_state); |
- |
-#define QUAD_DATA \ |
- gfx::Rect quad_rect(30, 40, 50, 60); \ |
- gfx::Rect quad_visible_rect(40, 50, 30, 20); \ |
- gfx::Rect quad_opaque_rect(60, 55, 10, 10); \ |
- ALLOW_UNUSED_LOCAL(quad_opaque_rect); \ |
- bool needs_blending = true; \ |
- ALLOW_UNUSED_LOCAL(needs_blending); |
- |
-#define SETUP_AND_COPY_QUAD_NEW(Type, quad) \ |
- DrawQuad* copy_new = \ |
- render_pass->CopyFromAndAppendDrawQuad(quad_new, copy_shared_state); \ |
- CompareDrawQuad(quad_new, copy_new, copy_shared_state); \ |
- const Type* copy_quad = Type::MaterialCast(copy_new); \ |
- ALLOW_UNUSED_LOCAL(copy_quad); |
- |
-#define SETUP_AND_COPY_QUAD_ALL(Type, quad) \ |
- DrawQuad* copy_all = \ |
- render_pass->CopyFromAndAppendDrawQuad(quad_all, copy_shared_state); \ |
- CompareDrawQuad(quad_all, copy_all, copy_shared_state); \ |
- copy_quad = Type::MaterialCast(copy_all); |
- |
-#define SETUP_AND_COPY_QUAD_NEW_RP(Type, quad, a) \ |
- DrawQuad* copy_new = render_pass->CopyFromAndAppendRenderPassDrawQuad( \ |
- quad_new, copy_shared_state, a); \ |
- CompareDrawQuad(quad_new, copy_new, copy_shared_state); \ |
- const Type* copy_quad = Type::MaterialCast(copy_new); \ |
- ALLOW_UNUSED_LOCAL(copy_quad); |
- |
-#define SETUP_AND_COPY_QUAD_ALL_RP(Type, quad, a) \ |
- DrawQuad* copy_all = render_pass->CopyFromAndAppendRenderPassDrawQuad( \ |
- quad_all, copy_shared_state, a); \ |
- CompareDrawQuad(quad_all, copy_all, copy_shared_state); \ |
- copy_quad = Type::MaterialCast(copy_all); |
- |
-#define CREATE_QUAD_1_NEW(Type, a) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a); } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_1_ALL(Type, a) \ |
- Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_all->SetAll(shared_state, \ |
- quad_rect, \ |
- quad_opaque_rect, \ |
- quad_visible_rect, \ |
- needs_blending, \ |
- a); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_2_NEW(Type, a, b) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b); } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_2_ALL(Type, a, b) \ |
- Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_all->SetAll(shared_state, \ |
- quad_rect, \ |
- quad_opaque_rect, \ |
- quad_visible_rect, \ |
- needs_blending, \ |
- a, \ |
- b); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_3_NEW(Type, a, b, c) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c); } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_3_ALL(Type, a, b, c) \ |
- Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_all->SetAll(shared_state, \ |
- quad_rect, \ |
- quad_opaque_rect, \ |
- quad_visible_rect, \ |
- needs_blending, \ |
- a, \ |
- b, \ |
- c); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_4_NEW(Type, a, b, c, d) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c, d); } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_4_ALL(Type, a, b, c, d) \ |
- Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_all->SetAll(shared_state, \ |
- quad_rect, \ |
- quad_opaque_rect, \ |
- quad_visible_rect, \ |
- needs_blending, \ |
- a, \ |
- b, \ |
- c, \ |
- d); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_5_NEW(Type, a, b, c, d, e) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c, d, e); } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_5_ALL(Type, a, b, c, d, e) \ |
- Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_all->SetAll(shared_state, \ |
- quad_rect, \ |
- quad_opaque_rect, \ |
- quad_visible_rect, \ |
- needs_blending, \ |
- a, \ |
- b, \ |
- c, \ |
- d, \ |
- e); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_6_NEW(Type, a, b, c, d, e, f) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c, d, e, f); } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_6_ALL(Type, a, b, c, d, e, f) \ |
- Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_all->SetAll(shared_state, \ |
- quad_rect, \ |
- quad_opaque_rect, \ |
- quad_visible_rect, \ |
- needs_blending, \ |
- a, \ |
- b, \ |
- c, \ |
- d, \ |
- e, \ |
- f); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_7_NEW(Type, a, b, c, d, e, f, g) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_new->SetNew(shared_state, quad_rect, a, b, c, d, e, f, g); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_7_ALL(Type, a, b, c, d, e, f, g) \ |
- Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_all->SetAll(shared_state, \ |
- quad_rect, \ |
- quad_opaque_rect, \ |
- quad_visible_rect, \ |
- needs_blending, \ |
- a, \ |
- b, \ |
- c, \ |
- d, \ |
- e, \ |
- f, \ |
- g); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_8_NEW(Type, a, b, c, d, e, f, g, h) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_new->SetNew( \ |
- shared_state, quad_rect, a, b, c, d, e, f, g, h); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_8_ALL(Type, a, b, c, d, e, f, g, h) \ |
- Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_all->SetAll(shared_state, \ |
- quad_rect, \ |
- quad_opaque_rect, \ |
- quad_visible_rect, \ |
- needs_blending, \ |
- a, \ |
- b, \ |
- c, \ |
- d, \ |
- e, \ |
- f, \ |
- g, \ |
- h); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_9_NEW(Type, a, b, c, d, e, f, g, h, i) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_new->SetNew( \ |
- shared_state, quad_rect, a, b, c, d, e, f, g, h, i); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_9_ALL(Type, a, b, c, d, e, f, g, h, i) \ |
- { \ |
- QUAD_DATA quad_all->SetAll(shared_state, \ |
- quad_rect, \ |
- quad_opaque_rect, \ |
- quad_visible_rect, \ |
- needs_blending, \ |
- a, \ |
- b, \ |
- c, \ |
- d, \ |
- e, \ |
- f, \ |
- g, \ |
- h, \ |
- i); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL(Type, quad_all); |
- |
-#define CREATE_QUAD_10_NEW(Type, a, b, c, d, e, f, g, h, i, j) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_new->SetNew( \ |
- shared_state, quad_rect, a, b, c, d, e, f, g, h, i, j); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW(Type, quad_new); |
- |
-#define CREATE_QUAD_ALL_RP(Type, a, b, c, d, e, f, g, copy_a) \ |
- Type* quad_all = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_all->SetAll(shared_state, \ |
- quad_rect, \ |
- quad_opaque_rect, \ |
- quad_visible_rect, \ |
- needs_blending, \ |
- a, \ |
- b, \ |
- c, \ |
- d, \ |
- e, \ |
- f, \ |
- g); \ |
- } \ |
- SETUP_AND_COPY_QUAD_ALL_RP(Type, quad_all, copy_a); |
- |
-#define CREATE_QUAD_NEW_RP(Type, a, b, c, d, e, f, g, h, copy_a) \ |
- Type* quad_new = render_pass->CreateAndAppendDrawQuad<Type>(); \ |
- { \ |
- QUAD_DATA quad_new->SetNew( \ |
- shared_state, quad_rect, a, b, c, d, e, f, g, h); \ |
- } \ |
- SETUP_AND_COPY_QUAD_NEW_RP(Type, quad_new, copy_a); |
- |
-TEST(DrawQuadTest, CopyCheckerboardDrawQuad) { |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- SkColor color = 0xfabb0011; |
- float scale = 2.3f; |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_3_NEW(CheckerboardDrawQuad, visible_rect, color, scale); |
- EXPECT_EQ(DrawQuad::CHECKERBOARD, copy_quad->material); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(color, copy_quad->color); |
- EXPECT_EQ(scale, copy_quad->scale); |
- |
- CREATE_QUAD_2_ALL(CheckerboardDrawQuad, color, scale); |
- EXPECT_EQ(DrawQuad::CHECKERBOARD, copy_quad->material); |
- EXPECT_EQ(color, copy_quad->color); |
- EXPECT_EQ(scale, copy_quad->scale); |
-} |
- |
-TEST(DrawQuadTest, CopyDebugBorderDrawQuad) { |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- SkColor color = 0xfabb0011; |
- int width = 99; |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_3_NEW(DebugBorderDrawQuad, visible_rect, color, width); |
- EXPECT_EQ(DrawQuad::DEBUG_BORDER, copy_quad->material); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(color, copy_quad->color); |
- EXPECT_EQ(width, copy_quad->width); |
- |
- CREATE_QUAD_2_ALL(DebugBorderDrawQuad, color, width); |
- EXPECT_EQ(DrawQuad::DEBUG_BORDER, copy_quad->material); |
- EXPECT_EQ(color, copy_quad->color); |
- EXPECT_EQ(width, copy_quad->width); |
-} |
- |
-TEST(DrawQuadTest, CopyIOSurfaceDrawQuad) { |
- gfx::Rect opaque_rect(33, 47, 10, 12); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- gfx::Size size(58, 95); |
- ResourceProvider::ResourceId resource_id = 72; |
- IOSurfaceDrawQuad::Orientation orientation = IOSurfaceDrawQuad::UNFLIPPED; |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_5_NEW(IOSurfaceDrawQuad, |
- opaque_rect, |
- visible_rect, |
- size, |
- resource_id, |
- orientation); |
- EXPECT_EQ(DrawQuad::IO_SURFACE_CONTENT, copy_quad->material); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(opaque_rect, copy_quad->opaque_rect); |
- EXPECT_EQ(size, copy_quad->io_surface_size); |
- EXPECT_EQ(resource_id, copy_quad->io_surface_resource_id); |
- EXPECT_EQ(orientation, copy_quad->orientation); |
- |
- CREATE_QUAD_3_ALL(IOSurfaceDrawQuad, size, resource_id, orientation); |
- EXPECT_EQ(DrawQuad::IO_SURFACE_CONTENT, copy_quad->material); |
- EXPECT_EQ(size, copy_quad->io_surface_size); |
- EXPECT_EQ(resource_id, copy_quad->io_surface_resource_id); |
- EXPECT_EQ(orientation, copy_quad->orientation); |
-} |
- |
-TEST(DrawQuadTest, CopyRenderPassDrawQuad) { |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- RenderPassId render_pass_id(22, 64); |
- ResourceProvider::ResourceId mask_resource_id = 78; |
- gfx::Vector2dF mask_uv_scale(33.f, 19.f); |
- gfx::Size mask_texture_size(128, 134); |
- FilterOperations filters; |
- filters.Append(FilterOperation::CreateBlurFilter(1.f)); |
- gfx::Vector2dF filters_scale; |
- FilterOperations background_filters; |
- background_filters.Append( |
- FilterOperation::CreateGrayscaleFilter(1.f)); |
- |
- RenderPassId copied_render_pass_id(235, 11); |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_NEW_RP(RenderPassDrawQuad, |
- visible_rect, |
- render_pass_id, |
- mask_resource_id, |
- mask_uv_scale, |
- mask_texture_size, |
- filters, |
- filters_scale, |
- background_filters, |
- copied_render_pass_id); |
- EXPECT_EQ(DrawQuad::RENDER_PASS, copy_quad->material); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(copied_render_pass_id, copy_quad->render_pass_id); |
- EXPECT_EQ(mask_resource_id, copy_quad->mask_resource_id); |
- EXPECT_EQ(mask_uv_scale.ToString(), copy_quad->mask_uv_scale.ToString()); |
- EXPECT_EQ(mask_texture_size.ToString(), |
- copy_quad->mask_texture_size.ToString()); |
- EXPECT_EQ(filters, copy_quad->filters); |
- EXPECT_EQ(filters_scale, copy_quad->filters_scale); |
- EXPECT_EQ(background_filters, copy_quad->background_filters); |
- |
- CREATE_QUAD_ALL_RP(RenderPassDrawQuad, |
- render_pass_id, |
- mask_resource_id, |
- mask_uv_scale, |
- mask_texture_size, |
- filters, |
- filters_scale, |
- background_filters, |
- copied_render_pass_id); |
- EXPECT_EQ(DrawQuad::RENDER_PASS, copy_quad->material); |
- EXPECT_EQ(copied_render_pass_id, copy_quad->render_pass_id); |
- EXPECT_EQ(mask_resource_id, copy_quad->mask_resource_id); |
- EXPECT_EQ(mask_uv_scale.ToString(), copy_quad->mask_uv_scale.ToString()); |
- EXPECT_EQ(mask_texture_size.ToString(), |
- copy_quad->mask_texture_size.ToString()); |
- EXPECT_EQ(filters, copy_quad->filters); |
- EXPECT_EQ(filters_scale, copy_quad->filters_scale); |
- EXPECT_EQ(background_filters, copy_quad->background_filters); |
-} |
- |
-TEST(DrawQuadTest, CopySolidColorDrawQuad) { |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- SkColor color = 0x49494949; |
- bool force_anti_aliasing_off = false; |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_3_NEW( |
- SolidColorDrawQuad, visible_rect, color, force_anti_aliasing_off); |
- EXPECT_EQ(DrawQuad::SOLID_COLOR, copy_quad->material); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(color, copy_quad->color); |
- EXPECT_EQ(force_anti_aliasing_off, copy_quad->force_anti_aliasing_off); |
- |
- CREATE_QUAD_2_ALL(SolidColorDrawQuad, color, force_anti_aliasing_off); |
- EXPECT_EQ(DrawQuad::SOLID_COLOR, copy_quad->material); |
- EXPECT_EQ(color, copy_quad->color); |
- EXPECT_EQ(force_anti_aliasing_off, copy_quad->force_anti_aliasing_off); |
-} |
- |
-TEST(DrawQuadTest, CopyStreamVideoDrawQuad) { |
- gfx::Rect opaque_rect(33, 47, 10, 12); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- ResourceProvider::ResourceId resource_id = 64; |
- gfx::Transform matrix = gfx::Transform(0.5, 0.25, 1, 0.75, 0, 1); |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_4_NEW( |
- StreamVideoDrawQuad, opaque_rect, visible_rect, resource_id, matrix); |
- EXPECT_EQ(DrawQuad::STREAM_VIDEO_CONTENT, copy_quad->material); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(opaque_rect, copy_quad->opaque_rect); |
- EXPECT_EQ(resource_id, copy_quad->resource_id); |
- EXPECT_EQ(matrix, copy_quad->matrix); |
- |
- CREATE_QUAD_2_ALL(StreamVideoDrawQuad, resource_id, matrix); |
- EXPECT_EQ(DrawQuad::STREAM_VIDEO_CONTENT, copy_quad->material); |
- EXPECT_EQ(resource_id, copy_quad->resource_id); |
- EXPECT_EQ(matrix, copy_quad->matrix); |
-} |
- |
-TEST(DrawQuadTest, CopySurfaceDrawQuad) { |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- SurfaceId surface_id(1234); |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_2_NEW(SurfaceDrawQuad, visible_rect, surface_id); |
- EXPECT_EQ(DrawQuad::SURFACE_CONTENT, copy_quad->material); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(surface_id, copy_quad->surface_id); |
- |
- CREATE_QUAD_1_ALL(SurfaceDrawQuad, surface_id); |
- EXPECT_EQ(DrawQuad::SURFACE_CONTENT, copy_quad->material); |
- EXPECT_EQ(surface_id, copy_quad->surface_id); |
-} |
- |
- |
-TEST(DrawQuadTest, CopyTextureDrawQuad) { |
- gfx::Rect opaque_rect(33, 47, 10, 12); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- unsigned resource_id = 82; |
- bool premultiplied_alpha = true; |
- gfx::PointF uv_top_left(0.5f, 224.f); |
- gfx::PointF uv_bottom_right(51.5f, 260.f); |
- const float vertex_opacity[] = { 1.0f, 1.0f, 1.0f, 1.0f }; |
- bool flipped = true; |
- bool nearest_neighbor = true; |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_10_NEW(TextureDrawQuad, |
- opaque_rect, |
- visible_rect, |
- resource_id, |
- premultiplied_alpha, |
- uv_top_left, |
- uv_bottom_right, |
- SK_ColorTRANSPARENT, |
- vertex_opacity, |
- flipped, |
- nearest_neighbor); |
- EXPECT_EQ(DrawQuad::TEXTURE_CONTENT, copy_quad->material); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(opaque_rect, copy_quad->opaque_rect); |
- EXPECT_EQ(resource_id, copy_quad->resource_id); |
- EXPECT_EQ(premultiplied_alpha, copy_quad->premultiplied_alpha); |
- EXPECT_EQ(uv_top_left, copy_quad->uv_top_left); |
- EXPECT_EQ(uv_bottom_right, copy_quad->uv_bottom_right); |
- EXPECT_FLOAT_ARRAY_EQ(vertex_opacity, copy_quad->vertex_opacity, 4); |
- EXPECT_EQ(flipped, copy_quad->flipped); |
- EXPECT_EQ(nearest_neighbor, copy_quad->nearest_neighbor); |
- |
- CREATE_QUAD_8_ALL(TextureDrawQuad, |
- resource_id, |
- premultiplied_alpha, |
- uv_top_left, |
- uv_bottom_right, |
- SK_ColorTRANSPARENT, |
- vertex_opacity, |
- flipped, |
- nearest_neighbor); |
- EXPECT_EQ(DrawQuad::TEXTURE_CONTENT, copy_quad->material); |
- EXPECT_EQ(resource_id, copy_quad->resource_id); |
- EXPECT_EQ(premultiplied_alpha, copy_quad->premultiplied_alpha); |
- EXPECT_EQ(uv_top_left, copy_quad->uv_top_left); |
- EXPECT_EQ(uv_bottom_right, copy_quad->uv_bottom_right); |
- EXPECT_FLOAT_ARRAY_EQ(vertex_opacity, copy_quad->vertex_opacity, 4); |
- EXPECT_EQ(flipped, copy_quad->flipped); |
- EXPECT_EQ(nearest_neighbor, copy_quad->nearest_neighbor); |
-} |
- |
-TEST(DrawQuadTest, CopyTileDrawQuad) { |
- gfx::Rect opaque_rect(33, 44, 22, 33); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- unsigned resource_id = 104; |
- gfx::RectF tex_coord_rect(31.f, 12.f, 54.f, 20.f); |
- gfx::Size texture_size(85, 32); |
- bool swizzle_contents = true; |
- bool nearest_neighbor = true; |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_7_NEW(TileDrawQuad, |
- opaque_rect, |
- visible_rect, |
- resource_id, |
- tex_coord_rect, |
- texture_size, |
- swizzle_contents, |
- nearest_neighbor); |
- EXPECT_EQ(DrawQuad::TILED_CONTENT, copy_quad->material); |
- EXPECT_EQ(opaque_rect, copy_quad->opaque_rect); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(resource_id, copy_quad->resource_id); |
- EXPECT_EQ(tex_coord_rect, copy_quad->tex_coord_rect); |
- EXPECT_EQ(texture_size, copy_quad->texture_size); |
- EXPECT_EQ(swizzle_contents, copy_quad->swizzle_contents); |
- EXPECT_EQ(nearest_neighbor, copy_quad->nearest_neighbor); |
- |
- CREATE_QUAD_5_ALL(TileDrawQuad, |
- resource_id, |
- tex_coord_rect, |
- texture_size, |
- swizzle_contents, |
- nearest_neighbor); |
- EXPECT_EQ(DrawQuad::TILED_CONTENT, copy_quad->material); |
- EXPECT_EQ(resource_id, copy_quad->resource_id); |
- EXPECT_EQ(tex_coord_rect, copy_quad->tex_coord_rect); |
- EXPECT_EQ(texture_size, copy_quad->texture_size); |
- EXPECT_EQ(swizzle_contents, copy_quad->swizzle_contents); |
- EXPECT_EQ(nearest_neighbor, copy_quad->nearest_neighbor); |
-} |
- |
-TEST(DrawQuadTest, CopyYUVVideoDrawQuad) { |
- gfx::Rect opaque_rect(33, 47, 10, 12); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- gfx::RectF tex_coord_rect(0.0f, 0.0f, 0.75f, 0.5f); |
- gfx::Size tex_size(32, 68); |
- ResourceProvider::ResourceId y_plane_resource_id = 45; |
- ResourceProvider::ResourceId u_plane_resource_id = 532; |
- ResourceProvider::ResourceId v_plane_resource_id = 4; |
- ResourceProvider::ResourceId a_plane_resource_id = 63; |
- YUVVideoDrawQuad::ColorSpace color_space = YUVVideoDrawQuad::JPEG; |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_9_NEW(YUVVideoDrawQuad, opaque_rect, visible_rect, tex_coord_rect, |
- tex_size, y_plane_resource_id, u_plane_resource_id, |
- v_plane_resource_id, a_plane_resource_id, color_space); |
- EXPECT_EQ(DrawQuad::YUV_VIDEO_CONTENT, copy_quad->material); |
- EXPECT_EQ(opaque_rect, copy_quad->opaque_rect); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(tex_coord_rect, copy_quad->tex_coord_rect); |
- EXPECT_EQ(tex_size, copy_quad->tex_size); |
- EXPECT_EQ(y_plane_resource_id, copy_quad->y_plane_resource_id); |
- EXPECT_EQ(u_plane_resource_id, copy_quad->u_plane_resource_id); |
- EXPECT_EQ(v_plane_resource_id, copy_quad->v_plane_resource_id); |
- EXPECT_EQ(a_plane_resource_id, copy_quad->a_plane_resource_id); |
- EXPECT_EQ(color_space, copy_quad->color_space); |
- |
- CREATE_QUAD_7_ALL(YUVVideoDrawQuad, tex_coord_rect, tex_size, |
- y_plane_resource_id, u_plane_resource_id, |
- v_plane_resource_id, a_plane_resource_id, color_space); |
- EXPECT_EQ(DrawQuad::YUV_VIDEO_CONTENT, copy_quad->material); |
- EXPECT_EQ(tex_coord_rect, copy_quad->tex_coord_rect); |
- EXPECT_EQ(tex_size, copy_quad->tex_size); |
- EXPECT_EQ(y_plane_resource_id, copy_quad->y_plane_resource_id); |
- EXPECT_EQ(u_plane_resource_id, copy_quad->u_plane_resource_id); |
- EXPECT_EQ(v_plane_resource_id, copy_quad->v_plane_resource_id); |
- EXPECT_EQ(a_plane_resource_id, copy_quad->a_plane_resource_id); |
- EXPECT_EQ(color_space, copy_quad->color_space); |
-} |
- |
-TEST(DrawQuadTest, CopyPictureDrawQuad) { |
- gfx::Rect opaque_rect(33, 44, 22, 33); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- gfx::RectF tex_coord_rect(31.f, 12.f, 54.f, 20.f); |
- gfx::Size texture_size(85, 32); |
- bool nearest_neighbor = true; |
- ResourceFormat texture_format = RGBA_8888; |
- gfx::Rect content_rect(30, 40, 20, 30); |
- float contents_scale = 3.141592f; |
- scoped_refptr<RasterSource> raster_source = |
- FakePicturePileImpl::CreateEmptyPile(gfx::Size(100, 100), |
- gfx::Size(100, 100)); |
- CREATE_SHARED_STATE(); |
- |
- CREATE_QUAD_9_NEW(PictureDrawQuad, opaque_rect, visible_rect, tex_coord_rect, |
- texture_size, nearest_neighbor, texture_format, |
- content_rect, contents_scale, raster_source); |
- EXPECT_EQ(DrawQuad::PICTURE_CONTENT, copy_quad->material); |
- EXPECT_EQ(opaque_rect, copy_quad->opaque_rect); |
- EXPECT_EQ(visible_rect, copy_quad->visible_rect); |
- EXPECT_EQ(tex_coord_rect, copy_quad->tex_coord_rect); |
- EXPECT_EQ(texture_size, copy_quad->texture_size); |
- EXPECT_EQ(nearest_neighbor, copy_quad->nearest_neighbor); |
- EXPECT_EQ(texture_format, copy_quad->texture_format); |
- EXPECT_EQ(content_rect, copy_quad->content_rect); |
- EXPECT_EQ(contents_scale, copy_quad->contents_scale); |
- EXPECT_EQ(raster_source, copy_quad->raster_source); |
- |
- CREATE_QUAD_7_ALL(PictureDrawQuad, tex_coord_rect, texture_size, |
- nearest_neighbor, texture_format, content_rect, |
- contents_scale, raster_source); |
- EXPECT_EQ(DrawQuad::PICTURE_CONTENT, copy_quad->material); |
- EXPECT_EQ(tex_coord_rect, copy_quad->tex_coord_rect); |
- EXPECT_EQ(texture_size, copy_quad->texture_size); |
- EXPECT_EQ(nearest_neighbor, copy_quad->nearest_neighbor); |
- EXPECT_EQ(texture_format, copy_quad->texture_format); |
- EXPECT_EQ(content_rect, copy_quad->content_rect); |
- EXPECT_EQ(contents_scale, copy_quad->contents_scale); |
- EXPECT_EQ(raster_source, copy_quad->raster_source); |
-} |
- |
-class DrawQuadIteratorTest : public testing::Test { |
- protected: |
- ResourceProvider::ResourceId IncrementResourceId( |
- ResourceProvider::ResourceId id) { |
- ++num_resources_; |
- return id + 1; |
- } |
- |
- int IterateAndCount(DrawQuad* quad) { |
- num_resources_ = 0; |
- quad->IterateResources(base::Bind( |
- &DrawQuadIteratorTest::IncrementResourceId, base::Unretained(this))); |
- return num_resources_; |
- } |
- |
- private: |
- int num_resources_; |
-}; |
- |
-TEST_F(DrawQuadIteratorTest, CheckerboardDrawQuad) { |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- SkColor color = 0xfabb0011; |
- float scale = 3.2f; |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_3_NEW(CheckerboardDrawQuad, visible_rect, color, scale); |
- EXPECT_EQ(0, IterateAndCount(quad_new)); |
-} |
- |
-TEST_F(DrawQuadIteratorTest, DebugBorderDrawQuad) { |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- SkColor color = 0xfabb0011; |
- int width = 99; |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_3_NEW(DebugBorderDrawQuad, visible_rect, color, width); |
- EXPECT_EQ(0, IterateAndCount(quad_new)); |
-} |
- |
-TEST_F(DrawQuadIteratorTest, IOSurfaceDrawQuad) { |
- gfx::Rect opaque_rect(33, 47, 10, 12); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- gfx::Size size(58, 95); |
- ResourceProvider::ResourceId resource_id = 72; |
- IOSurfaceDrawQuad::Orientation orientation = IOSurfaceDrawQuad::UNFLIPPED; |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_5_NEW(IOSurfaceDrawQuad, |
- opaque_rect, |
- visible_rect, |
- size, |
- resource_id, |
- orientation); |
- EXPECT_EQ(resource_id, quad_new->io_surface_resource_id); |
- EXPECT_EQ(1, IterateAndCount(quad_new)); |
- EXPECT_EQ(resource_id + 1, quad_new->io_surface_resource_id); |
-} |
- |
-TEST_F(DrawQuadIteratorTest, RenderPassDrawQuad) { |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- RenderPassId render_pass_id(22, 64); |
- ResourceProvider::ResourceId mask_resource_id = 78; |
- gfx::Vector2dF mask_uv_scale(33.f, 19.f); |
- gfx::Size mask_texture_size(128, 134); |
- FilterOperations filters; |
- filters.Append(FilterOperation::CreateBlurFilter(1.f)); |
- gfx::Vector2dF filters_scale(2.f, 3.f); |
- FilterOperations background_filters; |
- background_filters.Append( |
- FilterOperation::CreateGrayscaleFilter(1.f)); |
- |
- RenderPassId copied_render_pass_id(235, 11); |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_NEW_RP(RenderPassDrawQuad, |
- visible_rect, |
- render_pass_id, |
- mask_resource_id, |
- mask_uv_scale, |
- mask_texture_size, |
- filters, |
- filters_scale, |
- background_filters, |
- copied_render_pass_id); |
- EXPECT_EQ(mask_resource_id, quad_new->mask_resource_id); |
- EXPECT_EQ(1, IterateAndCount(quad_new)); |
- EXPECT_EQ(mask_resource_id + 1, quad_new->mask_resource_id); |
- quad_new->mask_resource_id = 0; |
- EXPECT_EQ(0, IterateAndCount(quad_new)); |
- EXPECT_EQ(0u, quad_new->mask_resource_id); |
-} |
- |
-TEST_F(DrawQuadIteratorTest, SolidColorDrawQuad) { |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- SkColor color = 0x49494949; |
- bool force_anti_aliasing_off = false; |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_3_NEW( |
- SolidColorDrawQuad, visible_rect, color, force_anti_aliasing_off); |
- EXPECT_EQ(0, IterateAndCount(quad_new)); |
-} |
- |
-TEST_F(DrawQuadIteratorTest, StreamVideoDrawQuad) { |
- gfx::Rect opaque_rect(33, 47, 10, 12); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- ResourceProvider::ResourceId resource_id = 64; |
- gfx::Transform matrix = gfx::Transform(0.5, 0.25, 1, 0.75, 0, 1); |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_4_NEW( |
- StreamVideoDrawQuad, opaque_rect, visible_rect, resource_id, matrix); |
- EXPECT_EQ(resource_id, quad_new->resource_id); |
- EXPECT_EQ(1, IterateAndCount(quad_new)); |
- EXPECT_EQ(resource_id + 1, quad_new->resource_id); |
-} |
- |
-TEST_F(DrawQuadIteratorTest, SurfaceDrawQuad) { |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- SurfaceId surface_id(4321); |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_2_NEW(SurfaceDrawQuad, visible_rect, surface_id); |
- EXPECT_EQ(0, IterateAndCount(quad_new)); |
-} |
- |
-TEST_F(DrawQuadIteratorTest, TextureDrawQuad) { |
- gfx::Rect opaque_rect(33, 47, 10, 12); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- unsigned resource_id = 82; |
- bool premultiplied_alpha = true; |
- gfx::PointF uv_top_left(0.5f, 224.f); |
- gfx::PointF uv_bottom_right(51.5f, 260.f); |
- const float vertex_opacity[] = { 1.0f, 1.0f, 1.0f, 1.0f }; |
- bool flipped = true; |
- bool nearest_neighbor = true; |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_10_NEW(TextureDrawQuad, |
- opaque_rect, |
- visible_rect, |
- resource_id, |
- premultiplied_alpha, |
- uv_top_left, |
- uv_bottom_right, |
- SK_ColorTRANSPARENT, |
- vertex_opacity, |
- flipped, |
- nearest_neighbor); |
- EXPECT_EQ(resource_id, quad_new->resource_id); |
- EXPECT_EQ(1, IterateAndCount(quad_new)); |
- EXPECT_EQ(resource_id + 1, quad_new->resource_id); |
-} |
- |
-TEST_F(DrawQuadIteratorTest, TileDrawQuad) { |
- gfx::Rect opaque_rect(33, 44, 22, 33); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- unsigned resource_id = 104; |
- gfx::RectF tex_coord_rect(31.f, 12.f, 54.f, 20.f); |
- gfx::Size texture_size(85, 32); |
- bool swizzle_contents = true; |
- bool nearest_neighbor = true; |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_7_NEW(TileDrawQuad, |
- opaque_rect, |
- visible_rect, |
- resource_id, |
- tex_coord_rect, |
- texture_size, |
- swizzle_contents, |
- nearest_neighbor); |
- EXPECT_EQ(resource_id, quad_new->resource_id); |
- EXPECT_EQ(1, IterateAndCount(quad_new)); |
- EXPECT_EQ(resource_id + 1, quad_new->resource_id); |
-} |
- |
-TEST_F(DrawQuadIteratorTest, YUVVideoDrawQuad) { |
- gfx::Rect opaque_rect(33, 47, 10, 12); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- gfx::RectF tex_coord_rect(0.0f, 0.0f, 0.75f, 0.5f); |
- gfx::Size tex_size(32, 68); |
- ResourceProvider::ResourceId y_plane_resource_id = 45; |
- ResourceProvider::ResourceId u_plane_resource_id = 532; |
- ResourceProvider::ResourceId v_plane_resource_id = 4; |
- ResourceProvider::ResourceId a_plane_resource_id = 63; |
- YUVVideoDrawQuad::ColorSpace color_space = YUVVideoDrawQuad::JPEG; |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_9_NEW(YUVVideoDrawQuad, opaque_rect, visible_rect, tex_coord_rect, |
- tex_size, y_plane_resource_id, u_plane_resource_id, |
- v_plane_resource_id, a_plane_resource_id, color_space); |
- EXPECT_EQ(DrawQuad::YUV_VIDEO_CONTENT, copy_quad->material); |
- EXPECT_EQ(y_plane_resource_id, quad_new->y_plane_resource_id); |
- EXPECT_EQ(u_plane_resource_id, quad_new->u_plane_resource_id); |
- EXPECT_EQ(v_plane_resource_id, quad_new->v_plane_resource_id); |
- EXPECT_EQ(a_plane_resource_id, quad_new->a_plane_resource_id); |
- EXPECT_EQ(color_space, quad_new->color_space); |
- EXPECT_EQ(4, IterateAndCount(quad_new)); |
- EXPECT_EQ(y_plane_resource_id + 1, quad_new->y_plane_resource_id); |
- EXPECT_EQ(u_plane_resource_id + 1, quad_new->u_plane_resource_id); |
- EXPECT_EQ(v_plane_resource_id + 1, quad_new->v_plane_resource_id); |
- EXPECT_EQ(a_plane_resource_id + 1, quad_new->a_plane_resource_id); |
-} |
- |
-// Disabled until picture draw quad is supported for ubercomp: crbug.com/231715 |
-TEST_F(DrawQuadIteratorTest, DISABLED_PictureDrawQuad) { |
- gfx::Rect opaque_rect(33, 44, 22, 33); |
- gfx::Rect visible_rect(40, 50, 30, 20); |
- gfx::RectF tex_coord_rect(31.f, 12.f, 54.f, 20.f); |
- gfx::Size texture_size(85, 32); |
- bool nearest_neighbor = true; |
- ResourceFormat texture_format = RGBA_8888; |
- gfx::Rect content_rect(30, 40, 20, 30); |
- float contents_scale = 3.141592f; |
- scoped_refptr<RasterSource> raster_source = |
- FakePicturePileImpl::CreateEmptyPile(gfx::Size(100, 100), |
- gfx::Size(100, 100)); |
- |
- CREATE_SHARED_STATE(); |
- CREATE_QUAD_9_NEW(PictureDrawQuad, opaque_rect, visible_rect, tex_coord_rect, |
- texture_size, nearest_neighbor, texture_format, |
- content_rect, contents_scale, raster_source); |
- EXPECT_EQ(0, IterateAndCount(quad_new)); |
-} |
- |
-TEST(DrawQuadTest, LargestQuadType) { |
- size_t largest = 0; |
- |
- for (int i = 0; i <= DrawQuad::MATERIAL_LAST; ++i) { |
- switch (static_cast<DrawQuad::Material>(i)) { |
- case DrawQuad::CHECKERBOARD: |
- largest = std::max(largest, sizeof(CheckerboardDrawQuad)); |
- break; |
- case DrawQuad::DEBUG_BORDER: |
- largest = std::max(largest, sizeof(DebugBorderDrawQuad)); |
- break; |
- case DrawQuad::IO_SURFACE_CONTENT: |
- largest = std::max(largest, sizeof(IOSurfaceDrawQuad)); |
- break; |
- case DrawQuad::PICTURE_CONTENT: |
- largest = std::max(largest, sizeof(PictureDrawQuad)); |
- break; |
- case DrawQuad::TEXTURE_CONTENT: |
- largest = std::max(largest, sizeof(TextureDrawQuad)); |
- break; |
- case DrawQuad::RENDER_PASS: |
- largest = std::max(largest, sizeof(RenderPassDrawQuad)); |
- break; |
- case DrawQuad::SOLID_COLOR: |
- largest = std::max(largest, sizeof(SolidColorDrawQuad)); |
- break; |
- case DrawQuad::SURFACE_CONTENT: |
- largest = std::max(largest, sizeof(SurfaceDrawQuad)); |
- break; |
- case DrawQuad::TILED_CONTENT: |
- largest = std::max(largest, sizeof(TileDrawQuad)); |
- break; |
- case DrawQuad::STREAM_VIDEO_CONTENT: |
- largest = std::max(largest, sizeof(StreamVideoDrawQuad)); |
- break; |
- case DrawQuad::YUV_VIDEO_CONTENT: |
- largest = std::max(largest, sizeof(YUVVideoDrawQuad)); |
- break; |
- case DrawQuad::INVALID: |
- break; |
- } |
- } |
- EXPECT_EQ(LargestDrawQuadSize(), largest); |
- |
- if (!HasFailure()) |
- return; |
- |
- // On failure, output the size of all quads for debugging. |
- LOG(ERROR) << "largest " << largest; |
- LOG(ERROR) << "kLargestDrawQuad " << LargestDrawQuadSize(); |
- for (int i = 0; i <= DrawQuad::MATERIAL_LAST; ++i) { |
- switch (static_cast<DrawQuad::Material>(i)) { |
- case DrawQuad::CHECKERBOARD: |
- LOG(ERROR) << "CheckerboardDrawQuad " << sizeof(CheckerboardDrawQuad); |
- break; |
- case DrawQuad::DEBUG_BORDER: |
- LOG(ERROR) << "DebugBorderDrawQuad " << sizeof(DebugBorderDrawQuad); |
- break; |
- case DrawQuad::IO_SURFACE_CONTENT: |
- LOG(ERROR) << "IOSurfaceDrawQuad " << sizeof(IOSurfaceDrawQuad); |
- break; |
- case DrawQuad::PICTURE_CONTENT: |
- LOG(ERROR) << "PictureDrawQuad " << sizeof(PictureDrawQuad); |
- break; |
- case DrawQuad::TEXTURE_CONTENT: |
- LOG(ERROR) << "TextureDrawQuad " << sizeof(TextureDrawQuad); |
- break; |
- case DrawQuad::RENDER_PASS: |
- LOG(ERROR) << "RenderPassDrawQuad " << sizeof(RenderPassDrawQuad); |
- break; |
- case DrawQuad::SOLID_COLOR: |
- LOG(ERROR) << "SolidColorDrawQuad " << sizeof(SolidColorDrawQuad); |
- break; |
- case DrawQuad::SURFACE_CONTENT: |
- LOG(ERROR) << "SurfaceDrawQuad " << sizeof(SurfaceDrawQuad); |
- break; |
- case DrawQuad::TILED_CONTENT: |
- LOG(ERROR) << "TileDrawQuad " << sizeof(TileDrawQuad); |
- break; |
- case DrawQuad::STREAM_VIDEO_CONTENT: |
- LOG(ERROR) << "StreamVideoDrawQuad " << sizeof(StreamVideoDrawQuad); |
- break; |
- case DrawQuad::YUV_VIDEO_CONTENT: |
- LOG(ERROR) << "YUVVideoDrawQuad " << sizeof(YUVVideoDrawQuad); |
- break; |
- case DrawQuad::INVALID: |
- break; |
- } |
- } |
-} |
- |
-} // namespace |
-} // namespace cc |