Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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 "cc/trees/layer_tree_host.h" | 5 #include "cc/trees/layer_tree_host.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "cc/layers/delegated_frame_provider.h" | 8 #include "cc/layers/delegated_frame_provider.h" |
| 9 #include "cc/layers/delegated_frame_resource_collection.h" | 9 #include "cc/layers/delegated_frame_resource_collection.h" |
| 10 #include "cc/layers/heads_up_display_layer.h" | 10 #include "cc/layers/heads_up_display_layer.h" |
| (...skipping 364 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 375 } | 375 } |
| 376 | 376 |
| 377 void DidInitializeOutputSurface() override { EXPECT_TRUE(false); } | 377 void DidInitializeOutputSurface() override { EXPECT_TRUE(false); } |
| 378 | 378 |
| 379 void AfterTest() override {} | 379 void AfterTest() override {} |
| 380 }; | 380 }; |
| 381 | 381 |
| 382 SINGLE_AND_MULTI_THREAD_TEST_F( | 382 SINGLE_AND_MULTI_THREAD_TEST_F( |
| 383 LayerTreeHostClientNotReadyDoesNotCreateOutputSurface); | 383 LayerTreeHostClientNotReadyDoesNotCreateOutputSurface); |
| 384 | 384 |
| 385 // This tests the OutputSurface release logic in the following sequence. | |
| 386 // SetUp LTH and create and init OutputSurface | |
| 387 // LTH::SetVisible(false); | |
| 388 // LTH::ReleaseOutputSurface(); | |
| 389 // ... | |
| 390 // Create and init new OutputSurface | |
| 391 // LTH::SetVisible(true); | |
| 392 class LayerTreeHostClientTakeAwayOutputSurface | |
| 393 : public LayerTreeHostContextTest { | |
| 394 public: | |
| 395 LayerTreeHostClientTakeAwayOutputSurface() | |
| 396 : LayerTreeHostContextTest(), setos_counter_(0) {} | |
| 397 | |
| 398 void BeginTest() override { PostSetNeedsCommitToMainThread(); } | |
| 399 | |
| 400 void RequestNewOutputSurface() override { | |
| 401 if (layer_tree_host()->visible()) | |
| 402 CreateAndSetOutputSurface(); | |
| 403 else | |
| 404 EndTest(); | |
|
no sievers
2015/09/14 21:28:13
Can we still go through and create another OutputS
sohanjg
2015/09/15 06:39:34
Yes, in the current form we were getting RequestNe
| |
| 405 } | |
| 406 | |
| 407 void CreateAndSetOutputSurface() { | |
| 408 scoped_ptr<OutputSurface> surface = | |
| 409 LayerTreeHostContextTest::CreateOutputSurface(); | |
| 410 CHECK(surface); | |
| 411 setos_counter_++; | |
| 412 layer_tree_host()->SetOutputSurface(surface.Pass()); | |
| 413 } | |
| 414 | |
| 415 void HideAndReleaseOutputSurface() { | |
| 416 EXPECT_TRUE(layer_tree_host()->proxy()->IsMainThread()); | |
| 417 layer_tree_host()->SetVisible(false); | |
| 418 scoped_ptr<OutputSurface> surface = | |
| 419 layer_tree_host()->ReleaseOutputSurface(); | |
| 420 CHECK(surface); | |
| 421 surface->context_provider()->DetachFromThread(); | |
| 422 MainThreadTaskRunner()->PostTask( | |
| 423 FROM_HERE, | |
| 424 base::Bind(&LayerTreeHostClientTakeAwayOutputSurface::MakeVisible, | |
| 425 base::Unretained(this))); | |
| 426 } | |
| 427 | |
| 428 void DidInitializeOutputSurface() override { | |
| 429 if (setos_counter_ == 1) { | |
| 430 EXPECT_TRUE(layer_tree_host()->visible()); | |
|
no sievers
2015/09/14 21:28:13
I think you can pull this out of the if-block rega
sohanjg
2015/09/15 06:39:34
Done.
| |
| 431 MainThreadTaskRunner()->PostTask( | |
| 432 FROM_HERE, base::Bind(&LayerTreeHostClientTakeAwayOutputSurface:: | |
| 433 HideAndReleaseOutputSurface, | |
| 434 base::Unretained(this))); | |
| 435 } | |
| 436 } | |
| 437 | |
| 438 void MakeVisible() { | |
| 439 EXPECT_TRUE(layer_tree_host()->proxy()->IsMainThread()); | |
| 440 layer_tree_host()->SetVisible(true); | |
| 441 } | |
| 442 | |
| 443 void AfterTest() override {} | |
| 444 | |
| 445 int setos_counter_; | |
| 446 }; | |
| 447 | |
| 448 SINGLE_AND_MULTI_THREAD_TEST_F(LayerTreeHostClientTakeAwayOutputSurface); | |
| 449 | |
| 385 class MultipleCompositeDoesNotCreateOutputSurface | 450 class MultipleCompositeDoesNotCreateOutputSurface |
| 386 : public LayerTreeHostContextTest { | 451 : public LayerTreeHostContextTest { |
| 387 public: | 452 public: |
| 388 MultipleCompositeDoesNotCreateOutputSurface() | 453 MultipleCompositeDoesNotCreateOutputSurface() |
| 389 : LayerTreeHostContextTest(), request_count_(0) {} | 454 : LayerTreeHostContextTest(), request_count_(0) {} |
| 390 | 455 |
| 391 void InitializeSettings(LayerTreeSettings* settings) override { | 456 void InitializeSettings(LayerTreeSettings* settings) override { |
| 392 settings->single_thread_proxy_scheduler = false; | 457 settings->single_thread_proxy_scheduler = false; |
| 393 settings->use_zero_copy = true; | 458 settings->use_zero_copy = true; |
| 394 } | 459 } |
| (...skipping 1163 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1558 void AfterTest() override {} | 1623 void AfterTest() override {} |
| 1559 | 1624 |
| 1560 bool deferred_; | 1625 bool deferred_; |
| 1561 }; | 1626 }; |
| 1562 | 1627 |
| 1563 SINGLE_AND_MULTI_THREAD_TEST_F( | 1628 SINGLE_AND_MULTI_THREAD_TEST_F( |
| 1564 LayerTreeHostContextTestLoseAfterSendingBeginMainFrame); | 1629 LayerTreeHostContextTestLoseAfterSendingBeginMainFrame); |
| 1565 | 1630 |
| 1566 } // namespace | 1631 } // namespace |
| 1567 } // namespace cc | 1632 } // namespace cc |
| OLD | NEW |