Chromium Code Reviews| Index: skia/ext/skia_utils_mac_unittest.mm |
| diff --git a/skia/ext/skia_utils_mac_unittest.mm b/skia/ext/skia_utils_mac_unittest.mm |
| index 1726c4a1bdc5717847032af64de2e1d85ded66f5..b9ab54c1ba6d9bf80951bc467ab0204d288834a8 100644 |
| --- a/skia/ext/skia_utils_mac_unittest.mm |
| +++ b/skia/ext/skia_utils_mac_unittest.mm |
| @@ -9,39 +9,60 @@ namespace { |
| class SkiaUtilsMacTest : public testing::Test { |
| public: |
| + // Creates a red or blue bitmap. |
| + SkBitmap CreateSkBitmap(int width, int height, bool isred, bool tfbit); |
| + |
| + // Creates a red or blue image. |
| + NSImage* CreateNSImage(int width, int height, bool isred); |
| + |
| + // Checks that the given bitmap rep is actually red or blue. |
| + void TestImageRep(NSBitmapImageRep* imageRep, bool isred); |
| + |
| + // Checks that the given bitmap is actually red or blue. |
| + void TestSkBitmap(const SkBitmap& bitmap, bool isred); |
| + |
| // If not red, is blue. |
| // If not tfbit (twenty-four-bit), is 444. |
| void ShapeHelper(int width, int height, bool isred, bool tfbit); |
| }; |
| -void SkiaUtilsMacTest::ShapeHelper(int width, int height, |
| - bool isred, bool tfbit) { |
| - SkBitmap thing; |
| +SkBitmap SkiaUtilsMacTest::CreateSkBitmap(int width, int height, |
| + bool isred, bool tfbit) { |
| + SkBitmap bitmap; |
| if (tfbit) |
| - thing.setConfig(SkBitmap::kARGB_8888_Config, width, height); |
| + bitmap.setConfig(SkBitmap::kARGB_8888_Config, width, height); |
| else |
| - thing.setConfig(SkBitmap::kARGB_4444_Config, width, height); |
| - thing.allocPixels(); |
| + bitmap.setConfig(SkBitmap::kARGB_4444_Config, width, height); |
| + bitmap.allocPixels(); |
| if (isred) |
| - thing.eraseRGB(0xff, 0, 0); |
| + bitmap.eraseRGB(0xff, 0, 0); |
| else |
| - thing.eraseRGB(0, 0, 0xff); |
| + bitmap.eraseRGB(0, 0, 0xff); |
| - // Confirm size |
| - NSImage* image = gfx::SkBitmapToNSImage(thing); |
| - EXPECT_DOUBLE_EQ([image size].width, (double)width); |
| - EXPECT_DOUBLE_EQ([image size].height, (double)height); |
| + return bitmap; |
| +} |
| - // Get the color of a pixel and make sure it looks fine |
| +NSImage* SkiaUtilsMacTest::CreateNSImage(int width, int height, bool isred) { |
| + NSImage* image = [[[NSImage alloc] initWithSize:NSMakeSize(width, height)] |
| + autorelease]; |
| [image lockFocus]; |
| + if (isred) |
| + [[NSColor colorWithDeviceRed:1.0 green:0.0 blue:0.0 alpha:1.0] set]; |
| + else |
| + [[NSColor colorWithDeviceRed:0.0 green:0.0 blue:1.0 alpha:1.0] set]; |
| + NSRectFill(NSMakeRect(0, 0, width, height)); |
| + [image unlockFocus]; |
| + return image; |
| +} |
| - int x = width > 17 ? 17 : 0; |
| - int y = height > 17 ? 17 : 0; |
| - NSColor* color = NSReadPixel(NSMakePoint(x, y)); |
| +void SkiaUtilsMacTest::TestImageRep(NSBitmapImageRep* imageRep, bool isred) { |
| + // Get the color of a pixel and make sure it looks fine |
| + int x = [imageRep size].width > 17 ? 17 : 0; |
| + int y = [imageRep size].height > 17 ? 17 : 0; |
| + NSColor* color = [imageRep colorAtX:x y:y]; |
| CGFloat red = 0, green = 0, blue = 0, alpha = 0; |
| - [image unlockFocus]; |
| // SkBitmapToNSImage returns a bitmap in the calibrated color space (sRGB), |
| // while NSReadPixel returns a color in the device color space. Convert back |
| @@ -52,14 +73,45 @@ void SkiaUtilsMacTest::ShapeHelper(int width, int height, |
| // Be tolerant of floating point rounding and lossy color space conversions. |
| if (isred) { |
| - EXPECT_GT(red, 0.95); |
| - EXPECT_LT(blue, 0.05); |
| + EXPECT_NEAR(red, 1.0, 0.025); |
| + EXPECT_NEAR(blue, 0.0, 0.025); |
| + } else { |
| + EXPECT_NEAR(red, 0.0, 0.025); |
| + EXPECT_NEAR(blue, 1.0, 0.025); |
| + } |
| + EXPECT_NEAR(green, 0.0, 0.025); |
| + EXPECT_NEAR(alpha, 1.0, 0.025); |
| +} |
| + |
| +void SkiaUtilsMacTest::TestSkBitmap(const SkBitmap& bitmap, bool isred) { |
| + int x = bitmap.width() > 17 ? 17 : 0; |
| + int y = bitmap.height() > 17 ? 17 : 0; |
| + SkColor color = bitmap.getColor(x, y); |
| + |
| + if (isred) { |
| + EXPECT_EQ(255u, SkColorGetR(color)); |
| + EXPECT_EQ(0u, SkColorGetB(color)); |
| } else { |
| - EXPECT_LT(red, 0.05); |
| - EXPECT_GT(blue, 0.95); |
| + EXPECT_EQ(0u, SkColorGetR(color)); |
| + EXPECT_EQ(255u, SkColorGetB(color)); |
| } |
| - EXPECT_LT(green, 0.05); |
| - EXPECT_GT(alpha, 0.95); |
| + EXPECT_EQ(0u, SkColorGetG(color)); |
| + EXPECT_EQ(255u, SkColorGetA(color)); |
| +} |
| + |
| +void SkiaUtilsMacTest::ShapeHelper(int width, int height, |
| + bool isred, bool tfbit) { |
| + SkBitmap thing(CreateSkBitmap(width, height, isred, tfbit)); |
| + |
| + // Confirm size |
| + NSImage* image = gfx::SkBitmapToNSImage(thing); |
| + EXPECT_DOUBLE_EQ([image size].width, (double)width); |
| + EXPECT_DOUBLE_EQ([image size].height, (double)height); |
| + |
| + EXPECT_TRUE([[image representations] count] == 1); |
| + EXPECT_TRUE([[[image representations] lastObject] |
| + isKindOfClass:[NSBitmapImageRep class]]); |
| + TestImageRep([[image representations] lastObject], isred); |
| } |
| TEST_F(SkiaUtilsMacTest, BitmapToNSImage_RedSquare64x64) { |
| @@ -74,4 +126,49 @@ TEST_F(SkiaUtilsMacTest, BitmapToNSImage_BlueRectangle444) { |
| ShapeHelper(200, 200, false, false); |
| } |
| +TEST_F(SkiaUtilsMacTest, MultipleBitmapsToNSImage) { |
| + int redWidth = 10; |
|
Robert Sesek
2011/04/19 20:53:18
nit: under_scores
|
| + int redHeight = 15; |
| + int blueWidth = 20; |
| + int blueHeight = 30; |
| + |
| + SkBitmap redBitmap(CreateSkBitmap(redWidth, redHeight, true, true)); |
| + SkBitmap blueBitmap(CreateSkBitmap(blueWidth, blueHeight, false, true)); |
| + std::vector<const SkBitmap*> bitmaps; |
| + bitmaps.push_back(&redBitmap); |
| + bitmaps.push_back(&blueBitmap); |
| + |
| + NSImage* image = gfx::SkBitmapsToNSImage(bitmaps); |
| + |
| + // Image size should be the same as the smallest bitmap. |
| + EXPECT_DOUBLE_EQ(redWidth, [image size].width); |
| + EXPECT_DOUBLE_EQ(redHeight, [image size].height); |
| + |
| + EXPECT_EQ(2u, [[image representations] count]); |
| + |
| + for (NSBitmapImageRep* imageRep in [image representations]) { |
| + NSBitmapImageRep* imageRep = [[image representations] objectAtIndex:0]; |
| + bool isred = [imageRep size].width == redWidth; |
| + if (isred) { |
| + EXPECT_DOUBLE_EQ(redHeight, [imageRep size].height); |
| + } else { |
| + EXPECT_DOUBLE_EQ(blueWidth, [imageRep size].width); |
| + EXPECT_DOUBLE_EQ(blueHeight, [imageRep size].height); |
| + } |
| + TestImageRep(imageRep, isred); |
| + } |
| +} |
| + |
| +TEST_F(SkiaUtilsMacTest, NSImageRepToSkBitmap) { |
| + int width = 10; |
| + int height = 15; |
| + bool isred = true; |
| + |
| + NSImage* image = CreateNSImage(width, height, isred); |
| + EXPECT_EQ(1u, [[image representations] count]); |
| + NSBitmapImageRep* imageRep = [[image representations] lastObject]; |
| + SkBitmap bitmap(gfx::NSImageRepToSkBitmap(imageRep, [image size], false)); |
| + TestSkBitmap(bitmap, isred); |
| +} |
| + |
| } // namespace |