summaryrefslogtreecommitdiffstats
path: root/cc/CCScopedTextureTest.cpp
diff options
context:
space:
mode:
authorjamesr@chromium.org <jamesr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-08-25 00:09:14 +0000
committerjamesr@chromium.org <jamesr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-08-25 00:09:14 +0000
commit94f206c1c75eb8cc4df2225a1c5c9c7b6fc96679 (patch)
tree530f51d5c75459999e4adf2a6895884ce1c15ce0 /cc/CCScopedTextureTest.cpp
parent56235947f2b023fc63cfad692c56df4e92199848 (diff)
downloadchromium_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.cpp108
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());
+}
+
+}