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

Unified Diff: cc/resources/resource_pool_unittest.cc

Issue 2744063002: Revert of cc::ResourcePool - Re-use larger resources for smaller requests (Closed)
Patch Set: Created 3 years, 9 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') | no next file » | 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 ec9bae418579850e880ad1dc322569ef531c8233..aa8e853e0c4f9caa95eda9cd1c30e7fc374f6002 100644
--- a/cc/resources/resource_pool_unittest.cc
+++ b/cc/resources/resource_pool_unittest.cc
@@ -33,12 +33,6 @@
}
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_;
@@ -111,28 +105,32 @@
gfx::ColorSpace color_space1;
gfx::ColorSpace color_space2 = gfx::ColorSpace::CreateSRGB();
- CheckAndReturnResource(
- resource_pool_->AcquireResource(size, format, color_space1));
+ Resource* resource =
+ resource_pool_->AcquireResource(size, format, color_space1);
+ resource_pool_->ReleaseResource(resource);
+ resource_pool_->CheckBusyResources();
EXPECT_EQ(1u, resource_provider_->num_resources());
// Same size/format should re-use resource.
- Resource* resource =
- resource_pool_->AcquireResource(size, format, color_space1);
- EXPECT_EQ(1u, resource_provider_->num_resources());
- CheckAndReturnResource(resource);
+ resource = resource_pool_->AcquireResource(size, format, color_space1);
+ EXPECT_EQ(1u, resource_provider_->num_resources());
+ resource_pool_->ReleaseResource(resource);
+ resource_pool_->CheckBusyResources();
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());
- CheckAndReturnResource(resource);
+ resource_pool_->ReleaseResource(resource);
+ resource_pool_->CheckBusyResources();
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());
- CheckAndReturnResource(resource);
+ resource_pool_->ReleaseResource(resource);
+ resource_pool_->CheckBusyResources();
EXPECT_EQ(3u, resource_provider_->num_resources());
}
@@ -319,47 +317,25 @@
ResourceFormat format = RGBA_8888;
gfx::ColorSpace color_space = gfx::ColorSpace::CreateSRGB();
- // 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);
+ // 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);
}
TEST_F(ResourcePoolTest, MemoryStateSuspended) {
« no previous file with comments | « cc/resources/resource_pool.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698