Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(447)

Unified Diff: cc/resources/resource_pool_unittest.cc

Issue 2726263003: cc::ResourcePool - Re-use larger resources for smaller requests (Closed)
Patch Set: fix compile Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « cc/resources/resource_pool.cc ('k') | cc/test/fake_picture_layer_tiling_client.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/resources/resource_pool_unittest.cc
diff --git a/cc/resources/resource_pool_unittest.cc b/cc/resources/resource_pool_unittest.cc
index aa8e853e0c4f9caa95eda9cd1c30e7fc374f6002..3c516e554369facfd81fb9f2d04e5a5d8d9cb6c0 100644
--- a/cc/resources/resource_pool_unittest.cc
+++ b/cc/resources/resource_pool_unittest.cc
@@ -29,10 +29,16 @@ class ResourcePoolTest : public testing::Test {
resource_pool_ =
ResourcePool::Create(resource_provider_.get(), task_runner_.get(),
ResourceProvider::TEXTURE_HINT_IMMUTABLE,
- ResourcePool::kDefaultExpirationDelay);
+ ResourcePool::kDefaultExpirationDelay, false);
}
protected:
+ void CheckAndReturnResource(Resource* resource) {
+ EXPECT_NE(nullptr, resource);
+ resource_pool_->ReleaseResource(resource);
+ resource_pool_->CheckBusyResources();
+ }
+
scoped_refptr<TestContextProvider> context_provider_;
std::unique_ptr<SharedBitmapManager> shared_bitmap_manager_;
std::unique_ptr<ResourceProvider> resource_provider_;
@@ -105,32 +111,28 @@ TEST_F(ResourcePoolTest, SimpleResourceReuse) {
gfx::ColorSpace color_space1;
gfx::ColorSpace color_space2 = gfx::ColorSpace::CreateSRGB();
- Resource* resource =
- resource_pool_->AcquireResource(size, format, color_space1);
- resource_pool_->ReleaseResource(resource);
- resource_pool_->CheckBusyResources();
+ CheckAndReturnResource(
+ resource_pool_->AcquireResource(size, format, color_space1));
EXPECT_EQ(1u, resource_provider_->num_resources());
// Same size/format should re-use resource.
- resource = resource_pool_->AcquireResource(size, format, color_space1);
+ Resource* resource =
+ resource_pool_->AcquireResource(size, format, color_space1);
EXPECT_EQ(1u, resource_provider_->num_resources());
- resource_pool_->ReleaseResource(resource);
- resource_pool_->CheckBusyResources();
+ CheckAndReturnResource(resource);
EXPECT_EQ(1u, resource_provider_->num_resources());
// Different size/format should allocate new resource.
resource = resource_pool_->AcquireResource(gfx::Size(50, 50), LUMINANCE_8,
color_space1);
EXPECT_EQ(2u, resource_provider_->num_resources());
- resource_pool_->ReleaseResource(resource);
- resource_pool_->CheckBusyResources();
+ CheckAndReturnResource(resource);
EXPECT_EQ(2u, resource_provider_->num_resources());
// Different color space should allocate new resource.
resource = resource_pool_->AcquireResource(size, format, color_space2);
EXPECT_EQ(3u, resource_provider_->num_resources());
- resource_pool_->ReleaseResource(resource);
- resource_pool_->CheckBusyResources();
+ CheckAndReturnResource(resource);
EXPECT_EQ(3u, resource_provider_->num_resources());
}
@@ -160,7 +162,7 @@ TEST_F(ResourcePoolTest, BusyResourcesEventuallyFreed) {
resource_pool_ =
ResourcePool::Create(resource_provider_.get(), task_runner_.get(),
ResourceProvider::TEXTURE_HINT_IMMUTABLE,
- base::TimeDelta::FromMilliseconds(10));
+ base::TimeDelta::FromMilliseconds(10), false);
// Limits high enough to not be hit by this test.
size_t bytes_limit = 10 * 1024 * 1024;
@@ -201,7 +203,7 @@ TEST_F(ResourcePoolTest, UnusedResourcesEventuallyFreed) {
resource_pool_ =
ResourcePool::Create(resource_provider_.get(), task_runner_.get(),
ResourceProvider::TEXTURE_HINT_IMMUTABLE,
- base::TimeDelta::FromMilliseconds(100));
+ base::TimeDelta::FromMilliseconds(100), false);
// Limits high enough to not be hit by this test.
size_t bytes_limit = 10 * 1024 * 1024;
@@ -317,25 +319,47 @@ TEST_F(ResourcePoolTest, ReuseResource) {
ResourceFormat format = RGBA_8888;
gfx::ColorSpace color_space = gfx::ColorSpace::CreateSRGB();
- // Create unused resources with sizes close to 100, 100.
- resource_pool_->ReleaseResource(
- resource_pool_->CreateResource(gfx::Size(99, 100), format, color_space));
- resource_pool_->ReleaseResource(
- resource_pool_->CreateResource(gfx::Size(99, 99), format, color_space));
- resource_pool_->ReleaseResource(
- resource_pool_->CreateResource(gfx::Size(100, 99), format, color_space));
- resource_pool_->ReleaseResource(
- resource_pool_->CreateResource(gfx::Size(101, 101), format, color_space));
- resource_pool_->CheckBusyResources();
-
- gfx::Size size(100, 100);
- Resource* resource = resource_pool_->ReuseResource(size, format, color_space);
- EXPECT_EQ(nullptr, resource);
- size = gfx::Size(100, 99);
- resource = resource_pool_->ReuseResource(size, format, color_space);
- EXPECT_NE(nullptr, resource);
- ASSERT_EQ(nullptr, resource_pool_->ReuseResource(size, format, color_space));
- resource_pool_->ReleaseResource(resource);
+ // Create unused resource with size 100x100.
+ CheckAndReturnResource(
+ resource_pool_->CreateResource(gfx::Size(100, 100), format, color_space));
+
+ // Try some cases that are too large, none should succeed.
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(101, 100), format,
+ color_space));
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(100, 101), format,
+ color_space));
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(90, 120), format,
+ color_space));
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(120, 120), format,
+ color_space));
+
+ // Try some cases that are more than 2x smaller than 100x100 in area and
+ // won't be re-used.
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(49, 100), format,
+ color_space));
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(100, 49), format,
+ color_space));
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(50, 50), format,
+ color_space));
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(70, 70), format,
+ color_space));
+
+ // Try some cases that are smaller than 100x100, but within 2x area. Reuse
+ // should succeed.
+ CheckAndReturnResource(
+ resource_pool_->ReuseResource(gfx::Size(50, 100), format, color_space));
+ CheckAndReturnResource(
+ resource_pool_->ReuseResource(gfx::Size(100, 50), format, color_space));
+ CheckAndReturnResource(
+ resource_pool_->ReuseResource(gfx::Size(71, 71), format, color_space));
+
+ // 100x100 is an exact match and should succeed. A subsequent request for
+ // the same size should fail (the resource is already in use).
+ Resource* resource =
+ resource_pool_->ReuseResource(gfx::Size(100, 100), format, color_space);
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(100, 100), format,
+ color_space));
+ CheckAndReturnResource(resource);
}
TEST_F(ResourcePoolTest, MemoryStateSuspended) {
@@ -380,7 +404,7 @@ TEST_F(ResourcePoolTest, TextureHintRespected) {
resource_pool_ =
ResourcePool::Create(resource_provider_.get(), task_runner_.get(),
ResourceProvider::TEXTURE_HINT_IMMUTABLE,
- base::TimeDelta::FromMilliseconds(100));
+ base::TimeDelta::FromMilliseconds(100), false);
Resource* resource =
resource_pool_->AcquireResource(size, format, color_space);
EXPECT_TRUE(resource_provider_->IsImmutable(resource->id()));
@@ -389,10 +413,41 @@ TEST_F(ResourcePoolTest, TextureHintRespected) {
resource_pool_ =
ResourcePool::Create(resource_provider_.get(), task_runner_.get(),
ResourceProvider::TEXTURE_HINT_DEFAULT,
- base::TimeDelta::FromMilliseconds(100));
+ base::TimeDelta::FromMilliseconds(100), false);
resource = resource_pool_->AcquireResource(size, format, color_space);
EXPECT_FALSE(resource_provider_->IsImmutable(resource->id()));
resource_pool_->ReleaseResource(resource);
}
+TEST_F(ResourcePoolTest, ExactRequestsRespected) {
+ ResourceFormat format = RGBA_8888;
+ gfx::ColorSpace color_space = gfx::ColorSpace::CreateSRGB();
+
+ resource_pool_ =
+ ResourcePool::Create(resource_provider_.get(), task_runner_.get(),
+ ResourceProvider::TEXTURE_HINT_DEFAULT,
+ base::TimeDelta::FromMilliseconds(100), true);
+
+ // Create unused resource with size 100x100.
+ CheckAndReturnResource(
+ resource_pool_->CreateResource(gfx::Size(100, 100), format, color_space));
+
+ // Try some cases that are smaller than 100x100, but within 2x area which
+ // would typically allow reuse. Reuse should fail due to the .
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(50, 100), format,
+ color_space));
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(100, 50), format,
+ color_space));
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(71, 71), format,
+ color_space));
+
+ // 100x100 is an exact match and should succeed. A subsequent request for
+ // the same size should fail (the resource is already in use).
+ Resource* resource =
+ resource_pool_->ReuseResource(gfx::Size(100, 100), format, color_space);
+ EXPECT_EQ(nullptr, resource_pool_->ReuseResource(gfx::Size(100, 100), format,
+ color_space));
+ CheckAndReturnResource(resource);
+}
+
} // namespace cc
« no previous file with comments | « cc/resources/resource_pool.cc ('k') | cc/test/fake_picture_layer_tiling_client.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698