| Index: cc/resources/texture_compressor_etc1_unittest.cc | 
| diff --git a/cc/resources/texture_compressor_etc1_unittest.cc b/cc/resources/texture_compressor_etc1_unittest.cc | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..239accc57f5e8174a024b2f75429ae8c8ff8c4a2 | 
| --- /dev/null | 
| +++ b/cc/resources/texture_compressor_etc1_unittest.cc | 
| @@ -0,0 +1,56 @@ | 
| +// Copyright 2015 The Chromium Authors. All rights reserved. | 
| +// Use of this source code is governed by a BSD-style license that can be | 
| +// found in the LICENSE file. | 
| + | 
| +#include "cc/resources/texture_compressor.h" | 
| + | 
| +#include "cc/base/util.h" | 
| +#include "testing/gtest/include/gtest/gtest.h" | 
| + | 
| +namespace cc { | 
| +namespace { | 
| + | 
| +const int kImageWidth = 256; | 
| +const int kImageHeight = 256; | 
| +const int kImageChannels = 4; | 
| +const int kImageSizeInBytes = kImageWidth * kImageHeight * kImageChannels; | 
| + | 
| +TEST(TextureCompressorETC1Test, Compress256x256Ratio) { | 
| +  scoped_ptr<TextureCompressor> compressor = | 
| +      TextureCompressor::Create(TextureCompressor::kFormatETC1); | 
| +  uint8_t src[kImageSizeInBytes]; | 
| +  uint8_t dst[kImageSizeInBytes]; | 
| +  const unsigned int kImagePoison = 0xDEADBEEF; | 
| + | 
| +  // Poison destination bytes so we can see how much has been | 
| +  // overwritten by compression algorithm. | 
| +  uint32_t* dst_32 = reinterpret_cast<uint32_t*>(dst); | 
| +  for (int i = 0; i < kImageWidth * kImageHeight; i++) { | 
| +    dst_32[i] = kImagePoison; | 
| +  } | 
| + | 
| +  // Generate test texture. | 
| +  for (int i = 0; i < kImageSizeInBytes; i++) { | 
| +    src[i] = i % 256; | 
| +  } | 
| + | 
| +  compressor->Compress(src, dst, kImageWidth, kImageHeight, | 
| +                       TextureCompressor::kQualityLow); | 
| + | 
| +  int compressed_size = 0; | 
| +  for (compressed_size = 0; compressed_size < kImageWidth * kImageHeight; | 
| +       compressed_size++) { | 
| +    if (dst_32[compressed_size] == kImagePoison) { | 
| +      // Represents size in bytes of the compressed block. | 
| +      compressed_size = compressed_size * 4; | 
| +      break; | 
| +    } | 
| +  } | 
| + | 
| +  // Check if compression ratio is 8:1 for RGBA or BGRA images, after discarding | 
| +  // alpha channel. | 
| +  EXPECT_EQ(kImageSizeInBytes, compressed_size * 8); | 
| +} | 
| + | 
| +}  // namespace | 
| +}  // namespace cc | 
|  |