| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (c) 2013, Google Inc. All rights reserved. | 2 * Copyright (c) 2013, Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 74 // them from the cache. | 74 // them from the cache. |
| 75 Heap::collectGarbage(BlinkGC::NoHeapPointersOnStack, BlinkGC::GCWithSwee
p, BlinkGC::ForcedGC); | 75 Heap::collectGarbage(BlinkGC::NoHeapPointersOnStack, BlinkGC::GCWithSwee
p, BlinkGC::ForcedGC); |
| 76 | 76 |
| 77 replaceMemoryCacheForTesting(m_globalMemoryCache.release()); | 77 replaceMemoryCacheForTesting(m_globalMemoryCache.release()); |
| 78 } | 78 } |
| 79 | 79 |
| 80 RefPtr<SkImage> m_image, m_image2; | 80 RefPtr<SkImage> m_image, m_image2; |
| 81 Persistent<MemoryCache> m_globalMemoryCache; | 81 Persistent<MemoryCache> m_globalMemoryCache; |
| 82 }; | 82 }; |
| 83 | 83 |
| 84 // Verifies that the image resource held by an ImageBitmap is the same as the | |
| 85 // one held by the HTMLImageElement. | |
| 86 TEST_F(ImageBitmapTest, ImageResourceConsistency) | 84 TEST_F(ImageBitmapTest, ImageResourceConsistency) |
| 87 { | 85 { |
| 88 RefPtrWillBeRawPtr<HTMLImageElement> imageElement = HTMLImageElement::create
(*Document::create().get()); | 86 RefPtrWillBeRawPtr<HTMLImageElement> imageElement = HTMLImageElement::create
(*Document::create().get()); |
| 89 imageElement->setImageResource(new ImageResource(StaticBitmapImage::create(m
_image).get())); | 87 imageElement->setImageResource(new ImageResource(StaticBitmapImage::create(m
_image).get())); |
| 90 | 88 |
| 91 RefPtrWillBeRawPtr<ImageBitmap> imageBitmapNoCrop = ImageBitmap::create(imag
eElement.get(), | 89 RefPtrWillBeRawPtr<ImageBitmap> imageBitmapNoCrop = ImageBitmap::create(imag
eElement.get(), |
| 92 IntRect(0, 0, m_image->width(), m_image->height())); | 90 IntRect(0, 0, m_image->width(), m_image->height())); |
| 93 RefPtrWillBeRawPtr<ImageBitmap> imageBitmapInteriorCrop = ImageBitmap::creat
e(imageElement.get(), | 91 RefPtrWillBeRawPtr<ImageBitmap> imageBitmapInteriorCrop = ImageBitmap::creat
e(imageElement.get(), |
| 94 IntRect(m_image->width() / 2, m_image->height() / 2, m_image->width() /
2, m_image->height() / 2)); | 92 IntRect(m_image->width() / 2, m_image->height() / 2, m_image->width() /
2, m_image->height() / 2)); |
| 95 RefPtrWillBeRawPtr<ImageBitmap> imageBitmapExteriorCrop = ImageBitmap::creat
e(imageElement.get(), | 93 RefPtrWillBeRawPtr<ImageBitmap> imageBitmapExteriorCrop = ImageBitmap::creat
e(imageElement.get(), |
| 96 IntRect(-m_image->width() / 2, -m_image->height() / 2, m_image->width(),
m_image->height())); | 94 IntRect(-m_image->width() / 2, -m_image->height() / 2, m_image->width(),
m_image->height())); |
| 97 RefPtrWillBeRawPtr<ImageBitmap> imageBitmapOutsideCrop = ImageBitmap::create
(imageElement.get(), | 95 RefPtrWillBeRawPtr<ImageBitmap> imageBitmapOutsideCrop = ImageBitmap::create
(imageElement.get(), |
| 98 IntRect(-m_image->width(), -m_image->height(), m_image->width(), m_image
->height())); | 96 IntRect(-m_image->width(), -m_image->height(), m_image->width(), m_image
->height())); |
| 99 | 97 |
| 100 ASSERT_EQ(imageBitmapNoCrop->bitmapImage().get(), imageElement->cachedImage(
)->image()); | 98 // Now that we use SkImage::newSubset() to crop the image, the ImageBitmap::
skImage() is not necessary the same |
| 101 ASSERT_EQ(imageBitmapInteriorCrop->bitmapImage().get(), imageElement->cached
Image()->image()); | 99 // as the source imageElement. See SkImage::newSubset() for details. |
| 102 ASSERT_EQ(imageBitmapExteriorCrop->bitmapImage().get(), imageElement->cached
Image()->image()); | 100 ASSERT_EQ(imageBitmapNoCrop->skImage(), imageElement->cachedImage()->image()
->imageForCurrentFrame().get()); |
| 101 ASSERT_NE(imageBitmapInteriorCrop->skImage(), imageElement->cachedImage()->i
mage()->imageForCurrentFrame().get()); |
| 102 ASSERT_NE(imageBitmapExteriorCrop->skImage(), imageElement->cachedImage()->i
mage()->imageForCurrentFrame().get()); |
| 103 | 103 |
| 104 RefPtr<Image> emptyImage = imageBitmapOutsideCrop->bitmapImage(); | 104 SkImage* emptyImage = imageBitmapOutsideCrop->skImage(); |
| 105 ASSERT_NE(emptyImage.get(), imageElement->cachedImage()->image()); | 105 ASSERT_EQ(emptyImage, nullptr); |
| 106 ASSERT_NE(emptyImage, imageElement->cachedImage()->image()->imageForCurrentF
rame()); |
| 106 } | 107 } |
| 107 | 108 |
| 108 // Verifies that HTMLImageElements are given an elevated CacheLiveResourcePriori
ty when used to construct an ImageBitmap. | 109 // Verifies that HTMLImageElements are given an elevated CacheLiveResourcePriori
ty when used to construct an ImageBitmap. |
| 109 // ImageBitmaps that have crop rects outside of the bounds of the HTMLImageEleme
nt do not have elevated CacheLiveResourcePriority. | 110 // ImageBitmaps that have crop rects outside of the bounds of the HTMLImageEleme
nt do not have elevated CacheLiveResourcePriority. |
| 110 TEST_F(ImageBitmapTest, ImageBitmapLiveResourcePriority) | 111 TEST_F(ImageBitmapTest, ImageBitmapLiveResourcePriority) |
| 111 { | 112 { |
| 112 RefPtrWillBePersistent<HTMLImageElement> imageNoCrop = HTMLImageElement::cre
ate(*Document::create().get()); | 113 RefPtrWillBePersistent<HTMLImageElement> imageNoCrop = HTMLImageElement::cre
ate(*Document::create().get()); |
| 113 ResourcePtr<ImageResource> cachedImageNoCrop = new ImageResource(ResourceReq
uest("http://foo.com/1"), | 114 ResourcePtr<ImageResource> cachedImageNoCrop = new ImageResource(ResourceReq
uest("http://foo.com/1"), |
| 114 StaticBitmapImage::create(m_image).get()); | 115 StaticBitmapImage::create(m_image).get()); |
| 115 imageNoCrop->setImageResource(cachedImageNoCrop.get()); | 116 imageNoCrop->setImageResource(cachedImageNoCrop.get()); |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 154 { | 155 { |
| 155 RefPtrWillBePersistent<ImageBitmap> imageBitmapNoCrop = ImageBitmap::cre
ate(imageNoCrop.get(), | 156 RefPtrWillBePersistent<ImageBitmap> imageBitmapNoCrop = ImageBitmap::cre
ate(imageNoCrop.get(), |
| 156 IntRect(0, 0, m_image->width(), m_image->height())); | 157 IntRect(0, 0, m_image->width(), m_image->height())); |
| 157 RefPtrWillBePersistent<ImageBitmap> imageBitmapInteriorCrop2 = ImageBitm
ap::create(imageInteriorCrop.get(), | 158 RefPtrWillBePersistent<ImageBitmap> imageBitmapInteriorCrop2 = ImageBitm
ap::create(imageInteriorCrop.get(), |
| 158 IntRect(m_image->width() / 2, m_image->height() / 2, m_image->width(
), m_image->height())); | 159 IntRect(m_image->width() / 2, m_image->height() / 2, m_image->width(
), m_image->height())); |
| 159 RefPtrWillBePersistent<ImageBitmap> imageBitmapExteriorCrop = ImageBitma
p::create(imageExteriorCrop.get(), | 160 RefPtrWillBePersistent<ImageBitmap> imageBitmapExteriorCrop = ImageBitma
p::create(imageExteriorCrop.get(), |
| 160 IntRect(-m_image->width() / 2, -m_image->height() / 2, m_image->widt
h(), m_image->height())); | 161 IntRect(-m_image->width() / 2, -m_image->height() / 2, m_image->widt
h(), m_image->height())); |
| 161 RefPtrWillBePersistent<ImageBitmap> imageBitmapOutsideCrop = ImageBitmap
::create(imageOutsideCrop.get(), | 162 RefPtrWillBePersistent<ImageBitmap> imageBitmapOutsideCrop = ImageBitmap
::create(imageOutsideCrop.get(), |
| 162 IntRect(-m_image->width(), -m_image->height(), m_image->width(), m_i
mage->height())); | 163 IntRect(-m_image->width(), -m_image->height(), m_image->width(), m_i
mage->height())); |
| 163 | 164 |
| 164 // Images that are referenced by ImageBitmaps have CacheLiveResourcePrio
rityHigh. | 165 // Images are not referenced by ImageBitmap anymore, so always CacheLive
ResourcePriorityLow |
| 165 ASSERT_EQ(memoryCache()->priority(imageNoCrop->cachedImage()), MemoryCac
heLiveResourcePriorityHigh); | 166 ASSERT_EQ(memoryCache()->priority(imageNoCrop->cachedImage()), MemoryCac
heLiveResourcePriorityLow); |
| 166 ASSERT_EQ(memoryCache()->priority(imageInteriorCrop->cachedImage()), Mem
oryCacheLiveResourcePriorityHigh); | 167 ASSERT_EQ(memoryCache()->priority(imageInteriorCrop->cachedImage()), Mem
oryCacheLiveResourcePriorityLow); |
| 167 ASSERT_EQ(memoryCache()->priority(imageExteriorCrop->cachedImage()), Mem
oryCacheLiveResourcePriorityHigh); | 168 ASSERT_EQ(memoryCache()->priority(imageExteriorCrop->cachedImage()), Mem
oryCacheLiveResourcePriorityLow); |
| 168 | 169 |
| 169 // ImageBitmaps that do not contain any of the source image do not eleva
te CacheLiveResourcePriority. | 170 // ImageBitmaps that do not contain any of the source image do not eleva
te CacheLiveResourcePriority. |
| 170 ASSERT_EQ(memoryCache()->priority(imageOutsideCrop->cachedImage()), Memo
ryCacheLiveResourcePriorityLow); | 171 ASSERT_EQ(memoryCache()->priority(imageOutsideCrop->cachedImage()), Memo
ryCacheLiveResourcePriorityLow); |
| 171 } | 172 } |
| 172 // Force a garbage collection to sweep out the local ImageBitmaps. | 173 // Force a garbage collection to sweep out the local ImageBitmaps. |
| 173 Heap::collectGarbage(BlinkGC::NoHeapPointersOnStack, BlinkGC::GCWithSweep, B
linkGC::ForcedGC); | 174 Heap::collectGarbage(BlinkGC::NoHeapPointersOnStack, BlinkGC::GCWithSweep, B
linkGC::ForcedGC); |
| 174 | 175 |
| 175 // CacheLiveResourcePriroity should return to CacheLiveResourcePriorityLow w
hen no ImageBitmaps reference the image. | 176 // CacheLiveResourcePriroity should return to CacheLiveResourcePriorityLow w
hen no ImageBitmaps reference the image. |
| 176 ASSERT_EQ(memoryCache()->priority(imageNoCrop->cachedImage()), MemoryCacheLi
veResourcePriorityLow); | 177 ASSERT_EQ(memoryCache()->priority(imageNoCrop->cachedImage()), MemoryCacheLi
veResourcePriorityLow); |
| 177 ASSERT_EQ(memoryCache()->priority(imageExteriorCrop->cachedImage()), MemoryC
acheLiveResourcePriorityLow); | 178 ASSERT_EQ(memoryCache()->priority(imageExteriorCrop->cachedImage()), MemoryC
acheLiveResourcePriorityLow); |
| 178 ASSERT_EQ(memoryCache()->priority(imageOutsideCrop->cachedImage()), MemoryCa
cheLiveResourcePriorityLow); | 179 ASSERT_EQ(memoryCache()->priority(imageOutsideCrop->cachedImage()), MemoryCa
cheLiveResourcePriorityLow); |
| 179 | 180 |
| 180 // There is still an ImageBitmap that references this image. | 181 // There is still an ImageBitmap that references this image. |
| 181 ASSERT_EQ(memoryCache()->priority(imageInteriorCrop->cachedImage()), MemoryC
acheLiveResourcePriorityHigh); | 182 ASSERT_EQ(memoryCache()->priority(imageInteriorCrop->cachedImage()), MemoryC
acheLiveResourcePriorityLow); |
| 182 imageBitmapInteriorCrop = nullptr; | 183 imageBitmapInteriorCrop = nullptr; |
| 183 } | 184 } |
| 184 | 185 |
| 185 // Verifies that ImageBitmaps constructed from HTMLImageElements hold a referenc
e to the original Image if the HTMLImageElement src is changed. | 186 // Verifies that ImageBitmaps constructed from HTMLImageElements hold a referenc
e to the original Image if the HTMLImageElement src is changed. |
| 186 TEST_F(ImageBitmapTest, ImageBitmapSourceChanged) | 187 TEST_F(ImageBitmapTest, ImageBitmapSourceChanged) |
| 187 { | 188 { |
| 188 RefPtrWillBeRawPtr<HTMLImageElement> image = HTMLImageElement::create(*Docum
ent::create().get()); | 189 RefPtrWillBeRawPtr<HTMLImageElement> image = HTMLImageElement::create(*Docum
ent::create().get()); |
| 189 ResourcePtr<ImageResource> originalImageResource = new ImageResource( | 190 ResourcePtr<ImageResource> originalImageResource = new ImageResource( |
| 190 StaticBitmapImage::create(m_image).get()); | 191 StaticBitmapImage::create(m_image).get()); |
| 191 image->setImageResource(originalImageResource.get()); | 192 image->setImageResource(originalImageResource.get()); |
| 192 | 193 |
| 193 RefPtrWillBeRawPtr<ImageBitmap> imageBitmap = ImageBitmap::create(image.get(
), | 194 RefPtrWillBeRawPtr<ImageBitmap> imageBitmap = ImageBitmap::create(image.get(
), |
| 194 IntRect(0, 0, m_image->width(), m_image->height())); | 195 IntRect(0, 0, m_image->width(), m_image->height())); |
| 195 ASSERT_EQ(imageBitmap->bitmapImage().get(), originalImageResource->image()); | 196 ASSERT_EQ(imageBitmap->skImage(), originalImageResource->image()->imageForCu
rrentFrame().get()); |
| 196 | 197 |
| 197 ResourcePtr<ImageResource> newImageResource = new ImageResource( | 198 ResourcePtr<ImageResource> newImageResource = new ImageResource( |
| 198 StaticBitmapImage::create(m_image2).get()); | 199 StaticBitmapImage::create(m_image2).get()); |
| 199 image->setImageResource(newImageResource.get()); | 200 image->setImageResource(newImageResource.get()); |
| 200 | 201 |
| 201 // The ImageBitmap should contain the same data as the original cached image
but should no longer hold a reference. | 202 // The ImageBitmap should contain the same data as the original cached image |
| 202 { | 203 { |
| 203 ASSERT_NE(imageBitmap->bitmapImage().get(), originalImageResource->image
()); | 204 ASSERT_EQ(imageBitmap->skImage(), originalImageResource->image()->imageF
orCurrentFrame().get()); |
| 204 RefPtr<SkImage> image1 = imageBitmap->bitmapImage()->imageForCurrentFram
e(); | 205 SkImage* image1 = imageBitmap->skImage(); |
| 205 ASSERT_NE(image1, nullptr); | 206 ASSERT_NE(image1, nullptr); |
| 206 RefPtr<SkImage> image2 = originalImageResource->image()->imageForCurrent
Frame(); | 207 SkImage* image2 = originalImageResource->image()->imageForCurrentFrame()
.get(); |
| 207 ASSERT_NE(image2, nullptr); | 208 ASSERT_NE(image2, nullptr); |
| 208 ASSERT_EQ(image1, image2); | 209 ASSERT_EQ(image1, image2); |
| 209 } | 210 } |
| 210 | 211 |
| 211 { | 212 { |
| 212 ASSERT_NE(imageBitmap->bitmapImage().get(), newImageResource->image()); | 213 ASSERT_NE(imageBitmap->skImage(), newImageResource->image()->imageForCur
rentFrame().get()); |
| 213 RefPtr<SkImage> image1 = imageBitmap->bitmapImage()->imageForCurrentFram
e(); | 214 SkImage* image1 = imageBitmap->skImage(); |
| 214 ASSERT_NE(image1, nullptr); | 215 ASSERT_NE(image1, nullptr); |
| 215 RefPtr<SkImage> image2 = newImageResource->image()->imageForCurrentFrame
(); | 216 SkImage* image2 = newImageResource->image()->imageForCurrentFrame().get(
); |
| 216 ASSERT_NE(image2, nullptr); | 217 ASSERT_NE(image2, nullptr); |
| 217 ASSERT_NE(image1, image2); | 218 ASSERT_NE(image1, image2); |
| 218 } | 219 } |
| 219 } | 220 } |
| 220 | 221 |
| 221 } // namespace | 222 } // namespace |
| OLD | NEW |