Chromium Code Reviews| Index: cc/trees/layer_tree_host_unittest_animation.cc |
| diff --git a/cc/trees/layer_tree_host_unittest_animation.cc b/cc/trees/layer_tree_host_unittest_animation.cc |
| index 423462148be821a37fe373e7469c2bcdbbfe7b29..8662e1693b76c41bf0065f815b3b39ceb5a215b5 100644 |
| --- a/cc/trees/layer_tree_host_unittest_animation.cc |
| +++ b/cc/trees/layer_tree_host_unittest_animation.cc |
| @@ -765,5 +765,57 @@ class LayerTreeHostAnimationTestCheckerboardDoesntStartAnimations |
| MULTI_THREAD_TEST_F( |
| LayerTreeHostAnimationTestCheckerboardDoesntStartAnimations); |
| +// Test that creating a pinch-zoom scrollbar animation leads to AnimateLayers |
| +// being called. |
| +class LayerTreeHostAnimationTestPinchZoomScrollbars |
| + : public LayerTreeHostAnimationTest { |
| + public: |
| + LayerTreeHostAnimationTestPinchZoomScrollbars() |
| + : root_layer_(ContentLayer::Create(&client_)), |
| + started_times_(0) {} |
| + |
| + virtual void InitializeSettings(LayerTreeSettings* settings) OVERRIDE { |
| + settings->use_pinch_zoom_scrollbars = true; |
| + } |
| + |
| + virtual void BeginTest() OVERRIDE { |
| + root_layer_->SetIsDrawable(true); |
| + root_layer_->SetBounds(gfx::Size(100, 100)); |
| + layer_tree_host()->SetRootLayer(root_layer_); |
|
danakj
2013/04/17 20:54:09
Can you set up the layer tree in SetupTree() inste
ajuma
2013/04/18 18:42:51
Done.
|
| + layer_tree_host()->SetPageScaleFactorAndLimits(0.5, 0.5, 0.9); |
|
danakj
2013/04/17 20:54:09
These are floats. 0.5f etc
wjmaclean
2013/04/17 20:56:54
Minor nit: we generally would only have pinch zoom
danakj
2013/04/17 21:01:03
Oh, is this test actually triggering the scrollbar
ajuma
2013/04/18 18:42:51
Done.
|
| + PostSetNeedsCommitToMainThread(); |
| + } |
| + |
| + virtual void AnimateLayers(LayerTreeHostImpl* host_impl, |
| + base::TimeTicks monotonic_time) OVERRIDE { |
| + if (host_impl->active_tree()->page_scale_factor() == 1.0) |
|
danakj
2013/04/17 20:54:09
1.f
ajuma
2013/04/18 18:42:51
Done.
|
| + return; |
| + |
| + if (started_times_ == 0) { |
|
danakj
2013/04/17 20:54:09
seems like a good spot for a switch?
ajuma
2013/04/18 18:42:51
Done.
|
| + host_impl->active_tree()->DidBeginScroll(); |
| + started_times_++; |
| + return; |
| + } |
| + |
| + if (started_times_ == 1) { |
| + host_impl->active_tree()->DidEndScroll(); |
| + started_times_++; |
| + return; |
| + } |
| + |
| + if (started_times_ == 2) |
| + EndTest(); |
| + } |
| + |
| + virtual void AfterTest() OVERRIDE {} |
| + |
| + private: |
| + FakeContentLayerClient client_; |
| + scoped_refptr<ContentLayer> root_layer_; |
| + int started_times_; |
| +}; |
| + |
| +SINGLE_AND_MULTI_THREAD_TEST_F(LayerTreeHostAnimationTestPinchZoomScrollbars); |
| + |
| } // namespace |
| } // namespace cc |