Chromium Code Reviews| Index: cc/output/context_cache_controller_unittest.cc |
| diff --git a/cc/output/context_cache_controller_unittest.cc b/cc/output/context_cache_controller_unittest.cc |
| index 67831aa16c151e237e7c9e776d10ecb0cd705d67..e137c257ef2a80c4a11bde21f258033f202ad279 100644 |
| --- a/cc/output/context_cache_controller_unittest.cc |
| +++ b/cc/output/context_cache_controller_unittest.cc |
| @@ -5,6 +5,7 @@ |
| #include "cc/output/context_cache_controller.h" |
| #include "base/memory/ptr_util.h" |
| +#include "base/test/test_mock_time_task_runner.h" |
| #include "cc/test/test_context_provider.h" |
| #include "cc/test/test_context_support.h" |
| #include "cc/test/test_web_graphics_context_3d.h" |
| @@ -25,7 +26,8 @@ class MockContextSupport : public TestContextSupport { |
| TEST(ContextCacheControllerTest, ScopedVisibilityBasic) { |
| StrictMock<MockContextSupport> context_support; |
| - ContextCacheController cache_controller(&context_support, nullptr); |
| + auto task_runner = make_scoped_refptr(new base::TestMockTimeTaskRunner()); |
|
danakj
2016/09/22 00:01:25
nit: no()
ericrk
2016/09/22 00:28:59
Done.
|
| + ContextCacheController cache_controller(&context_support, task_runner); |
| EXPECT_CALL(context_support, SetAggressivelyFreeResources(false)); |
| std::unique_ptr<ContextCacheController::ScopedVisibility> visibility = |
| @@ -38,19 +40,76 @@ TEST(ContextCacheControllerTest, ScopedVisibilityBasic) { |
| TEST(ContextCacheControllerTest, ScopedVisibilityMulti) { |
| StrictMock<MockContextSupport> context_support; |
| - ContextCacheController cache_controller(&context_support, nullptr); |
| + auto task_runner = make_scoped_refptr(new base::TestMockTimeTaskRunner()); |
|
danakj
2016/09/22 00:01:25
nitto
ericrk
2016/09/22 00:28:59
Done.
|
| + ContextCacheController cache_controller(&context_support, task_runner); |
| EXPECT_CALL(context_support, SetAggressivelyFreeResources(false)); |
| - std::unique_ptr<ContextCacheController::ScopedVisibility> visibility_1 = |
| - cache_controller.ClientBecameVisible(); |
| + auto visibility_1 = cache_controller.ClientBecameVisible(); |
| Mock::VerifyAndClearExpectations(&context_support); |
| - std::unique_ptr<ContextCacheController::ScopedVisibility> visibility_2 = |
| - cache_controller.ClientBecameVisible(); |
| + auto visibility_2 = cache_controller.ClientBecameVisible(); |
| cache_controller.ClientBecameNotVisible(std::move(visibility_1)); |
| EXPECT_CALL(context_support, SetAggressivelyFreeResources(true)); |
| cache_controller.ClientBecameNotVisible(std::move(visibility_2)); |
| } |
| +TEST(ContextCacheControllerTest, ScopedBusyWhileVisible) { |
| + StrictMock<MockContextSupport> context_support; |
| + auto task_runner = make_scoped_refptr(new base::TestMockTimeTaskRunner()); |
| + ContextCacheController cache_controller(&context_support, task_runner); |
| + |
| + EXPECT_CALL(context_support, SetAggressivelyFreeResources(false)); |
| + auto visibility = cache_controller.ClientBecameVisible(); |
| + Mock::VerifyAndClearExpectations(&context_support); |
| + |
| + // Now that we're visible, ensure that going idle triggers a delayed cleanup. |
| + auto busy = cache_controller.ClientBecameBusy(); |
| + cache_controller.ClientBecameNotBusy(std::move(busy)); |
| + |
| + EXPECT_CALL(context_support, SetAggressivelyFreeResources(true)); |
| + EXPECT_CALL(context_support, SetAggressivelyFreeResources(false)); |
| + task_runner->FastForwardBy(base::TimeDelta::FromSeconds(5)); |
| + Mock::VerifyAndClearExpectations(&context_support); |
| + |
| + EXPECT_CALL(context_support, SetAggressivelyFreeResources(true)); |
| + cache_controller.ClientBecameNotVisible(std::move(visibility)); |
| +} |
| + |
| +TEST(ContextCacheControllerTest, ScopedBusyWhileNotVisible) { |
| + StrictMock<MockContextSupport> context_support; |
| + auto task_runner = make_scoped_refptr(new base::TestMockTimeTaskRunner()); |
| + ContextCacheController cache_controller(&context_support, task_runner); |
| + |
| + auto busy = cache_controller.ClientBecameBusy(); |
| + |
| + // We are not visible, so becoming busy should not trigger an idle callback. |
| + cache_controller.ClientBecameNotBusy(std::move(busy)); |
| + task_runner->FastForwardBy(base::TimeDelta::FromSeconds(5)); |
| +} |
| + |
| +TEST(ContextCacheControllerTest, ScopedBusyMulitpleWhileVisible) { |
| + StrictMock<MockContextSupport> context_support; |
| + auto task_runner = make_scoped_refptr(new base::TestMockTimeTaskRunner()); |
| + ContextCacheController cache_controller(&context_support, task_runner); |
| + |
| + EXPECT_CALL(context_support, SetAggressivelyFreeResources(false)); |
| + auto visible = cache_controller.ClientBecameVisible(); |
| + Mock::VerifyAndClearExpectations(&context_support); |
| + |
| + auto busy_1 = cache_controller.ClientBecameBusy(); |
| + cache_controller.ClientBecameNotBusy(std::move(busy_1)); |
| + auto busy_2 = cache_controller.ClientBecameBusy(); |
| + cache_controller.ClientBecameNotBusy(std::move(busy_2)); |
| + |
| + // When we fast forward, only one cleanup should happen. |
| + EXPECT_CALL(context_support, SetAggressivelyFreeResources(true)); |
| + EXPECT_CALL(context_support, SetAggressivelyFreeResources(false)); |
| + task_runner->FastForwardBy(base::TimeDelta::FromSeconds(5)); |
| + Mock::VerifyAndClearExpectations(&context_support); |
| + |
| + EXPECT_CALL(context_support, SetAggressivelyFreeResources(true)); |
| + cache_controller.ClientBecameNotVisible(std::move(visible)); |
| +} |
| + |
| } // namespace |
| } // namespace cc |