OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include <set> | 5 #include <set> |
6 #include <vector> | 6 #include <vector> |
7 | 7 |
8 #include "base/location.h" | 8 #include "base/location.h" |
9 #include "base/single_thread_task_runner.h" | 9 #include "base/single_thread_task_runner.h" |
10 #include "base/thread_task_runner_handle.h" | 10 #include "base/thread_task_runner_handle.h" |
(...skipping 28 matching lines...) Expand all Loading... |
39 void TearDown() override { | 39 void TearDown() override { |
40 if (layer_tree_host_) { | 40 if (layer_tree_host_) { |
41 layer_tree_host_->SetRootLayer(nullptr); | 41 layer_tree_host_->SetRootLayer(nullptr); |
42 layer_tree_host_ = nullptr; | 42 layer_tree_host_ = nullptr; |
43 } | 43 } |
44 } | 44 } |
45 | 45 |
46 scoped_ptr<FakeLayerTreeHost> layer_tree_host_; | 46 scoped_ptr<FakeLayerTreeHost> layer_tree_host_; |
47 FakeLayerTreeHostClient fake_client_; | 47 FakeLayerTreeHostClient fake_client_; |
48 TestSharedBitmapManager shared_bitmap_manager_; | 48 TestSharedBitmapManager shared_bitmap_manager_; |
| 49 LayerSettings layer_settings_; |
49 }; | 50 }; |
50 | 51 |
51 void SatisfyCallback(SurfaceSequence* out, SurfaceSequence in) { | 52 void SatisfyCallback(SurfaceSequence* out, SurfaceSequence in) { |
52 *out = in; | 53 *out = in; |
53 } | 54 } |
54 | 55 |
55 void RequireCallback(SurfaceId* out_id, | 56 void RequireCallback(SurfaceId* out_id, |
56 std::set<SurfaceSequence>* out, | 57 std::set<SurfaceSequence>* out, |
57 SurfaceId in_id, | 58 SurfaceId in_id, |
58 SurfaceSequence in) { | 59 SurfaceSequence in) { |
59 *out_id = in_id; | 60 *out_id = in_id; |
60 out->insert(in); | 61 out->insert(in); |
61 } | 62 } |
62 | 63 |
63 // Check that one surface can be referenced by multiple LayerTreeHosts, and | 64 // Check that one surface can be referenced by multiple LayerTreeHosts, and |
64 // each will create its own SurfaceSequence that's satisfied on destruction. | 65 // each will create its own SurfaceSequence that's satisfied on destruction. |
65 TEST_F(SurfaceLayerTest, MultipleFramesOneSurface) { | 66 TEST_F(SurfaceLayerTest, MultipleFramesOneSurface) { |
66 SurfaceSequence blank_change; // Receives sequence if commit doesn't happen. | 67 SurfaceSequence blank_change; // Receives sequence if commit doesn't happen. |
67 | 68 |
68 SurfaceId required_id; | 69 SurfaceId required_id; |
69 std::set<SurfaceSequence> required_seq; | 70 std::set<SurfaceSequence> required_seq; |
70 scoped_refptr<SurfaceLayer> layer(SurfaceLayer::Create( | 71 scoped_refptr<SurfaceLayer> layer(SurfaceLayer::Create( |
71 base::Bind(&SatisfyCallback, &blank_change), | 72 layer_settings_, base::Bind(&SatisfyCallback, &blank_change), |
72 base::Bind(&RequireCallback, &required_id, &required_seq))); | 73 base::Bind(&RequireCallback, &required_id, &required_seq))); |
73 layer->SetSurfaceId(SurfaceId(1), 1.f, gfx::Size(1, 1)); | 74 layer->SetSurfaceId(SurfaceId(1), 1.f, gfx::Size(1, 1)); |
74 layer_tree_host_->set_surface_id_namespace(1); | 75 layer_tree_host_->set_surface_id_namespace(1); |
75 layer_tree_host_->SetRootLayer(layer); | 76 layer_tree_host_->SetRootLayer(layer); |
76 | 77 |
77 scoped_ptr<FakeLayerTreeHost> layer_tree_host2 = | 78 scoped_ptr<FakeLayerTreeHost> layer_tree_host2 = |
78 FakeLayerTreeHost::Create(&fake_client_); | 79 FakeLayerTreeHost::Create(&fake_client_); |
79 scoped_refptr<SurfaceLayer> layer2(SurfaceLayer::Create( | 80 scoped_refptr<SurfaceLayer> layer2(SurfaceLayer::Create( |
80 base::Bind(&SatisfyCallback, &blank_change), | 81 layer_settings_, base::Bind(&SatisfyCallback, &blank_change), |
81 base::Bind(&RequireCallback, &required_id, &required_seq))); | 82 base::Bind(&RequireCallback, &required_id, &required_seq))); |
82 layer2->SetSurfaceId(SurfaceId(1), 1.f, gfx::Size(1, 1)); | 83 layer2->SetSurfaceId(SurfaceId(1), 1.f, gfx::Size(1, 1)); |
83 layer_tree_host2->set_surface_id_namespace(2); | 84 layer_tree_host2->set_surface_id_namespace(2); |
84 layer_tree_host2->SetRootLayer(layer2); | 85 layer_tree_host2->SetRootLayer(layer2); |
85 | 86 |
86 // Layers haven't been removed, so no sequence should be satisfied. | 87 // Layers haven't been removed, so no sequence should be satisfied. |
87 EXPECT_TRUE(blank_change.is_null()); | 88 EXPECT_TRUE(blank_change.is_null()); |
88 | 89 |
89 SurfaceSequence expected1(1u, 1u); | 90 SurfaceSequence expected1(1u, 1u); |
90 SurfaceSequence expected2(2u, 1u); | 91 SurfaceSequence expected2(2u, 1u); |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
122 inputs.device_scale_factor = device_scale_factor; | 123 inputs.device_scale_factor = device_scale_factor; |
123 LayerTreeHostCommon::CalculateDrawProperties(&inputs); | 124 LayerTreeHostCommon::CalculateDrawProperties(&inputs); |
124 } | 125 } |
125 | 126 |
126 // Check that setting content scale on the surface works. | 127 // Check that setting content scale on the surface works. |
127 TEST_F(SurfaceLayerTest, ScaleSurface) { | 128 TEST_F(SurfaceLayerTest, ScaleSurface) { |
128 SurfaceSequence blank_change; | 129 SurfaceSequence blank_change; |
129 SurfaceId required_id; | 130 SurfaceId required_id; |
130 std::set<SurfaceSequence> required_seq; | 131 std::set<SurfaceSequence> required_seq; |
131 scoped_refptr<SurfaceLayer> layer(SurfaceLayer::Create( | 132 scoped_refptr<SurfaceLayer> layer(SurfaceLayer::Create( |
132 base::Bind(&SatisfyCallback, &blank_change), | 133 layer_settings_, base::Bind(&SatisfyCallback, &blank_change), |
133 base::Bind(&RequireCallback, &required_id, &required_seq))); | 134 base::Bind(&RequireCallback, &required_id, &required_seq))); |
134 gfx::Size surface_size(10, 15); | 135 gfx::Size surface_size(10, 15); |
135 layer->SetSurfaceId(SurfaceId(1), 2.f, surface_size); | 136 layer->SetSurfaceId(SurfaceId(1), 2.f, surface_size); |
136 layer->SetBounds(gfx::Size(25, 45)); | 137 layer->SetBounds(gfx::Size(25, 45)); |
137 layer_tree_host_->SetRootLayer(layer); | 138 layer_tree_host_->SetRootLayer(layer); |
138 | 139 |
139 CalcDrawProps(layer_tree_host_.get(), 5.f); | 140 CalcDrawProps(layer_tree_host_.get(), 5.f); |
140 EXPECT_EQ(2.f, layer->contents_scale_x()); | 141 EXPECT_EQ(2.f, layer->contents_scale_x()); |
141 EXPECT_EQ(2.f, layer->contents_scale_y()); | 142 EXPECT_EQ(2.f, layer->contents_scale_y()); |
142 EXPECT_EQ(surface_size.ToString(), layer->content_bounds().ToString()); | 143 EXPECT_EQ(surface_size.ToString(), layer->content_bounds().ToString()); |
143 | 144 |
144 layer_tree_host_->SetRootLayer(nullptr); | 145 layer_tree_host_->SetRootLayer(nullptr); |
145 layer_tree_host_.reset(); | 146 layer_tree_host_.reset(); |
146 } | 147 } |
147 | 148 |
148 // Check that SurfaceSequence is sent through swap promise. | 149 // Check that SurfaceSequence is sent through swap promise. |
149 class SurfaceLayerSwapPromise : public LayerTreeTest { | 150 class SurfaceLayerSwapPromise : public LayerTreeTest { |
150 public: | 151 public: |
151 SurfaceLayerSwapPromise() | 152 SurfaceLayerSwapPromise() |
152 : commit_count_(0), sequence_was_satisfied_(false) {} | 153 : commit_count_(0), sequence_was_satisfied_(false) {} |
153 | 154 |
154 void BeginTest() override { | 155 void BeginTest() override { |
155 layer_tree_host()->set_surface_id_namespace(1); | 156 layer_tree_host()->set_surface_id_namespace(1); |
156 layer_ = SurfaceLayer::Create( | 157 layer_ = SurfaceLayer::Create( |
157 base::Bind(&SatisfyCallback, &satisfied_sequence_), | 158 layer_settings(), base::Bind(&SatisfyCallback, &satisfied_sequence_), |
158 base::Bind(&RequireCallback, &required_id_, &required_set_)); | 159 base::Bind(&RequireCallback, &required_id_, &required_set_)); |
159 layer_->SetSurfaceId(SurfaceId(1), 1.f, gfx::Size(1, 1)); | 160 layer_->SetSurfaceId(SurfaceId(1), 1.f, gfx::Size(1, 1)); |
160 | 161 |
161 // Layer hasn't been added to tree so no SurfaceSequence generated yet. | 162 // Layer hasn't been added to tree so no SurfaceSequence generated yet. |
162 EXPECT_EQ(0u, required_set_.size()); | 163 EXPECT_EQ(0u, required_set_.size()); |
163 | 164 |
164 layer_tree_host()->SetRootLayer(layer_); | 165 layer_tree_host()->SetRootLayer(layer_); |
165 | 166 |
166 // Should have SurfaceSequence from first tree. | 167 // Should have SurfaceSequence from first tree. |
167 SurfaceSequence expected(1u, 1u); | 168 SurfaceSequence expected(1u, 1u); |
(...skipping 10 matching lines...) Expand all Loading... |
178 base::ThreadTaskRunnerHandle::Get()->PostTask( | 179 base::ThreadTaskRunnerHandle::Get()->PostTask( |
179 FROM_HERE, base::Bind(&SurfaceLayerSwapPromise::ChangeTree, | 180 FROM_HERE, base::Bind(&SurfaceLayerSwapPromise::ChangeTree, |
180 base::Unretained(this))); | 181 base::Unretained(this))); |
181 } | 182 } |
182 | 183 |
183 void ChangeTree() { | 184 void ChangeTree() { |
184 ++commit_count_; | 185 ++commit_count_; |
185 switch (commit_count_) { | 186 switch (commit_count_) { |
186 case 1: | 187 case 1: |
187 // Remove SurfaceLayer from tree to cause SwapPromise to be created. | 188 // Remove SurfaceLayer from tree to cause SwapPromise to be created. |
188 blank_layer_ = SolidColorLayer::Create(); | 189 blank_layer_ = SolidColorLayer::Create(layer_settings()); |
189 blank_layer_->SetIsDrawable(true); | 190 blank_layer_->SetIsDrawable(true); |
190 blank_layer_->SetBounds(gfx::Size(10, 10)); | 191 blank_layer_->SetBounds(gfx::Size(10, 10)); |
191 layer_tree_host()->SetRootLayer(blank_layer_); | 192 layer_tree_host()->SetRootLayer(blank_layer_); |
192 break; | 193 break; |
193 case 2: | 194 case 2: |
194 break; | 195 break; |
195 default: | 196 default: |
196 NOTREACHED(); | 197 NOTREACHED(); |
197 break; | 198 break; |
198 } | 199 } |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
232 SurfaceId required_id_; | 233 SurfaceId required_id_; |
233 std::set<SurfaceSequence> required_set_; | 234 std::set<SurfaceSequence> required_set_; |
234 }; | 235 }; |
235 | 236 |
236 // TODO(jbauman): Reenable on single thread once http://crbug.com/421923 is | 237 // TODO(jbauman): Reenable on single thread once http://crbug.com/421923 is |
237 // fixed. | 238 // fixed. |
238 MULTI_THREAD_TEST_F(SurfaceLayerSwapPromise); | 239 MULTI_THREAD_TEST_F(SurfaceLayerSwapPromise); |
239 | 240 |
240 } // namespace | 241 } // namespace |
241 } // namespace cc | 242 } // namespace cc |
OLD | NEW |