aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests/ImageFilterCacheTest.cpp
diff options
context:
space:
mode:
authorGravatar robertphillips <robertphillips@google.com>2016-02-19 10:41:12 -0800
committerGravatar Commit bot <commit-bot@chromium.org>2016-02-19 10:41:13 -0800
commitcbc5bccebec983cdd7bea4f10373ec3af115def3 (patch)
tree957b4a2c57761ffb39faee2992def6674e8a16cc /tests/ImageFilterCacheTest.cpp
parentbe8c19e8d3deac9b9585c44b9a423912dd00a75a (diff)
Add GPU-backed SkImage case to ImageFilterCache unit test
Diffstat (limited to 'tests/ImageFilterCacheTest.cpp')
-rw-r--r--tests/ImageFilterCacheTest.cpp47
1 files changed, 39 insertions, 8 deletions
diff --git a/tests/ImageFilterCacheTest.cpp b/tests/ImageFilterCacheTest.cpp
index f2e662f56c..175d17c946 100644
--- a/tests/ImageFilterCacheTest.cpp
+++ b/tests/ImageFilterCacheTest.cpp
@@ -147,11 +147,9 @@ DEF_TEST(ImageFilterCache_RasterBacked, reporter) {
test_explicit_purging(reporter, fullImg, subsetImg);
}
-DEF_TEST(ImageFilterCache_ImageBacked, reporter) {
- SkBitmap srcBM = create_bm();
-
- SkAutoTUnref<SkImage> srcImage(SkImage::NewFromBitmap(srcBM));
+// Shared test code for both the raster and gpu-backed image cases
+static void test_image_backed(skiatest::Reporter* reporter, SkImage* srcImage) {
const SkIRect& full = SkIRect::MakeWH(kFullSize, kFullSize);
SkAutoTUnref<SkSpecialImage> fullImg(SkSpecialImage::NewFromImage(full, srcImage));
@@ -166,10 +164,18 @@ DEF_TEST(ImageFilterCache_ImageBacked, reporter) {
test_explicit_purging(reporter, fullImg, subsetImg);
}
+DEF_TEST(ImageFilterCache_ImageBackedRaster, reporter) {
+ SkBitmap srcBM = create_bm();
+
+ SkAutoTUnref<SkImage> srcImage(SkImage::NewFromBitmap(srcBM));
+
+ test_image_backed(reporter, srcImage);
+}
+
#if SK_SUPPORT_GPU
#include "GrContext.h"
-DEF_GPUTEST_FOR_RENDERING_CONTEXTS(ImageFilterCache_GPUBacked, reporter, context) {
+static GrTexture* create_texture(GrContext* context) {
SkBitmap srcBM = create_bm();
GrSurfaceDesc desc;
@@ -178,9 +184,34 @@ DEF_GPUTEST_FOR_RENDERING_CONTEXTS(ImageFilterCache_GPUBacked, reporter, context
desc.fWidth = kFullSize;
desc.fHeight = kFullSize;
- SkAutoTUnref<GrTexture> srcTexture(context->textureProvider()->createTexture(desc, false,
- srcBM.getPixels(),
- 0));
+ return context->textureProvider()->createTexture(desc, false, srcBM.getPixels(), 0);
+}
+
+DEF_GPUTEST_FOR_RENDERING_CONTEXTS(ImageFilterCache_ImageBackedGPU, reporter, context) {
+ SkAutoTUnref<GrTexture> srcTexture(create_texture(context));
+ if (!srcTexture) {
+ return;
+ }
+
+ GrBackendTextureDesc backendDesc;
+ backendDesc.fConfig = kSkia8888_GrPixelConfig;
+ backendDesc.fFlags = kNone_GrBackendTextureFlag;
+ backendDesc.fWidth = kFullSize;
+ backendDesc.fHeight = kFullSize;
+ backendDesc.fSampleCnt = 0;
+ backendDesc.fTextureHandle = srcTexture->getTextureHandle();
+ SkAutoTUnref<SkImage> srcImage(SkImage::NewFromTexture(context, backendDesc,
+ kPremul_SkAlphaType));
+ if (!srcImage) {
+ return;
+ }
+
+ test_image_backed(reporter, srcImage);
+}
+
+DEF_GPUTEST_FOR_RENDERING_CONTEXTS(ImageFilterCache_GPUBacked, reporter, context) {
+
+ SkAutoTUnref<GrTexture> srcTexture(create_texture(context));
if (!srcTexture) {
return;
}