Lots of random cleanups, mostly for native_theme_win.cc:
[chromium-blink-merge.git] / cc / trees / layer_tree_host_unittest_picture.cc
blob731f69214afcfc462f2c4a65c3cae4d110962c58
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "cc/trees/layer_tree_host.h"
7 #include "cc/test/fake_content_layer_client.h"
8 #include "cc/test/fake_picture_layer.h"
9 #include "cc/test/fake_picture_layer_impl.h"
10 #include "cc/test/layer_tree_test.h"
11 #include "cc/trees/layer_tree_impl.h"
13 namespace cc {
14 namespace {
16 // These tests deal with picture layers.
17 class LayerTreeHostPictureTest : public LayerTreeTest {
18 protected:
19 virtual void InitializeSettings(LayerTreeSettings* settings) OVERRIDE {
20 // PictureLayer can only be used with impl side painting enabled.
21 settings->impl_side_painting = true;
25 class LayerTreeHostPictureTestTwinLayer
26 : public LayerTreeHostPictureTest {
27 virtual void SetupTree() OVERRIDE {
28 LayerTreeHostPictureTest::SetupTree();
30 scoped_refptr<FakePictureLayer> picture =
31 FakePictureLayer::Create(&client_);
32 layer_tree_host()->root_layer()->AddChild(picture);
35 virtual void BeginTest() OVERRIDE {
36 activates_ = 0;
37 PostSetNeedsCommitToMainThread();
40 virtual void DidCommit() OVERRIDE {
41 switch (layer_tree_host()->source_frame_number()) {
42 case 2:
43 // Drop the picture layer from the tree.
44 layer_tree_host()->root_layer()->children()[0]->RemoveFromParent();
45 break;
46 case 3:
47 // Add a new picture layer.
48 scoped_refptr<FakePictureLayer> picture =
49 FakePictureLayer::Create(&client_);
50 layer_tree_host()->root_layer()->AddChild(picture);
51 break;
55 virtual void WillActivateTreeOnThread(LayerTreeHostImpl* impl) OVERRIDE {
56 LayerImpl* pending_root_impl = impl->pending_tree()->root_layer();
57 LayerImpl* active_root_impl = impl->active_tree()->root_layer();
59 if (pending_root_impl->children().empty()) {
60 EXPECT_EQ(2, activates_);
61 return;
64 FakePictureLayerImpl* pending_picture_impl =
65 static_cast<FakePictureLayerImpl*>(pending_root_impl->children()[0]);
67 if (!active_root_impl) {
68 EXPECT_EQ(0, activates_);
69 EXPECT_EQ(NULL, pending_picture_impl->twin_layer());
70 return;
73 if (active_root_impl->children().empty()) {
74 EXPECT_EQ(3, activates_);
75 EXPECT_EQ(NULL, pending_picture_impl->twin_layer());
76 return;
79 FakePictureLayerImpl* active_picture_impl =
80 static_cast<FakePictureLayerImpl*>(active_root_impl->children()[0]);
82 // After the first activation, when we commit again, we'll have a pending
83 // and active layer. Then we recreate a picture layer in the 4th activate
84 // and the next commit will have a pending and active twin again.
85 EXPECT_TRUE(activates_ == 1 || activates_ == 4);
87 EXPECT_EQ(pending_picture_impl, active_picture_impl->twin_layer());
88 EXPECT_EQ(active_picture_impl, pending_picture_impl->twin_layer());
91 virtual void DidActivateTreeOnThread(LayerTreeHostImpl* impl) OVERRIDE {
92 LayerImpl* active_root_impl = impl->active_tree()->root_layer();
94 if (active_root_impl->children().empty()) {
95 EXPECT_EQ(2, activates_);
96 } else {
97 FakePictureLayerImpl* active_picture_impl =
98 static_cast<FakePictureLayerImpl*>(active_root_impl->children()[0]);
100 EXPECT_EQ(NULL, active_picture_impl->twin_layer());
103 ++activates_;
104 if (activates_ <= 4)
105 PostSetNeedsCommitToMainThread();
106 else
107 EndTest();
110 virtual void AfterTest() OVERRIDE {}
112 FakeContentLayerClient client_;
113 int activates_;
116 MULTI_THREAD_TEST_F(LayerTreeHostPictureTestTwinLayer);
118 } // namespace
119 } // namespace cc