| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/surfaces/display.h" | 5 #include "cc/surfaces/display.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/test/null_task_runner.h" | 9 #include "base/test/null_task_runner.h" |
| 10 #include "cc/output/compositor_frame.h" | 10 #include "cc/output/compositor_frame.h" |
| 11 #include "cc/output/copy_output_result.h" | 11 #include "cc/output/copy_output_result.h" |
| 12 #include "cc/output/delegated_frame_data.h" | 12 #include "cc/output/delegated_frame_data.h" |
| 13 #include "cc/output/texture_mailbox_deleter.h" | 13 #include "cc/output/texture_mailbox_deleter.h" |
| 14 #include "cc/quads/render_pass.h" | 14 #include "cc/quads/render_pass.h" |
| 15 #include "cc/resources/shared_bitmap_manager.h" | 15 #include "cc/resources/shared_bitmap_manager.h" |
| 16 #include "cc/scheduler/begin_frame_source.h" | 16 #include "cc/scheduler/begin_frame_source.h" |
| 17 #include "cc/surfaces/display_client.h" | 17 #include "cc/surfaces/display_client.h" |
| 18 #include "cc/surfaces/display_scheduler.h" | 18 #include "cc/surfaces/display_scheduler.h" |
| 19 #include "cc/surfaces/frame_sink_id.h" | 19 #include "cc/surfaces/frame_sink_id.h" |
| 20 #include "cc/surfaces/surface.h" | 20 #include "cc/surfaces/surface.h" |
| 21 #include "cc/surfaces/surface_factory.h" | 21 #include "cc/surfaces/surface_factory.h" |
| 22 #include "cc/surfaces/surface_factory_client.h" | 22 #include "cc/surfaces/surface_factory_client.h" |
| 23 #include "cc/surfaces/surface_id_allocator.h" | 23 #include "cc/surfaces/surface_id_allocator.h" |
| 24 #include "cc/surfaces/surface_manager.h" | 24 #include "cc/surfaces/surface_manager.h" |
| 25 #include "cc/test/fake_output_surface.h" | 25 #include "cc/test/fake_output_surface.h" |
| 26 #include "cc/test/scheduler_test_common.h" | 26 #include "cc/test/scheduler_test_common.h" |
| 27 #include "cc/test/test_shared_bitmap_manager.h" | 27 #include "cc/test/test_shared_bitmap_manager.h" |
| 28 #include "gpu/GLES2/gl2extchromium.h" |
| 28 #include "testing/gmock/include/gmock/gmock.h" | 29 #include "testing/gmock/include/gmock/gmock.h" |
| 29 #include "testing/gtest/include/gtest/gtest.h" | 30 #include "testing/gtest/include/gtest/gtest.h" |
| 30 | 31 |
| 31 using testing::AnyNumber; | 32 using testing::AnyNumber; |
| 32 | 33 |
| 33 namespace cc { | 34 namespace cc { |
| 34 namespace { | 35 namespace { |
| 35 | 36 |
| 36 static constexpr FrameSinkId kArbitraryFrameSinkId(3, 3); | 37 static constexpr FrameSinkId kArbitraryFrameSinkId(3, 3); |
| 37 | 38 |
| (...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 108 manager_.InvalidateFrameSinkId(kArbitraryFrameSinkId); | 109 manager_.InvalidateFrameSinkId(kArbitraryFrameSinkId); |
| 109 } | 110 } |
| 110 | 111 |
| 111 void SetUpDisplay(const RendererSettings& settings, | 112 void SetUpDisplay(const RendererSettings& settings, |
| 112 std::unique_ptr<TestWebGraphicsContext3D> context) { | 113 std::unique_ptr<TestWebGraphicsContext3D> context) { |
| 113 std::unique_ptr<BeginFrameSource> begin_frame_source( | 114 std::unique_ptr<BeginFrameSource> begin_frame_source( |
| 114 new StubBeginFrameSource); | 115 new StubBeginFrameSource); |
| 115 | 116 |
| 116 std::unique_ptr<FakeOutputSurface> output_surface; | 117 std::unique_ptr<FakeOutputSurface> output_surface; |
| 117 if (context) { | 118 if (context) { |
| 118 output_surface = FakeOutputSurface::Create3d(std::move(context)); | 119 auto provider = TestContextProvider::Create(std::move(context)); |
| 120 provider->BindToCurrentThread(); |
| 121 output_surface = FakeOutputSurface::Create3d(std::move(provider)); |
| 119 } else { | 122 } else { |
| 120 std::unique_ptr<TestSoftwareOutputDevice> device( | 123 std::unique_ptr<TestSoftwareOutputDevice> device( |
| 121 new TestSoftwareOutputDevice); | 124 new TestSoftwareOutputDevice); |
| 122 software_output_device_ = device.get(); | 125 software_output_device_ = device.get(); |
| 123 output_surface = FakeOutputSurface::CreateSoftware(std::move(device)); | 126 output_surface = FakeOutputSurface::CreateSoftware(std::move(device)); |
| 124 } | 127 } |
| 125 output_surface_ = output_surface.get(); | 128 output_surface_ = output_surface.get(); |
| 126 | 129 |
| 127 std::unique_ptr<TestDisplayScheduler> scheduler( | 130 std::unique_ptr<TestDisplayScheduler> scheduler( |
| 128 new TestDisplayScheduler(begin_frame_source.get(), task_runner_.get())); | 131 new TestDisplayScheduler(begin_frame_source.get(), task_runner_.get())); |
| (...skipping 363 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 492 | 495 |
| 493 testing::Mock::VerifyAndClearExpectations(context_ptr); | 496 testing::Mock::VerifyAndClearExpectations(context_ptr); |
| 494 | 497 |
| 495 EXPECT_CALL(*context_ptr, shallowFinishCHROMIUM()); | 498 EXPECT_CALL(*context_ptr, shallowFinishCHROMIUM()); |
| 496 display_->Resize(gfx::Size(250, 250)); | 499 display_->Resize(gfx::Size(250, 250)); |
| 497 testing::Mock::VerifyAndClearExpectations(context_ptr); | 500 testing::Mock::VerifyAndClearExpectations(context_ptr); |
| 498 | 501 |
| 499 factory_.Destroy(local_frame_id); | 502 factory_.Destroy(local_frame_id); |
| 500 } | 503 } |
| 501 | 504 |
| 505 class CountLossDisplayClient : public StubDisplayClient { |
| 506 public: |
| 507 CountLossDisplayClient() = default; |
| 508 |
| 509 void DisplayOutputSurfaceLost() override { ++loss_count_; } |
| 510 |
| 511 int loss_count() const { return loss_count_; } |
| 512 |
| 513 private: |
| 514 int loss_count_ = 0; |
| 515 }; |
| 516 |
| 517 TEST_F(DisplayTest, ContextLossInformsClient) { |
| 518 SetUpDisplay(RendererSettings(), TestWebGraphicsContext3D::Create()); |
| 519 |
| 520 CountLossDisplayClient client; |
| 521 display_->Initialize(&client, &manager_, kArbitraryFrameSinkId); |
| 522 |
| 523 // Verify DidLoseOutputSurface callback is hooked up correctly. |
| 524 EXPECT_EQ(0, client.loss_count()); |
| 525 output_surface_->context_provider()->ContextGL()->LoseContextCHROMIUM( |
| 526 GL_GUILTY_CONTEXT_RESET_ARB, GL_INNOCENT_CONTEXT_RESET_ARB); |
| 527 output_surface_->context_provider()->ContextGL()->Flush(); |
| 528 EXPECT_EQ(1, client.loss_count()); |
| 529 } |
| 530 |
| 502 } // namespace | 531 } // namespace |
| 503 } // namespace cc | 532 } // namespace cc |
| OLD | NEW |