Chromium Code Reviews| Index: tests/ImageNewShaderTest.cpp |
| diff --git a/tests/ImageNewShaderTest.cpp b/tests/ImageNewShaderTest.cpp |
| index c01fbe7ee8bdab01e60c612d3c65cfbfe549f18d..90405365820cde1dae2cb21032bcd1b7815a90e1 100644 |
| --- a/tests/ImageNewShaderTest.cpp |
| +++ b/tests/ImageNewShaderTest.cpp |
| @@ -16,12 +16,21 @@ |
| #include "Test.h" |
| -void testBitmapEquality(skiatest::Reporter* reporter, SkBitmap& bm1, SkBitmap& bm2) { |
| - SkAutoLockPixels lockBm1(bm1); |
| - SkAutoLockPixels lockBm2(bm2); |
| - |
| - REPORTER_ASSERT(reporter, bm1.getSize() == bm2.getSize()); |
| - REPORTER_ASSERT(reporter, 0 == memcmp(bm1.getPixels(), bm2.getPixels(), bm1.getSize())); |
| +void testBitmapEquality(skiatest::Reporter* reporter, const SkBitmap& src, const SkBitmap& dst, |
| + const char label[]) { |
| + SkAutoLockPixels lockBm1(src); |
| + SkAutoLockPixels lockBm2(dst); |
| + |
| + REPORTER_ASSERT(reporter, src.getSize() == dst.getSize()); |
| + if (memcmp(src.getPixels(), dst.getPixels(), dst.getSize())) { |
| + SkDebugf("testBitmapEquality %s\n", label); |
| + for (int y = 0; y < src.height(); ++y) { |
| + for (int x = 0; x < src.width(); ++x) { |
| + SkDebugf("(%d %d) src=%08X dst=%08X\n", x, y, src.getColor(x, y), dst.getColor(x, y)); |
| + } |
| + } |
| + REPORTER_ASSERT(reporter, false); |
| + } |
| } |
| void paintSource(SkSurface* sourceSurface) { |
| @@ -41,7 +50,8 @@ void paintSource(SkSurface* sourceSurface) { |
| sourceCanvas->drawRect(rect, paintColor); |
| } |
| -void runShaderTest(skiatest::Reporter* reporter, SkSurface* sourceSurface, SkSurface* destinationSurface, SkImageInfo& info) { |
| +void runShaderTest(skiatest::Reporter* reporter, SkSurface* sourceSurface, |
| + SkSurface* destinationSurface, SkImageInfo& info, const char label[]) { |
| paintSource(sourceSurface); |
| SkAutoTUnref<SkImage> sourceImage(sourceSurface->newImageSnapshot()); |
| @@ -58,14 +68,14 @@ void runShaderTest(skiatest::Reporter* reporter, SkSurface* sourceSurface, SkSur |
| SkIRect rect = info.bounds(); |
| - SkBitmap bmOrig; |
| - sourceSurface->getCanvas()->readPixels(rect, &bmOrig); |
| + SkBitmap srcBM; |
| + sourceSurface->getCanvas()->readPixels(rect, &srcBM); |
| - SkBitmap bm; |
| - destinationCanvas->readPixels(rect, &bm); |
| + SkBitmap dstBM; |
| + destinationCanvas->readPixels(rect, &dstBM); |
| - testBitmapEquality(reporter, bmOrig, bm); |
| + testBitmapEquality(reporter, srcBM, dstBM, label); |
| @@ -92,9 +102,15 @@ void runShaderTest(skiatest::Reporter* reporter, SkSurface* sourceSurface, SkSur |
| { |
| SkAutoLockPixels lockBm(bmt); |
| for (int y = 0; y < info.height(); y++) { |
| - REPORTER_ASSERT(reporter, 0xFFFF0000 == bmt.getColor(0, y)); |
| + if (0xFFFF0000 != bmt.getColor(0, y)) { |
| + SkDebugf("y = %d for %s\n", y, label); |
| + REPORTER_ASSERT(reporter, 0xFFFF0000 == bmt.getColor(0, y)); |
| + } |
| for (int x = 1; x < info.width(); x++) { |
| + if (0xFFDEDEDE != bmt.getColor(x, y)) { |
| + SkDebugf("(%d %d) color = %x for %s\n", x, y, bmt.getColor(x, y), label); |
| + } |
| REPORTER_ASSERT(reporter, 0xFFDEDEDE == bmt.getColor(x, y)); |
| } |
| } |
| @@ -107,12 +123,13 @@ DEF_TEST(ImageNewShader, reporter) { |
| SkAutoTUnref<SkSurface> sourceSurface(SkSurface::NewRaster(info)); |
| SkAutoTUnref<SkSurface> destinationSurface(SkSurface::NewRaster(info)); |
| - runShaderTest(reporter, sourceSurface.get(), destinationSurface.get(), info); |
| + runShaderTest(reporter, sourceSurface.get(), destinationSurface.get(), info, "raster"); |
| } |
| #if SK_SUPPORT_GPU |
| void gpuToGpu(skiatest::Reporter* reporter, GrContext* context) { |
| + // if we change these to 5,5, this fails on Nexus 7 w/ Tegra 3. See skbug.com/4365 |
|
reed1
2015/09/21 21:02:06
Will remove this comment.
|
| SkImageInfo info = SkImageInfo::MakeN32Premul(5, 5); |
| SkAutoTUnref<SkSurface> sourceSurface( |
| @@ -120,7 +137,7 @@ void gpuToGpu(skiatest::Reporter* reporter, GrContext* context) { |
| SkAutoTUnref<SkSurface> destinationSurface( |
| SkSurface::NewRenderTarget(context, SkSurface::kNo_Budgeted, info)); |
| - runShaderTest(reporter, sourceSurface.get(), destinationSurface.get(), info); |
| + runShaderTest(reporter, sourceSurface.get(), destinationSurface.get(), info, "gpu"); |
| } |
| void gpuToRaster(skiatest::Reporter* reporter, GrContext* context) { |
| @@ -130,7 +147,7 @@ void gpuToRaster(skiatest::Reporter* reporter, GrContext* context) { |
| SkSurface::kNo_Budgeted, info)); |
| SkAutoTUnref<SkSurface> destinationSurface(SkSurface::NewRaster(info)); |
| - runShaderTest(reporter, sourceSurface.get(), destinationSurface.get(), info); |
| + runShaderTest(reporter, sourceSurface.get(), destinationSurface.get(), info, "gpu-raster"); |
| } |
| void rasterToGpu(skiatest::Reporter* reporter, GrContext* context) { |
| @@ -140,7 +157,7 @@ void rasterToGpu(skiatest::Reporter* reporter, GrContext* context) { |
| SkAutoTUnref<SkSurface> destinationSurface(SkSurface::NewRenderTarget(context, |
| SkSurface::kNo_Budgeted, info)); |
| - runShaderTest(reporter, sourceSurface.get(), destinationSurface.get(), info); |
| + runShaderTest(reporter, sourceSurface.get(), destinationSurface.get(), info, "raster-gpu"); |
| } |
| DEF_GPUTEST(ImageNewShader_GPU, reporter, factory) { |