diff options
author | jamesr@chromium.org <jamesr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-08-25 00:09:14 +0000 |
---|---|---|
committer | jamesr@chromium.org <jamesr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-08-25 00:09:14 +0000 |
commit | 94f206c1c75eb8cc4df2225a1c5c9c7b6fc96679 (patch) | |
tree | 530f51d5c75459999e4adf2a6895884ce1c15ce0 /cc/CCScopedTextureTest.cpp | |
parent | 56235947f2b023fc63cfad692c56df4e92199848 (diff) | |
download | chromium_src-94f206c1c75eb8cc4df2225a1c5c9c7b6fc96679.zip chromium_src-94f206c1c75eb8cc4df2225a1c5c9c7b6fc96679.tar.gz chromium_src-94f206c1c75eb8cc4df2225a1c5c9c7b6fc96679.tar.bz2 |
Here are gyp targets and stubs for compiling libcc and the webkit_compositor bindings in chromium. Everything is guarded behind the off-by-default use_libcc_for_compositor gyp variable. I haven't included the actual code here, but there are scripts to sync. I plan to land + manually sync the code into place until we're ready to flip the gyp switch.
Snapshot from r126652
BUG=
Review URL: https://chromiumcodereview.appspot.com/10828381
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@153354 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'cc/CCScopedTextureTest.cpp')
-rw-r--r-- | cc/CCScopedTextureTest.cpp | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/cc/CCScopedTextureTest.cpp b/cc/CCScopedTextureTest.cpp new file mode 100644 index 0000000..b39efca --- /dev/null +++ b/cc/CCScopedTextureTest.cpp @@ -0,0 +1,108 @@ +// 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 "config.h" + +#include "CCScopedTexture.h" + +#include "CCRenderer.h" +#include "CCSingleThreadProxy.h" // For DebugScopedSetImplThread +#include "CCTiledLayerTestCommon.h" +#include "FakeCCGraphicsContext.h" +#include "GraphicsContext3D.h" +#include <gtest/gtest.h> + +using namespace WebCore; +using namespace WebKit; +using namespace WebKitTests; + +namespace { + +TEST(CCScopedTextureTest, NewScopedTexture) +{ + OwnPtr<CCGraphicsContext> context(createFakeCCGraphicsContext()); + DebugScopedSetImplThread implThread; + OwnPtr<CCResourceProvider> resourceProvider(CCResourceProvider::create(context.get())); + OwnPtr<CCScopedTexture> texture = CCScopedTexture::create(resourceProvider.get()); + + // New scoped textures do not hold a texture yet. + EXPECT_EQ(0u, texture->id()); + + // New scoped textures do not have a size yet. + EXPECT_EQ(IntSize(), texture->size()); + EXPECT_EQ(0u, texture->bytes()); +} + +TEST(CCScopedTextureTest, CreateScopedTexture) +{ + OwnPtr<CCGraphicsContext> context(createFakeCCGraphicsContext()); + DebugScopedSetImplThread implThread; + OwnPtr<CCResourceProvider> resourceProvider(CCResourceProvider::create(context.get())); + OwnPtr<CCScopedTexture> texture = CCScopedTexture::create(resourceProvider.get()); + texture->allocate(CCRenderer::ImplPool, IntSize(30, 30), GraphicsContext3D::RGBA, CCResourceProvider::TextureUsageAny); + + // The texture has an allocated byte-size now. + size_t expectedBytes = 30 * 30 * 4; + EXPECT_EQ(expectedBytes, texture->bytes()); + + EXPECT_LT(0u, texture->id()); + EXPECT_EQ(GraphicsContext3D::RGBA, texture->format()); + EXPECT_EQ(IntSize(30, 30), texture->size()); +} + +TEST(CCScopedTextureTest, ScopedTextureIsDeleted) +{ + OwnPtr<CCGraphicsContext> context(createFakeCCGraphicsContext()); + DebugScopedSetImplThread implThread; + OwnPtr<CCResourceProvider> resourceProvider(CCResourceProvider::create(context.get())); + + { + OwnPtr<CCScopedTexture> texture = CCScopedTexture::create(resourceProvider.get()); + + EXPECT_EQ(0u, resourceProvider->numResources()); + texture->allocate(CCRenderer::ImplPool, IntSize(30, 30), GraphicsContext3D::RGBA, CCResourceProvider::TextureUsageAny); + EXPECT_LT(0u, texture->id()); + EXPECT_EQ(1u, resourceProvider->numResources()); + } + + EXPECT_EQ(0u, resourceProvider->numResources()); + + { + OwnPtr<CCScopedTexture> texture = CCScopedTexture::create(resourceProvider.get()); + EXPECT_EQ(0u, resourceProvider->numResources()); + texture->allocate(CCRenderer::ImplPool, IntSize(30, 30), GraphicsContext3D::RGBA, CCResourceProvider::TextureUsageAny); + EXPECT_LT(0u, texture->id()); + EXPECT_EQ(1u, resourceProvider->numResources()); + texture->free(); + EXPECT_EQ(0u, resourceProvider->numResources()); + } +} + +TEST(CCScopedTextureTest, LeakScopedTexture) +{ + OwnPtr<CCGraphicsContext> context(createFakeCCGraphicsContext()); + DebugScopedSetImplThread implThread; + OwnPtr<CCResourceProvider> resourceProvider(CCResourceProvider::create(context.get())); + + { + OwnPtr<CCScopedTexture> texture = CCScopedTexture::create(resourceProvider.get()); + + EXPECT_EQ(0u, resourceProvider->numResources()); + texture->allocate(CCRenderer::ImplPool, IntSize(30, 30), GraphicsContext3D::RGBA, CCResourceProvider::TextureUsageAny); + EXPECT_LT(0u, texture->id()); + EXPECT_EQ(1u, resourceProvider->numResources()); + + texture->leak(); + EXPECT_EQ(0u, texture->id()); + EXPECT_EQ(1u, resourceProvider->numResources()); + + texture->free(); + EXPECT_EQ(0u, texture->id()); + EXPECT_EQ(1u, resourceProvider->numResources()); + } + + EXPECT_EQ(1u, resourceProvider->numResources()); +} + +} |