| Index: cc/surfaces/surface_aggregator_test_helpers.cc
|
| diff --git a/cc/surfaces/surface_aggregator_test_helpers.cc b/cc/surfaces/surface_aggregator_test_helpers.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..b21b37e28d64a63174d135b077e275bf4234c7c7
|
| --- /dev/null
|
| +++ b/cc/surfaces/surface_aggregator_test_helpers.cc
|
| @@ -0,0 +1,158 @@
|
| +// Copyright 2014 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/surfaces/surface_aggregator_test_helpers.h"
|
| +
|
| +#include "base/format_macros.h"
|
| +#include "base/strings/stringprintf.h"
|
| +#include "cc/layers/append_quads_data.h"
|
| +#include "cc/output/compositor_frame.h"
|
| +#include "cc/output/delegated_frame_data.h"
|
| +#include "cc/quads/render_pass_draw_quad.h"
|
| +#include "cc/quads/shared_quad_state.h"
|
| +#include "cc/quads/solid_color_draw_quad.h"
|
| +#include "cc/quads/surface_draw_quad.h"
|
| +#include "cc/surfaces/surface.h"
|
| +#include "cc/test/render_pass_test_common.h"
|
| +#include "cc/test/render_pass_test_utils.h"
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +#include "third_party/skia/include/core/SkXfermode.h"
|
| +
|
| +namespace cc {
|
| +namespace test {
|
| +
|
| +void AddTestSurfaceQuad(TestRenderPass* pass,
|
| + const gfx::Size& surface_size,
|
| + float opacity,
|
| + SurfaceId surface_id) {
|
| + gfx::Transform content_to_target_transform;
|
| + gfx::Size content_bounds = surface_size;
|
| + gfx::Rect visible_content_rect = gfx::Rect(surface_size);
|
| + gfx::Rect clip_rect = gfx::Rect(surface_size);
|
| + bool is_clipped = false;
|
| + SkXfermode::Mode blend_mode = SkXfermode::kSrcOver_Mode;
|
| +
|
| + SharedQuadState* shared_quad_state = pass->CreateAndAppendSharedQuadState();
|
| + shared_quad_state->SetAll(content_to_target_transform,
|
| + content_bounds,
|
| + visible_content_rect,
|
| + clip_rect,
|
| + is_clipped,
|
| + opacity,
|
| + blend_mode,
|
| + 0);
|
| +
|
| + SurfaceDrawQuad* surface_quad =
|
| + pass->CreateAndAppendDrawQuad<SurfaceDrawQuad>();
|
| + gfx::Rect quad_rect = gfx::Rect(surface_size);
|
| + surface_quad->SetNew(pass->shared_quad_state_list.back(),
|
| + gfx::Rect(surface_size),
|
| + gfx::Rect(surface_size),
|
| + surface_id);
|
| +}
|
| +void AddTestRenderPassQuad(TestRenderPass* pass, RenderPassId render_pass_id) {
|
| + gfx::Rect output_rect = gfx::Rect(0, 0, 5, 5);
|
| + SharedQuadState* shared_state = pass->CreateAndAppendSharedQuadState();
|
| + shared_state->SetAll(gfx::Transform(),
|
| + output_rect.size(),
|
| + output_rect,
|
| + output_rect,
|
| + false,
|
| + 1,
|
| + SkXfermode::kSrcOver_Mode,
|
| + 0);
|
| + RenderPassDrawQuad* quad =
|
| + pass->CreateAndAppendDrawQuad<RenderPassDrawQuad>();
|
| + quad->SetNew(shared_state,
|
| + output_rect,
|
| + output_rect,
|
| + render_pass_id,
|
| + 0,
|
| + gfx::Vector2dF(),
|
| + gfx::Size(),
|
| + FilterOperations(),
|
| + gfx::Vector2dF(),
|
| + FilterOperations());
|
| +}
|
| +
|
| +void AddQuadInPass(TestRenderPass* pass, Quad desc) {
|
| + switch (desc.material) {
|
| + case DrawQuad::SOLID_COLOR:
|
| + AddQuad(pass, gfx::Rect(0, 0, 5, 5), desc.color);
|
| + break;
|
| + case DrawQuad::SURFACE_CONTENT:
|
| + AddTestSurfaceQuad(pass, gfx::Size(5, 5), desc.opacity, desc.surface_id);
|
| + break;
|
| + case DrawQuad::RENDER_PASS:
|
| + AddTestRenderPassQuad(pass, desc.render_pass_id);
|
| + break;
|
| + default:
|
| + NOTREACHED();
|
| + }
|
| +}
|
| +
|
| +void AddPasses(RenderPassList* pass_list,
|
| + const gfx::Rect& output_rect,
|
| + Pass* passes,
|
| + size_t pass_count) {
|
| + gfx::Transform root_transform;
|
| + for (size_t i = 0; i < pass_count; ++i) {
|
| + Pass pass = passes[i];
|
| + TestRenderPass* test_pass =
|
| + AddRenderPass(pass_list, pass.id, output_rect, root_transform);
|
| + for (size_t j = 0; j < pass.quad_count; ++j) {
|
| + AddQuadInPass(test_pass, pass.quads[j]);
|
| + }
|
| + }
|
| +}
|
| +
|
| +void TestQuadMatchesExpectations(Quad expected_quad, const DrawQuad* quad) {
|
| + switch (expected_quad.material) {
|
| + case DrawQuad::SOLID_COLOR: {
|
| + ASSERT_EQ(DrawQuad::SOLID_COLOR, quad->material);
|
| +
|
| + const SolidColorDrawQuad* solid_color_quad =
|
| + SolidColorDrawQuad::MaterialCast(quad);
|
| +
|
| + EXPECT_EQ(expected_quad.color, solid_color_quad->color);
|
| + break;
|
| + }
|
| + case DrawQuad::RENDER_PASS: {
|
| + ASSERT_EQ(DrawQuad::RENDER_PASS, quad->material);
|
| +
|
| + const RenderPassDrawQuad* render_pass_quad =
|
| + RenderPassDrawQuad::MaterialCast(quad);
|
| +
|
| + EXPECT_EQ(expected_quad.render_pass_id, render_pass_quad->render_pass_id);
|
| + break;
|
| + }
|
| + default:
|
| + NOTREACHED();
|
| + break;
|
| + }
|
| +}
|
| +
|
| +void TestPassMatchesExpectations(Pass expected_pass, const RenderPass* pass) {
|
| + ASSERT_EQ(expected_pass.quad_count, pass->quad_list.size());
|
| + for (auto iter = pass->quad_list.cbegin(); iter != pass->quad_list.cend();
|
| + ++iter) {
|
| + SCOPED_TRACE(base::StringPrintf("Quad number %" PRIuS, iter.index()));
|
| + TestQuadMatchesExpectations(expected_pass.quads[iter.index()], *iter);
|
| + }
|
| +}
|
| +
|
| +void TestPassesMatchExpectations(Pass* expected_passes,
|
| + size_t expected_pass_count,
|
| + const RenderPassList* passes) {
|
| + ASSERT_EQ(expected_pass_count, passes->size());
|
| +
|
| + for (size_t i = 0; i < passes->size(); ++i) {
|
| + SCOPED_TRACE(base::StringPrintf("Pass number %" PRIuS, i));
|
| + RenderPass* pass = passes->at(i);
|
| + TestPassMatchesExpectations(expected_passes[i], pass);
|
| + }
|
| +}
|
| +
|
| +} // namespace test
|
| +} // namespace cc
|
|
|