Index: media/base/yuv_convert_unittest.cc |
diff --git a/media/base/yuv_convert_unittest.cc b/media/base/yuv_convert_unittest.cc |
index 1ac2a2d17cafa5738bacb2f84d92ee1dfacb5231..f41a968593fe99b132fd51ef98f65063e9d6d205 100644 |
--- a/media/base/yuv_convert_unittest.cc |
+++ b/media/base/yuv_convert_unittest.cc |
@@ -76,6 +76,14 @@ static void ReadYUY2Data(scoped_ptr<uint8[]>* data) { |
ReadData(FILE_PATH_LITERAL("bali_640x360_YUY2.yuv"), kYUY2Size, data); |
} |
+// Helper for converting image format from BGRA to RGBA. |
+static void ConvertBGRAToRGBA(unsigned char* pixels, size_t buffer_size) { |
scherkus (not reviewing)
2013/06/20 00:28:08
wait ... isn't this backwards?
your comment in me
hkuang1
2013/06/20 03:45:33
Yes, my bad. Should be RGBA to BGRA. "SwapRedAndBl
|
+ // Swizzle red and blue channels. |
+ for (size_t i = 0; i < buffer_size; i += 4) { |
+ std::swap(pixels[i], pixels[i + 2]); |
+ } |
+} |
+ |
namespace media { |
TEST(YUVConvertTest, YV12) { |
@@ -98,6 +106,10 @@ TEST(YUVConvertTest, YV12) { |
kSourceWidth * kBpp, // RGBStride |
media::YV12); |
+#if defined(OS_ANDROID) |
+ ConvertBGRAToRGBA(rgb_converted_bytes.get(), kRGBSizeConverted); |
+#endif |
+ |
uint32 rgb_hash = DJB2Hash(rgb_converted_bytes.get(), kRGBSizeConverted, |
kDJB2HashSeed); |
EXPECT_EQ(2413171226u, rgb_hash); |
@@ -123,6 +135,10 @@ TEST(YUVConvertTest, YV16) { |
kSourceWidth * kBpp, // RGBStride |
media::YV16); |
+#if defined(OS_ANDROID) |
+ ConvertBGRAToRGBA(rgb_converted_bytes.get(), kRGBSizeConverted); |
+#endif |
+ |
uint32 rgb_hash = DJB2Hash(rgb_converted_bytes.get(), kRGBSizeConverted, |
kDJB2HashSeed); |
EXPECT_EQ(4222342047u, rgb_hash); |
@@ -217,6 +233,10 @@ TEST_P(YUVScaleTest, Normal) { |
media::ROTATE_0, |
GetParam().scale_filter); |
+#if defined(OS_ANDROID) |
+ ConvertBGRAToRGBA(rgb_bytes_.get(), kRGBSizeScaled); |
+#endif |
+ |
uint32 rgb_hash = DJB2Hash(rgb_bytes_.get(), kRGBSizeScaled, kDJB2HashSeed); |
EXPECT_EQ(GetParam().rgb_hash, rgb_hash); |
} |
@@ -304,6 +324,10 @@ TEST(YUVConvertTest, Clamp) { |
0, // RGBStride |
media::YV12); |
+#if defined(OS_ANDROID) |
+ ConvertBGRAToRGBA(rgb, kBpp); |
+#endif |
+ |
int expected_test = memcmp(rgb, expected, sizeof(expected)); |
EXPECT_EQ(0, expected_test); |
} |
@@ -328,6 +352,7 @@ TEST(YUVConvertTest, RGB24ToYUV) { |
uint32 rgb_hash = DJB2Hash(yuv_converted_bytes.get(), kYUV12Size, |
kDJB2HashSeed); |
+ |
scherkus (not reviewing)
2013/06/20 00:28:08
remove extra line that snuck in
hkuang1
2013/06/20 03:45:33
Done.
|
EXPECT_EQ(320824432u, rgb_hash); |
} |