Chromium Code Reviews| Index: cc/gl_renderer_pixeltest.cc |
| diff --git a/cc/gl_renderer_pixeltest.cc b/cc/gl_renderer_pixeltest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7405c1a69d01edd46e500e5e2168511c7b32ee5e |
| --- /dev/null |
| +++ b/cc/gl_renderer_pixeltest.cc |
| @@ -0,0 +1,105 @@ |
| +// 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/gl_renderer.h" |
| + |
| +#include "base/file_util.h" |
| +#include "base/path_service.h" |
| +#include "cc/cc_paths.h" |
| +#include "cc/draw_quad.h" |
| +#include "cc/prioritized_resource_manager.h" |
| +#include "cc/resource_provider.h" |
| +#include "cc/test/pixel_test_graphics_context.h" |
| +#include "cc/test/pixel_test_utils.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| +#include "ui/gfx/codec/png_codec.h" |
| +#include "ui/gl/gl_implementation.h" |
| + |
| +namespace cc { |
| +namespace { |
| + |
| +class FakeRendererClient : public RendererClient { |
| + public: |
| + FakeRendererClient() |
| + { |
| + } |
| + |
| + // RendererClient methods. |
| + virtual const gfx::Size& deviceViewportSize() const OVERRIDE { |
| + static gfx::Size fakeSize(200, 200); |
|
danakj
2012/12/03 19:14:10
nit: fake_size
|
| + return fakeSize; |
| + } |
| + virtual const LayerTreeSettings& settings() const OVERRIDE { |
| + static LayerTreeSettings fakeSettings; |
|
danakj
2012/12/03 19:14:10
nit: fake_settings
|
| + return fakeSettings; |
| + } |
| + virtual void didLoseContext() OVERRIDE { } |
| + virtual void onSwapBuffersComplete() OVERRIDE { } |
| + virtual void setFullRootLayerDamage() OVERRIDE { } |
| + virtual void setManagedMemoryPolicy(const ManagedMemoryPolicy&) OVERRIDE {} |
| + virtual void enforceManagedMemoryPolicy( |
| + const ManagedMemoryPolicy&) OVERRIDE {} |
| + virtual bool hasImplThread() const OVERRIDE { return false; } |
| +}; |
| + |
| + |
| +class GLRendererPixeltest : public testing::Test { |
|
enne (OOO)
2012/12/03 21:40:29
Can you be consistent in your capitalization of Te
|
| + protected: |
| + GLRendererPixeltest() {} |
| + |
| + virtual void SetUp() { |
| + gfx::InitializeGLBindings(gfx::kGLImplementationOSMesaGL); |
| + context_ = PixelTestGraphicsContext::create(); |
| + resource_provider_ = ResourceProvider::create(context_.get()); |
| + renderer_ = GLRenderer::create(&fake_client_, resource_provider_.get()); |
| + } |
| + |
| + scoped_ptr<GraphicsContext> context_; |
| + FakeRendererClient fake_client_; |
| + scoped_ptr<ResourceProvider> resource_provider_; |
| + scoped_ptr<GLRenderer> renderer_; |
| +}; |
| + |
| +TEST_F(GLRendererPixeltest, simpleGreenRect) { |
| + gfx::Rect rect(0, 0, 200, 200); |
| + |
| + RenderPass::Id id(1, 1); |
| + scoped_ptr<RenderPass> pass = RenderPass::Create(); |
| + pass->SetNew(id, rect, rect, gfx::Transform()); |
| + |
| + scoped_ptr<SharedQuadState> shared_state = SharedQuadState::Create(); |
| + shared_state->SetAll(gfx::Transform(), |
| + rect, |
|
danakj
2012/12/03 19:14:10
can you use temp vars for these so we can see what
|
| + rect, |
| + rect, |
| + false, |
| + 1); |
| + |
| + scoped_ptr<SolidColorDrawQuad> color_quad = SolidColorDrawQuad::Create(); |
| + color_quad->SetNew(shared_state.get(), rect, SK_ColorGREEN); |
| + |
| + pass->quad_list.append(color_quad.PassAs<DrawQuad>()); |
| + |
| + RenderPassList pass_list; |
| + pass_list.push_back(pass.get()); |
| + RenderPassIdHashMap pass_map; |
| + pass_map.add(id, pass.PassAs<RenderPass>()); |
| + |
| + renderer_->drawFrame(pass_list, pass_map); |
| + |
| + SkBitmap bitmap; |
| + bitmap.setConfig(SkBitmap::kARGB_8888_Config, 200, 200); |
| + bitmap.allocPixels(); |
| + unsigned char* pixels = static_cast<unsigned char*>(bitmap.getPixels()); |
| + renderer_->getFramebufferPixels(pixels, gfx::Rect(0, 0, 200, 200)); |
| + |
| + FilePath test_data_dir; |
| + ASSERT_TRUE(PathService::Get(cc::DIR_TEST_DATA, &test_data_dir)); |
| + // test::WritePNGFile(bitmap, test_data_dir.AppendASCII("green.png")); |
| + EXPECT_TRUE(test::IsSameAsPNGFile(bitmap, |
| + test_data_dir.AppendASCII("green.png"))); |
| +} |
| + |
| +} // namespace |
| +} // namespace cc |