Update CodexTest to test valid_alpha.
authorscroggo <scroggo@chromium.org>
Wed, 12 Aug 2015 15:31:44 +0000 (08:31 -0700)
committerCommit bot <commit-bot@chromium.org>
Wed, 12 Aug 2015 15:31:44 +0000 (08:31 -0700)
Add a static function to CodexTest, which consolidates decoding,
comparing to an expected SkCodec::Result, and optionally comparing to a
digest.

Test decoding non-opaque to opaque (fails) and premul to unpremul/vice
versa (succeeds).

BUG=skia:3475

Review URL: https://codereview.chromium.org/1277253003

src/codec/SkCodec_wbmp.cpp
tests/CodexTest.cpp

index 52535e1f029a2c065c0a04fc3c8690b4398ce8e3..6f98294fc65f3cc950b68c255ac9978f8ac428c0 100644 (file)
@@ -120,6 +120,10 @@ SkCodec::Result SkWbmpCodec::onGetPixels(const SkImageInfo& info,
         return kInvalidScale;
     }
 
+    if (!valid_alpha(info.alphaType(), this->getInfo().alphaType())) {
+        return SkCodec::kInvalidConversion;
+    }
+
     // Prepare a color table if necessary
     setup_color_table(info.colorType(), ctable, ctableCount);
 
@@ -200,6 +204,10 @@ public:
             return SkCodec::kInvalidScale;
         }
 
+        if (!valid_alpha(dstInfo.alphaType(), this->getInfo().alphaType())) {
+            return SkCodec::kInvalidConversion;
+        }
+
         // Fill in the color table
         setup_color_table(dstInfo.colorType(), inputColorTable, inputColorCount);
 
index f3137a88bb52e9685e5895bc15eb88ac06ebe142..95cd5635445ca6fa62dd378c7893e46ad58a0996 100644 (file)
@@ -42,6 +42,26 @@ static void compare_to_good_digest(skiatest::Reporter* r, const SkMD5::Digest& g
     REPORTER_ASSERT(r, digest == goodDigest);
 }
 
+/**
+ *  Test decoding an SkCodec to a particular SkImageInfo.
+ *
+ *  Calling getPixels(info) should return expectedResult, and if goodDigest is non NULL,
+ *  the resulting decode should match.
+ */
+static void test_info(skiatest::Reporter* r, SkCodec* codec, const SkImageInfo& info,
+                      SkCodec::Result expectedResult, const SkMD5::Digest* goodDigest) {
+    SkBitmap bm;
+    bm.allocPixels(info);
+    SkAutoLockPixels autoLockPixels(bm);
+
+    SkCodec::Result result = codec->getPixels(info, bm.getPixels(), bm.rowBytes());
+    REPORTER_ASSERT(r, result == expectedResult);
+
+    if (goodDigest) {
+        compare_to_good_digest(r, *goodDigest, bm);
+    }
+}
+
 SkIRect generate_random_subset(SkRandom* rand, int w, int h) {
     SkIRect rect;
     do {
@@ -86,14 +106,32 @@ static void check(skiatest::Reporter* r,
     SkMD5::Digest digest;
     md5(bm, &digest);
 
-    bm.eraseColor(SK_ColorYELLOW);
-
-    result =
-        codec->getPixels(info, bm.getPixels(), bm.rowBytes(), NULL, NULL, NULL);
-
-    REPORTER_ASSERT(r, result == SkCodec::kSuccess);
     // verify that re-decoding gives the same result.
-    compare_to_good_digest(r, digest, bm);
+    test_info(r, codec, info, SkCodec::kSuccess, &digest);
+
+    {
+        // Check alpha type conversions
+        if (info.alphaType() == kOpaque_SkAlphaType) {
+            test_info(r, codec, info.makeAlphaType(kUnpremul_SkAlphaType),
+                      SkCodec::kInvalidConversion, NULL);
+            test_info(r, codec, info.makeAlphaType(kPremul_SkAlphaType),
+                      SkCodec::kInvalidConversion, NULL);
+        } else {
+            // Decoding to opaque should fail
+            test_info(r, codec, info.makeAlphaType(kOpaque_SkAlphaType),
+                      SkCodec::kInvalidConversion, NULL);
+            SkAlphaType otherAt = info.alphaType();
+            if (kPremul_SkAlphaType == otherAt) {
+                otherAt = kUnpremul_SkAlphaType;
+            } else {
+                otherAt = kPremul_SkAlphaType;
+            }
+            // The other non-opaque alpha type should always succeed, but not match.
+            test_info(r, codec, info.makeAlphaType(otherAt), SkCodec::kSuccess, NULL);
+        }
+    }
+
+    // Scanline decoding follows.
 
     stream.reset(resource(path));
     SkAutoTDelete<SkScanlineDecoder> scanlineDecoder(