Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1851)

Unified Diff: skia/ext/platform_canvas_unittest.cc

Issue 2340823002: Turn on more of the platform_canvas_unittests (Closed)
Patch Set: Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: skia/ext/platform_canvas_unittest.cc
diff --git a/skia/ext/platform_canvas_unittest.cc b/skia/ext/platform_canvas_unittest.cc
index 136addee2d06a569a02f10f8095c86b58c5f1a34..8f30a5c2b071098f93e9a07298d602c2aeb31069 100644
--- a/skia/ext/platform_canvas_unittest.cc
+++ b/skia/ext/platform_canvas_unittest.cc
@@ -38,7 +38,12 @@ namespace skia {
namespace {
-#if defined(OS_WIN)
+// Uses DstATop transfer mode with SK_ColorBLACK 0xff000000:
+// the destination pixel will end up with 0xff alpha
+// if it was transparent black (0x0) before the blend,
+// it will be set to opaque black (0xff000000).
+// if it has nonzero alpha before the blend,
+// it will retain its color.
void MakeOpaque(SkCanvas* canvas, int x, int y, int width, int height) {
if (width <= 0 || height <= 0)
return;
@@ -51,7 +56,6 @@ void MakeOpaque(SkCanvas* canvas, int x, int y, int width, int height) {
paint.setXfermodeMode(SkXfermode::kDstATop_Mode);
canvas->drawRect(rect, paint);
}
-#endif
bool IsOfColor(const SkBitmap& bitmap, int x, int y, uint32_t color) {
// For masking out the alpha values.
@@ -276,9 +280,7 @@ TEST(PlatformCanvas, FillLayer) {
{
LayerSaver layer(*canvas, kLayerX, kLayerY, kLayerW, kLayerH);
DrawNativeRect(*canvas, 0, 0, 100, 100);
-#if defined(OS_WIN)
MakeOpaque(canvas.get(), 0, 0, 100, 100);
-#endif
}
EXPECT_TRUE(VerifyBlackRect(*canvas, kLayerX, kLayerY, kLayerW, kLayerH));
@@ -287,9 +289,7 @@ TEST(PlatformCanvas, FillLayer) {
{
LayerSaver layer(*canvas, kLayerX, kLayerY, kLayerW, kLayerH);
DrawNativeRect(*canvas, kInnerX, kInnerY, kInnerW, kInnerH);
-#if defined(OS_WIN)
MakeOpaque(canvas.get(), kInnerX, kInnerY, kInnerW, kInnerH);
-#endif
}
EXPECT_TRUE(VerifyBlackRect(*canvas, kInnerX, kInnerY, kInnerW, kInnerH));
@@ -300,9 +300,7 @@ TEST(PlatformCanvas, FillLayer) {
canvas->save();
AddClip(*canvas, kInnerX, kInnerY, kInnerW, kInnerH);
DrawNativeRect(*canvas, 0, 0, 100, 100);
-#if defined(OS_WIN)
MakeOpaque(canvas.get(), kInnerX, kInnerY, kInnerW, kInnerH);
-#endif
canvas->restore();
}
EXPECT_TRUE(VerifyBlackRect(*canvas, kInnerX, kInnerY, kInnerW, kInnerH));
@@ -314,16 +312,12 @@ TEST(PlatformCanvas, FillLayer) {
{
LayerSaver layer(*canvas, kLayerX, kLayerY, kLayerW, kLayerH);
DrawNativeRect(*canvas, 0, 0, 100, 100);
-#if defined(OS_WIN)
MakeOpaque(canvas.get(), 0, 0, 100, 100);
-#endif
}
canvas->restore();
EXPECT_TRUE(VerifyBlackRect(*canvas, kInnerX, kInnerY, kInnerW, kInnerH));
}
-#if !defined(USE_AURA) // http://crbug.com/154358
-
// Test that translation + make layer works properly.
TEST(PlatformCanvas, TranslateLayer) {
// Create the canvas initialized to opaque white.
@@ -337,9 +331,7 @@ TEST(PlatformCanvas, TranslateLayer) {
{
LayerSaver layer(*canvas, kLayerX, kLayerY, kLayerW, kLayerH);
DrawNativeRect(*canvas, 0, 0, 100, 100);
-#if defined(OS_WIN)
MakeOpaque(canvas.get(), 0, 0, 100, 100);
-#endif
}
canvas->restore();
EXPECT_TRUE(VerifyBlackRect(*canvas, kLayerX + 1, kLayerY + 1,
@@ -352,9 +344,7 @@ TEST(PlatformCanvas, TranslateLayer) {
{
LayerSaver layer(*canvas, kLayerX, kLayerY, kLayerW, kLayerH);
DrawNativeRect(*canvas, kInnerX, kInnerY, kInnerW, kInnerH);
-#if defined(OS_WIN)
MakeOpaque(canvas.get(), kInnerX, kInnerY, kInnerW, kInnerH);
-#endif
}
canvas->restore();
EXPECT_TRUE(VerifyBlackRect(*canvas, kInnerX + 1, kInnerY + 1,
@@ -367,9 +357,7 @@ TEST(PlatformCanvas, TranslateLayer) {
LayerSaver layer(*canvas, kLayerX, kLayerY, kLayerW, kLayerH);
canvas->translate(1, 1);
DrawNativeRect(*canvas, kInnerX, kInnerY, kInnerW, kInnerH);
-#if defined(OS_WIN)
MakeOpaque(canvas.get(), kInnerX, kInnerY, kInnerW, kInnerH);
-#endif
}
canvas->restore();
EXPECT_TRUE(VerifyBlackRect(*canvas, kInnerX + 1, kInnerY + 1,
@@ -385,9 +373,7 @@ TEST(PlatformCanvas, TranslateLayer) {
canvas->translate(1, 1);
AddClip(*canvas, kInnerX + 1, kInnerY + 1, kInnerW - 1, kInnerH - 1);
DrawNativeRect(*canvas, 0, 0, 100, 100);
-#if defined(OS_WIN)
MakeOpaque(canvas.get(), kLayerX, kLayerY, kLayerW, kLayerH);
-#endif
}
canvas->restore();
EXPECT_TRUE(VerifyBlackRect(*canvas, kInnerX + 3, kInnerY + 3,
@@ -395,7 +381,7 @@ TEST(PlatformCanvas, TranslateLayer) {
// TODO(dglazkov): Figure out why this fails on Mac (antialiased clipping?),
// modify test and remove this guard.
-#if !defined(OS_MACOSX)
+#if !defined(OS_MACOSX) && !defined(USE_AURA)
// Translate both before and after, and have a path clip.
canvas->drawColor(SK_ColorWHITE);
canvas->save();
@@ -414,9 +400,7 @@ TEST(PlatformCanvas, TranslateLayer) {
canvas->clipPath(path);
DrawNativeRect(*canvas, 0, 0, 100, 100);
-#if defined(OS_WIN)
MakeOpaque(canvas.get(), kLayerX, kLayerY, kLayerW, kLayerH);
-#endif
}
canvas->restore();
EXPECT_TRUE(VerifyRoundedRect(*canvas, SK_ColorWHITE, SK_ColorBLACK,
@@ -424,6 +408,4 @@ TEST(PlatformCanvas, TranslateLayer) {
#endif
}
-#endif // #if !defined(USE_AURA)
-
} // namespace skia
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698