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 "base/basictypes.h" | 5 #include "base/basictypes.h" |
6 #include "base/compiler_specific.h" | 6 #include "base/compiler_specific.h" |
7 #include "cc/test/fake_content_layer_client.h" | 7 #include "cc/test/fake_content_layer_client.h" |
8 #include "cc/test/fake_picture_layer.h" | 8 #include "cc/test/fake_picture_layer.h" |
9 #include "cc/test/layer_tree_test.h" | 9 #include "cc/test/layer_tree_test.h" |
10 #include "cc/trees/thread_proxy.h" | 10 #include "cc/trees/proxy_impl.h" |
| 11 #include "cc/trees/proxy_main.h" |
11 | 12 |
12 #define THREAD_PROXY_TEST_F(TEST_FIXTURE_NAME) \ | 13 #define PROXY_MAIN_THREADED_TEST_F(TEST_FIXTURE_NAME) \ |
13 TEST_F(TEST_FIXTURE_NAME, MultiThread) { Run(true); } | 14 TEST_F(TEST_FIXTURE_NAME, MultiThread) { Run(true); } |
14 | 15 |
15 // Do common tests for single thread proxy and thread proxy. | 16 // Do common tests for single thread proxy and proxy main in threaded mode. |
16 // TODO(simonhong): Add SINGLE_THREAD_PROXY_TEST_F | 17 // TODO(simonhong): Add SINGLE_THREAD_PROXY_TEST_F |
17 #define PROXY_TEST_SCHEDULED_ACTION(TEST_FIXTURE_NAME) \ | 18 #define PROXY_TEST_SCHEDULED_ACTION(TEST_FIXTURE_NAME) \ |
18 THREAD_PROXY_TEST_F(TEST_FIXTURE_NAME); | 19 PROXY_MAIN_THREADED_TEST_F(TEST_FIXTURE_NAME); |
19 | 20 |
20 namespace cc { | 21 namespace cc { |
21 | 22 |
22 class ProxyTest : public LayerTreeTest { | 23 class ProxyTest : public LayerTreeTest { |
23 protected: | 24 protected: |
24 ProxyTest() {} | 25 ProxyTest() {} |
25 ~ProxyTest() override {} | 26 ~ProxyTest() override {} |
26 | 27 |
27 void Run(bool threaded) { | 28 void Run(bool threaded) { |
28 // We don't need to care about delegating mode. | 29 // We don't need to care about delegating mode. |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
64 ~ProxyTestScheduledActionsBasic() override {} | 65 ~ProxyTestScheduledActionsBasic() override {} |
65 | 66 |
66 private: | 67 private: |
67 int action_phase_; | 68 int action_phase_; |
68 | 69 |
69 DISALLOW_COPY_AND_ASSIGN(ProxyTestScheduledActionsBasic); | 70 DISALLOW_COPY_AND_ASSIGN(ProxyTestScheduledActionsBasic); |
70 }; | 71 }; |
71 | 72 |
72 PROXY_TEST_SCHEDULED_ACTION(ProxyTestScheduledActionsBasic); | 73 PROXY_TEST_SCHEDULED_ACTION(ProxyTestScheduledActionsBasic); |
73 | 74 |
74 class ThreadProxyTest : public ProxyTest { | 75 class ProxyMainThreaded : public ProxyTest { |
75 protected: | 76 protected: |
76 ThreadProxyTest() | 77 ProxyMainThreaded() |
77 : update_check_layer_( | 78 : update_check_layer_( |
78 FakePictureLayer::Create(layer_settings(), &client_)) {} | 79 FakePictureLayer::Create(layer_settings(), &client_)) {} |
79 ~ThreadProxyTest() override {} | 80 ~ProxyMainThreaded() override {} |
80 | 81 |
81 void SetupTree() override { | 82 void SetupTree() override { |
82 layer_tree_host()->SetRootLayer(update_check_layer_); | 83 layer_tree_host()->SetRootLayer(update_check_layer_); |
83 ProxyTest::SetupTree(); | 84 ProxyTest::SetupTree(); |
84 } | 85 } |
85 | 86 |
86 const ThreadProxy::MainThreadOnly& ThreadProxyMainOnly() const { | |
87 DCHECK(proxy()); | |
88 DCHECK(proxy()->HasImplThread()); | |
89 return static_cast<const ThreadProxy*>(proxy())->main(); | |
90 } | |
91 | |
92 const ThreadProxy::CompositorThreadOnly& ThreadProxyImplOnly() const { | |
93 DCHECK(proxy()); | |
94 DCHECK(proxy()->HasImplThread()); | |
95 return static_cast<const ThreadProxy*>(proxy())->impl(); | |
96 } | |
97 | |
98 protected: | 87 protected: |
99 FakeContentLayerClient client_; | 88 FakeContentLayerClient client_; |
100 scoped_refptr<FakePictureLayer> update_check_layer_; | 89 scoped_refptr<FakePictureLayer> update_check_layer_; |
101 | 90 |
102 private: | 91 private: |
103 DISALLOW_COPY_AND_ASSIGN(ThreadProxyTest); | 92 DISALLOW_COPY_AND_ASSIGN(ProxyMainThreaded); |
104 }; | 93 }; |
105 | 94 |
106 class ThreadProxyTestSetNeedsCommit : public ThreadProxyTest { | 95 class ProxyMainThreadedSetNeedsCommit : public ProxyMainThreaded { |
107 protected: | 96 protected: |
108 ThreadProxyTestSetNeedsCommit() {} | 97 ProxyMainThreadedSetNeedsCommit() {} |
109 ~ThreadProxyTestSetNeedsCommit() override {} | 98 ~ProxyMainThreadedSetNeedsCommit() override {} |
110 | 99 |
111 void BeginTest() override { | 100 void BeginTest() override { |
112 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 101 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
113 ThreadProxyMainOnly().max_requested_pipeline_stage); | 102 GetProxyMain()->max_requested_pipeline_stage()); |
114 | 103 |
115 proxy()->SetNeedsCommit(); | 104 proxy()->SetNeedsCommit(); |
116 | 105 |
117 EXPECT_EQ(ThreadProxy::COMMIT_PIPELINE_STAGE, | 106 EXPECT_EQ(ProxyMain::COMMIT_PIPELINE_STAGE, |
118 ThreadProxyMainOnly().max_requested_pipeline_stage); | 107 GetProxyMain()->max_requested_pipeline_stage()); |
119 } | 108 } |
120 | 109 |
121 void DidBeginMainFrame() override { | 110 void DidBeginMainFrame() override { |
122 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 111 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
123 ThreadProxyMainOnly().max_requested_pipeline_stage); | 112 GetProxyMain()->max_requested_pipeline_stage()); |
124 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 113 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
125 ThreadProxyMainOnly().current_pipeline_stage); | 114 GetProxyMain()->current_pipeline_stage()); |
126 } | 115 } |
127 | 116 |
128 void DidCommit() override { | 117 void DidCommit() override { |
129 EXPECT_EQ(1, update_check_layer_->update_count()); | 118 EXPECT_EQ(1, update_check_layer_->update_count()); |
130 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 119 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
131 ThreadProxyMainOnly().current_pipeline_stage); | 120 GetProxyMain()->current_pipeline_stage()); |
132 EndTest(); | 121 EndTest(); |
133 } | 122 } |
134 | 123 |
135 private: | 124 private: |
136 DISALLOW_COPY_AND_ASSIGN(ThreadProxyTestSetNeedsCommit); | 125 DISALLOW_COPY_AND_ASSIGN(ProxyMainThreadedSetNeedsCommit); |
137 }; | 126 }; |
138 | 127 |
139 THREAD_PROXY_TEST_F(ThreadProxyTestSetNeedsCommit); | 128 PROXY_MAIN_THREADED_TEST_F(ProxyMainThreadedSetNeedsCommit); |
140 | 129 |
141 class ThreadProxyTestSetNeedsAnimate : public ThreadProxyTest { | 130 class ProxyMainThreadedSetNeedsAnimate : public ProxyMainThreaded { |
142 protected: | 131 protected: |
143 ThreadProxyTestSetNeedsAnimate() {} | 132 ProxyMainThreadedSetNeedsAnimate() {} |
144 ~ThreadProxyTestSetNeedsAnimate() override {} | 133 ~ProxyMainThreadedSetNeedsAnimate() override {} |
145 | 134 |
146 void BeginTest() override { | 135 void BeginTest() override { |
147 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 136 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
148 ThreadProxyMainOnly().max_requested_pipeline_stage); | 137 GetProxyMain()->max_requested_pipeline_stage()); |
149 | 138 |
150 proxy()->SetNeedsAnimate(); | 139 proxy()->SetNeedsAnimate(); |
151 | 140 |
152 EXPECT_EQ(ThreadProxy::ANIMATE_PIPELINE_STAGE, | 141 EXPECT_EQ(ProxyMain::ANIMATE_PIPELINE_STAGE, |
153 ThreadProxyMainOnly().max_requested_pipeline_stage); | 142 GetProxyMain()->max_requested_pipeline_stage()); |
154 } | 143 } |
155 | 144 |
156 void DidBeginMainFrame() override { | 145 void DidBeginMainFrame() override { |
157 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 146 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
158 ThreadProxyMainOnly().max_requested_pipeline_stage); | 147 GetProxyMain()->max_requested_pipeline_stage()); |
159 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 148 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
160 ThreadProxyMainOnly().current_pipeline_stage); | 149 GetProxyMain()->current_pipeline_stage()); |
161 } | 150 } |
162 | 151 |
163 void DidCommit() override { | 152 void DidCommit() override { |
164 EXPECT_EQ(0, update_check_layer_->update_count()); | 153 EXPECT_EQ(0, update_check_layer_->update_count()); |
165 EndTest(); | 154 EndTest(); |
166 } | 155 } |
167 | 156 |
168 private: | 157 private: |
169 DISALLOW_COPY_AND_ASSIGN(ThreadProxyTestSetNeedsAnimate); | 158 DISALLOW_COPY_AND_ASSIGN(ProxyMainThreadedSetNeedsAnimate); |
170 }; | 159 }; |
171 | 160 |
172 THREAD_PROXY_TEST_F(ThreadProxyTestSetNeedsAnimate); | 161 PROXY_MAIN_THREADED_TEST_F(ProxyMainThreadedSetNeedsAnimate); |
173 | 162 |
174 class ThreadProxyTestSetNeedsUpdateLayers : public ThreadProxyTest { | 163 class ProxyMainThreadedSetNeedsUpdateLayers : public ProxyMainThreaded { |
175 protected: | 164 protected: |
176 ThreadProxyTestSetNeedsUpdateLayers() {} | 165 ProxyMainThreadedSetNeedsUpdateLayers() {} |
177 ~ThreadProxyTestSetNeedsUpdateLayers() override {} | 166 ~ProxyMainThreadedSetNeedsUpdateLayers() override {} |
178 | 167 |
179 void BeginTest() override { | 168 void BeginTest() override { |
180 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 169 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
181 ThreadProxyMainOnly().max_requested_pipeline_stage); | 170 GetProxyMain()->max_requested_pipeline_stage()); |
182 | 171 |
183 proxy()->SetNeedsUpdateLayers(); | 172 proxy()->SetNeedsUpdateLayers(); |
184 | 173 |
185 EXPECT_EQ(ThreadProxy::UPDATE_LAYERS_PIPELINE_STAGE, | 174 EXPECT_EQ(ProxyMain::UPDATE_LAYERS_PIPELINE_STAGE, |
186 ThreadProxyMainOnly().max_requested_pipeline_stage); | 175 GetProxyMain()->max_requested_pipeline_stage()); |
187 } | 176 } |
188 | 177 |
189 void DidBeginMainFrame() override { | 178 void DidBeginMainFrame() override { |
190 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 179 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
191 ThreadProxyMainOnly().max_requested_pipeline_stage); | 180 GetProxyMain()->max_requested_pipeline_stage()); |
192 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 181 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
193 ThreadProxyMainOnly().current_pipeline_stage); | 182 GetProxyMain()->current_pipeline_stage()); |
194 } | 183 } |
195 | 184 |
196 void DidCommit() override { | 185 void DidCommit() override { |
197 EXPECT_EQ(1, update_check_layer_->update_count()); | 186 EXPECT_EQ(1, update_check_layer_->update_count()); |
198 EndTest(); | 187 EndTest(); |
199 } | 188 } |
200 | 189 |
201 private: | 190 private: |
202 DISALLOW_COPY_AND_ASSIGN(ThreadProxyTestSetNeedsUpdateLayers); | 191 DISALLOW_COPY_AND_ASSIGN(ProxyMainThreadedSetNeedsUpdateLayers); |
203 }; | 192 }; |
204 | 193 |
205 THREAD_PROXY_TEST_F(ThreadProxyTestSetNeedsUpdateLayers); | 194 PROXY_MAIN_THREADED_TEST_F(ProxyMainThreadedSetNeedsUpdateLayers); |
206 | 195 |
207 class ThreadProxyTestSetNeedsUpdateLayersWhileAnimating | 196 class ProxyMainThreadedSetNeedsUpdateLayersWhileAnimating |
208 : public ThreadProxyTest { | 197 : public ProxyMainThreaded { |
209 protected: | 198 protected: |
210 ThreadProxyTestSetNeedsUpdateLayersWhileAnimating() {} | 199 ProxyMainThreadedSetNeedsUpdateLayersWhileAnimating() {} |
211 ~ThreadProxyTestSetNeedsUpdateLayersWhileAnimating() override {} | 200 ~ProxyMainThreadedSetNeedsUpdateLayersWhileAnimating() override {} |
212 | 201 |
213 void BeginTest() override { proxy()->SetNeedsAnimate(); } | 202 void BeginTest() override { proxy()->SetNeedsAnimate(); } |
214 | 203 |
215 void WillBeginMainFrame() override { | 204 void WillBeginMainFrame() override { |
216 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 205 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
217 ThreadProxyMainOnly().max_requested_pipeline_stage); | 206 GetProxyMain()->max_requested_pipeline_stage()); |
218 EXPECT_EQ(ThreadProxy::ANIMATE_PIPELINE_STAGE, | 207 EXPECT_EQ(ProxyMain::ANIMATE_PIPELINE_STAGE, |
219 ThreadProxyMainOnly().current_pipeline_stage); | 208 GetProxyMain()->current_pipeline_stage()); |
220 EXPECT_EQ(ThreadProxy::ANIMATE_PIPELINE_STAGE, | 209 EXPECT_EQ(ProxyMain::ANIMATE_PIPELINE_STAGE, |
221 ThreadProxyMainOnly().final_pipeline_stage); | 210 GetProxyMain()->final_pipeline_stage()); |
222 | 211 |
223 proxy()->SetNeedsUpdateLayers(); | 212 proxy()->SetNeedsUpdateLayers(); |
224 | 213 |
225 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 214 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
226 ThreadProxyMainOnly().max_requested_pipeline_stage); | 215 GetProxyMain()->max_requested_pipeline_stage()); |
227 EXPECT_EQ(ThreadProxy::UPDATE_LAYERS_PIPELINE_STAGE, | 216 EXPECT_EQ(ProxyMain::UPDATE_LAYERS_PIPELINE_STAGE, |
228 ThreadProxyMainOnly().final_pipeline_stage); | 217 GetProxyMain()->final_pipeline_stage()); |
229 } | 218 } |
230 | 219 |
231 void DidBeginMainFrame() override { | 220 void DidBeginMainFrame() override { |
232 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 221 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
233 ThreadProxyMainOnly().max_requested_pipeline_stage); | 222 GetProxyMain()->max_requested_pipeline_stage()); |
234 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 223 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
235 ThreadProxyMainOnly().current_pipeline_stage); | 224 GetProxyMain()->current_pipeline_stage()); |
236 } | 225 } |
237 | 226 |
238 void DidCommit() override { | 227 void DidCommit() override { |
239 EXPECT_EQ(1, update_check_layer_->update_count()); | 228 EXPECT_EQ(1, update_check_layer_->update_count()); |
240 EndTest(); | 229 EndTest(); |
241 } | 230 } |
242 | 231 |
243 private: | 232 private: |
244 DISALLOW_COPY_AND_ASSIGN(ThreadProxyTestSetNeedsUpdateLayersWhileAnimating); | 233 DISALLOW_COPY_AND_ASSIGN(ProxyMainThreadedSetNeedsUpdateLayersWhileAnimating); |
245 }; | 234 }; |
246 | 235 |
247 THREAD_PROXY_TEST_F(ThreadProxyTestSetNeedsUpdateLayersWhileAnimating); | 236 PROXY_MAIN_THREADED_TEST_F(ProxyMainThreadedSetNeedsUpdateLayersWhileAnimating); |
248 | 237 |
249 class ThreadProxyTestSetNeedsCommitWhileAnimating : public ThreadProxyTest { | 238 class ProxyMainThreadedSetNeedsCommitWhileAnimating : public ProxyMainThreaded { |
250 protected: | 239 protected: |
251 ThreadProxyTestSetNeedsCommitWhileAnimating() {} | 240 ProxyMainThreadedSetNeedsCommitWhileAnimating() {} |
252 ~ThreadProxyTestSetNeedsCommitWhileAnimating() override {} | 241 ~ProxyMainThreadedSetNeedsCommitWhileAnimating() override {} |
253 | 242 |
254 void BeginTest() override { proxy()->SetNeedsAnimate(); } | 243 void BeginTest() override { proxy()->SetNeedsAnimate(); } |
255 | 244 |
256 void WillBeginMainFrame() override { | 245 void WillBeginMainFrame() override { |
257 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 246 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
258 ThreadProxyMainOnly().max_requested_pipeline_stage); | 247 GetProxyMain()->max_requested_pipeline_stage()); |
259 EXPECT_EQ(ThreadProxy::ANIMATE_PIPELINE_STAGE, | 248 EXPECT_EQ(ProxyMain::ANIMATE_PIPELINE_STAGE, |
260 ThreadProxyMainOnly().current_pipeline_stage); | 249 GetProxyMain()->current_pipeline_stage()); |
261 EXPECT_EQ(ThreadProxy::ANIMATE_PIPELINE_STAGE, | 250 EXPECT_EQ(ProxyMain::ANIMATE_PIPELINE_STAGE, |
262 ThreadProxyMainOnly().final_pipeline_stage); | 251 GetProxyMain()->final_pipeline_stage()); |
263 | 252 |
264 proxy()->SetNeedsCommit(); | 253 proxy()->SetNeedsCommit(); |
265 | 254 |
266 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 255 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
267 ThreadProxyMainOnly().max_requested_pipeline_stage); | 256 GetProxyMain()->max_requested_pipeline_stage()); |
268 EXPECT_EQ(ThreadProxy::COMMIT_PIPELINE_STAGE, | 257 EXPECT_EQ(ProxyMain::COMMIT_PIPELINE_STAGE, |
269 ThreadProxyMainOnly().final_pipeline_stage); | 258 GetProxyMain()->final_pipeline_stage()); |
270 } | 259 } |
271 | 260 |
272 void DidBeginMainFrame() override { | 261 void DidBeginMainFrame() override { |
273 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 262 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
274 ThreadProxyMainOnly().max_requested_pipeline_stage); | 263 GetProxyMain()->max_requested_pipeline_stage()); |
275 EXPECT_EQ(ThreadProxy::NO_PIPELINE_STAGE, | 264 EXPECT_EQ(ProxyMain::NO_PIPELINE_STAGE, |
276 ThreadProxyMainOnly().current_pipeline_stage); | 265 GetProxyMain()->current_pipeline_stage()); |
277 } | 266 } |
278 | 267 |
279 void DidCommit() override { | 268 void DidCommit() override { |
280 EXPECT_EQ(1, update_check_layer_->update_count()); | 269 EXPECT_EQ(1, update_check_layer_->update_count()); |
281 EndTest(); | 270 EndTest(); |
282 } | 271 } |
283 | 272 |
284 private: | 273 private: |
285 DISALLOW_COPY_AND_ASSIGN(ThreadProxyTestSetNeedsCommitWhileAnimating); | 274 DISALLOW_COPY_AND_ASSIGN(ProxyMainThreadedSetNeedsCommitWhileAnimating); |
286 }; | 275 }; |
287 | 276 |
288 THREAD_PROXY_TEST_F(ThreadProxyTestSetNeedsCommitWhileAnimating); | 277 PROXY_MAIN_THREADED_TEST_F(ProxyMainThreadedSetNeedsCommitWhileAnimating); |
289 | 278 |
290 class ThreadProxyTestCommitWaitsForActivation : public ThreadProxyTest { | 279 class ProxyMainThreadedCommitWaitsForActivation : public ProxyMainThreaded { |
291 protected: | 280 protected: |
292 ThreadProxyTestCommitWaitsForActivation() : commits_completed_(0) {} | 281 ProxyMainThreadedCommitWaitsForActivation() : commits_completed_(0) {} |
293 ~ThreadProxyTestCommitWaitsForActivation() override {} | 282 ~ProxyMainThreadedCommitWaitsForActivation() override {} |
294 | 283 |
295 void BeginTest() override { proxy()->SetNeedsCommit(); } | 284 void BeginTest() override { proxy()->SetNeedsCommit(); } |
296 | 285 |
297 void ScheduledActionCommit() override { | 286 void ScheduledActionCommit() override { |
298 switch (commits_completed_) { | 287 switch (commits_completed_) { |
299 case 0: | 288 case 0: |
300 // The first commit does not wait for activation. Verify that the | 289 // The first commit does not wait for activation. Verify that the |
301 // completion event is cleared. | 290 // completion event is cleared. |
302 EXPECT_FALSE(ThreadProxyImplOnly().commit_completion_event); | 291 EXPECT_FALSE(GetProxyImpl()->HasCommitCompletionEvent()); |
303 EXPECT_FALSE(ThreadProxyImplOnly().next_commit_waits_for_activation); | 292 EXPECT_FALSE(GetProxyImpl()->next_commit_waits_for_activation()); |
304 break; | 293 break; |
305 case 1: | 294 case 1: |
306 // The second commit should be held until activation. | 295 // The second commit should be held until activation. |
307 EXPECT_TRUE(ThreadProxyImplOnly().commit_completion_event); | 296 EXPECT_TRUE(GetProxyImpl()->HasCommitCompletionEvent()); |
308 EXPECT_TRUE(ThreadProxyImplOnly().next_commit_waits_for_activation); | 297 EXPECT_TRUE(GetProxyImpl()->next_commit_waits_for_activation()); |
309 break; | 298 break; |
310 case 2: | 299 case 2: |
311 // The third commit should not wait for activation. | 300 // The third commit should not wait for activation. |
312 EXPECT_FALSE(ThreadProxyImplOnly().commit_completion_event); | 301 EXPECT_FALSE(GetProxyImpl()->HasCommitCompletionEvent()); |
313 EXPECT_FALSE(ThreadProxyImplOnly().next_commit_waits_for_activation); | 302 EXPECT_FALSE(GetProxyImpl()->next_commit_waits_for_activation()); |
314 } | 303 } |
315 } | 304 } |
316 | 305 |
317 void DidActivateSyncTree() override { | 306 void DidActivateSyncTree() override { |
318 // The next_commit_waits_for_activation should have been cleared after the | 307 // The next_commit_waits_for_activation should have been cleared after the |
319 // sync tree is activated. | 308 // sync tree is activated. |
320 EXPECT_FALSE(ThreadProxyImplOnly().next_commit_waits_for_activation); | 309 EXPECT_FALSE(GetProxyImpl()->next_commit_waits_for_activation()); |
321 } | 310 } |
322 | 311 |
323 void DidCommit() override { | 312 void DidCommit() override { |
324 switch (commits_completed_) { | 313 switch (commits_completed_) { |
325 case 0: | 314 case 0: |
326 // The first commit has been completed. Set next commit waits for | 315 // The first commit has been completed. Set next commit waits for |
327 // activation and start another commit. | 316 // activation and start another commit. |
328 commits_completed_++; | 317 commits_completed_++; |
329 proxy()->SetNextCommitWaitsForActivation(); | 318 proxy()->SetNextCommitWaitsForActivation(); |
330 proxy()->SetNeedsCommit(); | 319 proxy()->SetNeedsCommit(); |
331 case 1: | 320 case 1: |
332 // Start another commit to verify that this is not held until | 321 // Start another commit to verify that this is not held until |
333 // activation. | 322 // activation. |
334 commits_completed_++; | 323 commits_completed_++; |
335 proxy()->SetNeedsCommit(); | 324 proxy()->SetNeedsCommit(); |
336 case 2: | 325 case 2: |
337 commits_completed_++; | 326 commits_completed_++; |
338 EndTest(); | 327 EndTest(); |
339 } | 328 } |
340 } | 329 } |
341 | 330 |
342 void AfterTest() override { EXPECT_EQ(3, commits_completed_); } | 331 void AfterTest() override { EXPECT_EQ(3, commits_completed_); } |
343 | 332 |
344 private: | 333 private: |
345 int commits_completed_; | 334 int commits_completed_; |
346 | 335 |
347 DISALLOW_COPY_AND_ASSIGN(ThreadProxyTestCommitWaitsForActivation); | 336 DISALLOW_COPY_AND_ASSIGN(ProxyMainThreadedCommitWaitsForActivation); |
348 }; | 337 }; |
349 | 338 |
350 THREAD_PROXY_TEST_F(ThreadProxyTestCommitWaitsForActivation); | 339 PROXY_MAIN_THREADED_TEST_F(ProxyMainThreadedCommitWaitsForActivation); |
351 | 340 |
352 } // namespace cc | 341 } // namespace cc |
OLD | NEW |