Index: Source/platform/graphics/ImageDecodingStoreTest.cpp |
diff --git a/Source/platform/graphics/ImageDecodingStoreTest.cpp b/Source/platform/graphics/ImageDecodingStoreTest.cpp |
index 07d67b3ab09113ac32e22ff8414af016b1c91a0f..5ce5c411625f8352830e02b85df4876db4be7112 100644 |
--- a/Source/platform/graphics/ImageDecodingStoreTest.cpp |
+++ b/Source/platform/graphics/ImageDecodingStoreTest.cpp |
@@ -29,7 +29,6 @@ |
#include "platform/SharedBuffer.h" |
#include "platform/graphics/ImageFrameGenerator.h" |
-#include "platform/graphics/test/MockDiscardablePixelRef.h" |
#include "platform/graphics/test/MockImageDecoder.h" |
#include <gtest/gtest.h> |
@@ -42,7 +41,6 @@ public: |
virtual void SetUp() |
{ |
ImageDecodingStore::instance()->setCacheLimitInBytes(1024 * 1024); |
- ImageDecodingStore::instance()->setImageCachingEnabled(true); |
m_data = SharedBuffer::create(); |
m_generator = ImageFrameGenerator::create(SkISize::Make(100, 100), m_data, true); |
m_decodersDestroyed = 0; |
@@ -74,52 +72,6 @@ public: |
virtual float frameDuration() const { return 0; } |
protected: |
- PassOwnPtr<ScaledImageFragment> createCompleteImage(const SkISize& size, bool discardable = false, size_t index = 0) |
- { |
- SkBitmap bitmap; |
- bitmap.setInfo(SkImageInfo::MakeN32Premul(size)); |
- if (!discardable) { |
- bitmap.allocPixels(); |
- } else { |
- MockDiscardablePixelRef::Allocator mockDiscardableAllocator; |
- bitmap.allocPixels(&mockDiscardableAllocator, 0); |
- } |
- return ScaledImageFragment::createComplete(size, index, bitmap); |
- } |
- |
- PassOwnPtr<ScaledImageFragment> createIncompleteImage(const SkISize& size, bool discardable = false, size_t generation = 0) |
- { |
- SkBitmap bitmap; |
- bitmap.setInfo(SkImageInfo::MakeN32Premul(size)); |
- if (!discardable) { |
- bitmap.allocPixels(); |
- } else { |
- MockDiscardablePixelRef::Allocator mockDiscardableAllocator; |
- bitmap.allocPixels(&mockDiscardableAllocator, 0); |
- } |
- return ScaledImageFragment::createPartial(size, 0, generation, bitmap); |
- } |
- |
- void insertCache(const SkISize& size) |
- { |
- const ScaledImageFragment* image = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createCompleteImage(size)); |
- unlockCache(image); |
- } |
- |
- const ScaledImageFragment* lockCache(const SkISize& size, size_t index = 0) |
- { |
- const ScaledImageFragment* cachedImage = 0; |
- if (ImageDecodingStore::instance()->lockCache(m_generator.get(), size, index, &cachedImage)) |
- return cachedImage; |
- return 0; |
- } |
- |
- void unlockCache(const ScaledImageFragment* cachedImage) |
- { |
- ImageDecodingStore::instance()->unlockCache(m_generator.get(), cachedImage); |
- } |
- |
void evictOneCache() |
{ |
size_t memoryUsageInBytes = ImageDecodingStore::instance()->memoryUsageInBytes(); |
@@ -129,137 +81,18 @@ protected: |
ImageDecodingStore::instance()->setCacheLimitInBytes(0); |
} |
- bool isCacheAlive(const SkISize& size) |
- { |
- const ScaledImageFragment* cachedImage = lockCache(size); |
- if (!cachedImage) |
- return false; |
- ImageDecodingStore::instance()->unlockCache(m_generator.get(), cachedImage); |
- return true; |
- } |
- |
RefPtr<SharedBuffer> m_data; |
RefPtr<ImageFrameGenerator> m_generator; |
int m_decodersDestroyed; |
}; |
-TEST_F(ImageDecodingStoreTest, evictOneCache) |
-{ |
- insertCache(SkISize::Make(1, 1)); |
- insertCache(SkISize::Make(2, 2)); |
- insertCache(SkISize::Make(3, 3)); |
- EXPECT_EQ(3, ImageDecodingStore::instance()->cacheEntries()); |
- |
- evictOneCache(); |
- EXPECT_EQ(2, ImageDecodingStore::instance()->cacheEntries()); |
- |
- evictOneCache(); |
- EXPECT_EQ(1, ImageDecodingStore::instance()->cacheEntries()); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, pruneOrderIsLeastRecentlyUsed) |
-{ |
- insertCache(SkISize::Make(1, 1)); |
- insertCache(SkISize::Make(2, 2)); |
- insertCache(SkISize::Make(3, 3)); |
- insertCache(SkISize::Make(4, 4)); |
- insertCache(SkISize::Make(5, 5)); |
- EXPECT_EQ(5, ImageDecodingStore::instance()->cacheEntries()); |
- |
- // Use cache in the order 3, 2, 4, 1, 5. |
- EXPECT_TRUE(isCacheAlive(SkISize::Make(3, 3))); |
- EXPECT_TRUE(isCacheAlive(SkISize::Make(2, 2))); |
- EXPECT_TRUE(isCacheAlive(SkISize::Make(4, 4))); |
- EXPECT_TRUE(isCacheAlive(SkISize::Make(1, 1))); |
- EXPECT_TRUE(isCacheAlive(SkISize::Make(5, 5))); |
- |
- // Evict 3. |
- evictOneCache(); |
- EXPECT_FALSE(isCacheAlive(SkISize::Make(3, 3))); |
- EXPECT_EQ(4, ImageDecodingStore::instance()->cacheEntries()); |
- |
- // Evict 2. |
- evictOneCache(); |
- EXPECT_FALSE(isCacheAlive(SkISize::Make(2, 2))); |
- EXPECT_EQ(3, ImageDecodingStore::instance()->cacheEntries()); |
- |
- // Evict 4. |
- evictOneCache(); |
- EXPECT_FALSE(isCacheAlive(SkISize::Make(4, 4))); |
- EXPECT_EQ(2, ImageDecodingStore::instance()->cacheEntries()); |
- |
- // Evict 1. |
- evictOneCache(); |
- EXPECT_FALSE(isCacheAlive(SkISize::Make(1, 1))); |
- EXPECT_EQ(1, ImageDecodingStore::instance()->cacheEntries()); |
- |
- // Evict 5. |
- evictOneCache(); |
- EXPECT_FALSE(isCacheAlive(SkISize::Make(5, 5))); |
- EXPECT_EQ(0, ImageDecodingStore::instance()->cacheEntries()); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, pruneCausedByInsertion) |
-{ |
- ImageDecodingStore::instance()->setCacheLimitInBytes(100); |
- |
- // Insert 100 entries. |
- // Cache entries stored should increase and eventually decrease to 1. |
- insertCache(SkISize::Make(1, 1)); |
- insertCache(SkISize::Make(2, 2)); |
- insertCache(SkISize::Make(3, 3)); |
- EXPECT_EQ(3, ImageDecodingStore::instance()->cacheEntries()); |
- |
- for (int i = 4; i <= 100; ++i) |
- insertCache(SkISize::Make(i, i)); |
- |
- EXPECT_EQ(1, ImageDecodingStore::instance()->cacheEntries()); |
- for (int i = 1; i <= 99; ++i) |
- EXPECT_FALSE(isCacheAlive(SkISize::Make(i, i))); |
- EXPECT_TRUE(isCacheAlive(SkISize::Make(100, 100))); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, cacheInUseNotEvicted) |
-{ |
- insertCache(SkISize::Make(1, 1)); |
- insertCache(SkISize::Make(2, 2)); |
- insertCache(SkISize::Make(3, 3)); |
- EXPECT_EQ(3, ImageDecodingStore::instance()->cacheEntries()); |
- |
- const ScaledImageFragment* cachedImage = lockCache(SkISize::Make(1, 1)); |
- ASSERT_TRUE(cachedImage); |
- |
- // Cache 2 is evicted because cache 1 is in use. |
- evictOneCache(); |
- EXPECT_TRUE(isCacheAlive(SkISize::Make(1, 1))); |
- EXPECT_FALSE(isCacheAlive(SkISize::Make(2, 2))); |
- EXPECT_TRUE(isCacheAlive(SkISize::Make(3, 3))); |
- |
- EXPECT_EQ(2, ImageDecodingStore::instance()->cacheEntries()); |
- unlockCache(cachedImage); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, destroyImageFrameGenerator) |
-{ |
- insertCache(SkISize::Make(1, 1)); |
- insertCache(SkISize::Make(2, 2)); |
- insertCache(SkISize::Make(3, 3)); |
- OwnPtr<ImageDecoder> decoder = MockImageDecoder::create(this); |
- decoder->setSize(1, 1); |
- ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder.release(), false); |
- EXPECT_EQ(4, ImageDecodingStore::instance()->cacheEntries()); |
- |
- m_generator.clear(); |
- EXPECT_FALSE(ImageDecodingStore::instance()->cacheEntries()); |
-} |
- |
TEST_F(ImageDecodingStoreTest, insertDecoder) |
{ |
const SkISize size = SkISize::Make(1, 1); |
OwnPtr<ImageDecoder> decoder = MockImageDecoder::create(this); |
decoder->setSize(1, 1); |
const ImageDecoder* refDecoder = decoder.get(); |
- ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder.release(), false); |
+ ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder.release()); |
EXPECT_EQ(1, ImageDecodingStore::instance()->cacheEntries()); |
EXPECT_EQ(4u, ImageDecodingStore::instance()->memoryUsageInBytes()); |
@@ -279,9 +112,9 @@ TEST_F(ImageDecodingStoreTest, evictDecoder) |
decoder1->setSize(1, 1); |
decoder2->setSize(2, 2); |
decoder3->setSize(3, 3); |
- ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder1.release(), false); |
- ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder2.release(), false); |
- ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder3.release(), false); |
+ ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder1.release()); |
+ ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder2.release()); |
+ ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder3.release()); |
EXPECT_EQ(3, ImageDecodingStore::instance()->cacheEntries()); |
EXPECT_EQ(56u, ImageDecodingStore::instance()->memoryUsageInBytes()); |
@@ -306,9 +139,9 @@ TEST_F(ImageDecodingStoreTest, decoderInUseNotEvicted) |
decoder1->setSize(1, 1); |
decoder2->setSize(2, 2); |
decoder3->setSize(3, 3); |
- ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder1.release(), false); |
- ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder2.release(), false); |
- ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder3.release(), false); |
+ ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder1.release()); |
+ ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder2.release()); |
+ ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder3.release()); |
EXPECT_EQ(3, ImageDecodingStore::instance()->cacheEntries()); |
ImageDecoder* testDecoder; |
@@ -332,7 +165,7 @@ TEST_F(ImageDecodingStoreTest, removeDecoder) |
OwnPtr<ImageDecoder> decoder = MockImageDecoder::create(this); |
decoder->setSize(1, 1); |
const ImageDecoder* refDecoder = decoder.get(); |
- ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder.release(), false); |
+ ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder.release()); |
EXPECT_EQ(1, ImageDecodingStore::instance()->cacheEntries()); |
EXPECT_EQ(4u, ImageDecodingStore::instance()->memoryUsageInBytes()); |
@@ -346,134 +179,4 @@ TEST_F(ImageDecodingStoreTest, removeDecoder) |
EXPECT_FALSE(ImageDecodingStore::instance()->lockDecoder(m_generator.get(), size, &testDecoder)); |
} |
-TEST_F(ImageDecodingStoreTest, multipleIndex) |
-{ |
- const SkISize size = SkISize::Make(1, 1); |
- const ScaledImageFragment* refImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createCompleteImage(size, false, 0)); |
- unlockCache(refImage); |
- const ScaledImageFragment* testImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createCompleteImage(size, false, 1)); |
- unlockCache(testImage); |
- EXPECT_NE(refImage, testImage); |
- EXPECT_EQ(2, ImageDecodingStore::instance()->cacheEntries()); |
- |
- EXPECT_TRUE(ImageDecodingStore::instance()->lockCache(m_generator.get(), size, 1, &refImage)); |
- EXPECT_EQ(refImage, testImage); |
- unlockCache(refImage); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, finalAndPartialImage) |
-{ |
- const SkISize size = SkISize::Make(1, 1); |
- const ScaledImageFragment* refImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createCompleteImage(size, false, 0)); |
- unlockCache(refImage); |
- const ScaledImageFragment* testImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createIncompleteImage(size, false, 1)); |
- unlockCache(testImage); |
- EXPECT_NE(refImage, testImage); |
- EXPECT_EQ(2, ImageDecodingStore::instance()->cacheEntries()); |
- |
- EXPECT_TRUE(ImageDecodingStore::instance()->lockCache(m_generator.get(), size, 0, &refImage)); |
- EXPECT_NE(refImage, testImage); |
- unlockCache(refImage); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, insertNoGenerationCollision) |
-{ |
- const SkISize size = SkISize::Make(1, 1); |
- const ScaledImageFragment* refImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createIncompleteImage(size, false, 1)); |
- unlockCache(refImage); |
- const ScaledImageFragment* testImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createIncompleteImage(size, false, 2)); |
- unlockCache(testImage); |
- EXPECT_NE(refImage, testImage); |
- EXPECT_EQ(2, ImageDecodingStore::instance()->cacheEntries()); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, insertGenerationCollision) |
-{ |
- const SkISize size = SkISize::Make(1, 1); |
- const ScaledImageFragment* refImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createIncompleteImage(size, false, 1)); |
- unlockCache(refImage); |
- const ScaledImageFragment* testImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createIncompleteImage(size, false, 1)); |
- unlockCache(testImage); |
- EXPECT_EQ(refImage, testImage); |
- EXPECT_EQ(1, ImageDecodingStore::instance()->cacheEntries()); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, insertGenerationCollisionAfterMemoryDiscarded) |
-{ |
- const SkISize size = SkISize::Make(1, 1); |
- const ScaledImageFragment* refImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createIncompleteImage(size, true, 1)); |
- unlockCache(refImage); |
- MockDiscardablePixelRef* pixelRef = static_cast<MockDiscardablePixelRef*>(refImage->bitmap().pixelRef()); |
- pixelRef->discard(); |
- const ScaledImageFragment* testImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createIncompleteImage(size, false, 1)); |
- unlockCache(testImage); |
- EXPECT_NE(refImage, testImage); |
- EXPECT_EQ(1, ImageDecodingStore::instance()->cacheEntries()); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, lockCacheFailedAfterMemoryDiscarded) |
-{ |
- const ScaledImageFragment* cachedImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createCompleteImage(SkISize::Make(1, 1), true)); |
- unlockCache(cachedImage); |
- MockDiscardablePixelRef* pixelRef = static_cast<MockDiscardablePixelRef*>(cachedImage->bitmap().pixelRef()); |
- pixelRef->discard(); |
- EXPECT_EQ(0, lockCache(SkISize::Make(1, 1))); |
- EXPECT_EQ(0, ImageDecodingStore::instance()->cacheEntries()); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, clear) |
-{ |
- insertCache(SkISize::Make(1, 1)); |
- insertCache(SkISize::Make(2, 2)); |
- EXPECT_EQ(2, ImageDecodingStore::instance()->cacheEntries()); |
- |
- OwnPtr<ImageDecoder> decoder = MockImageDecoder::create(this); |
- decoder->setSize(1, 1); |
- ImageDecodingStore::instance()->insertDecoder(m_generator.get(), decoder.release(), false); |
- EXPECT_EQ(3, ImageDecodingStore::instance()->cacheEntries()); |
- |
- ImageDecodingStore::instance()->clear(); |
- EXPECT_EQ(0, ImageDecodingStore::instance()->cacheEntries()); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, clearInUse) |
-{ |
- insertCache(SkISize::Make(1, 1)); |
- insertCache(SkISize::Make(2, 2)); |
- EXPECT_EQ(2, ImageDecodingStore::instance()->cacheEntries()); |
- |
- const ScaledImageFragment* cachedImage = lockCache(SkISize::Make(1, 1)); |
- ASSERT_TRUE(cachedImage); |
- ImageDecodingStore::instance()->clear(); |
- EXPECT_EQ(1, ImageDecodingStore::instance()->cacheEntries()); |
- |
- unlockCache(cachedImage); |
- EXPECT_EQ(1, ImageDecodingStore::instance()->cacheEntries()); |
-} |
- |
-TEST_F(ImageDecodingStoreTest, disableImageCaching) |
-{ |
- ImageDecodingStore::instance()->setImageCachingEnabled(false); |
- insertCache(SkISize::Make(1, 1)); |
- insertCache(SkISize::Make(2, 2)); |
- EXPECT_EQ(0, ImageDecodingStore::instance()->cacheEntries()); |
- |
- const ScaledImageFragment* cachedImage = ImageDecodingStore::instance()->insertAndLockCache( |
- m_generator.get(), createCompleteImage(SkISize::Make(3, 3), true)); |
- EXPECT_EQ(1, ImageDecodingStore::instance()->cacheEntries()); |
- unlockCache(cachedImage); |
- EXPECT_EQ(0, ImageDecodingStore::instance()->cacheEntries()); |
-} |
- |
} // namespace |