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 "base/run_loop.h" | 5 #include "base/run_loop.h" |
6 #include "base/thread_task_runner_handle.h" | 6 #include "base/thread_task_runner_handle.h" |
7 #include "cc/output/begin_frame_args.h" | 7 #include "cc/output/begin_frame_args.h" |
8 #include "cc/test/begin_frame_args_test.h" | 8 #include "cc/test/begin_frame_args_test.h" |
9 #include "testing/gmock/include/gmock/gmock.h" | 9 #include "testing/gmock/include/gmock/gmock.h" |
10 #include "testing/gtest/include/gtest/gtest.h" | 10 #include "testing/gtest/include/gtest/gtest.h" |
11 #include "ui/compositor/compositor.h" | 11 #include "ui/compositor/compositor.h" |
12 #include "ui/compositor/compositor_observer.h" | |
12 #include "ui/compositor/test/context_factories_for_test.h" | 13 #include "ui/compositor/test/context_factories_for_test.h" |
13 | 14 |
14 using testing::Mock; | 15 using testing::Mock; |
15 using testing::_; | 16 using testing::_; |
16 | 17 |
17 namespace ui { | 18 namespace ui { |
18 namespace { | 19 namespace { |
19 | 20 |
20 class MockCompositorBeginFrameObserver : public CompositorBeginFrameObserver { | 21 class MockCompositorBeginFrameObserver : public CompositorBeginFrameObserver { |
21 public: | 22 public: |
22 MOCK_METHOD1(OnSendBeginFrame, void(const cc::BeginFrameArgs&)); | 23 MOCK_METHOD1(OnSendBeginFrame, void(const cc::BeginFrameArgs&)); |
23 }; | 24 }; |
24 | 25 |
26 class WaitForCompositingObserver : public CompositorObserver { | |
27 public: | |
28 WaitForCompositingObserver(base::Closure quit_closure) | |
29 : quit_closure_(quit_closure) {} | |
30 | |
31 void OnCompositingDidCommit(Compositor* compositor) override { | |
32 quit_closure_.Run(); | |
33 } | |
34 void OnCompositingStarted(Compositor* compositor, | |
35 base::TimeTicks start_time) override {} | |
36 void OnCompositingEnded(Compositor* compositor) override {} | |
37 void OnCompositingAborted(Compositor* compositor) override {} | |
38 void OnCompositingLockStateChanged(Compositor* compositor) override {} | |
39 void OnCompositingShuttingDown(Compositor* compositor) override {} | |
40 | |
41 private: | |
42 base::Closure quit_closure_; | |
43 }; | |
44 | |
25 // Test fixture for tests that require a ui::Compositor with a real task | 45 // Test fixture for tests that require a ui::Compositor with a real task |
26 // runner. | 46 // runner. |
27 class CompositorTest : public testing::Test { | 47 class CompositorTest : public testing::Test { |
28 public: | 48 public: |
29 CompositorTest() {} | 49 CompositorTest() {} |
30 ~CompositorTest() override {} | 50 ~CompositorTest() override {} |
31 | 51 |
32 void SetUp() override { | 52 void SetUp() override { |
33 task_runner_ = base::ThreadTaskRunnerHandle::Get(); | 53 task_runner_ = base::ThreadTaskRunnerHandle::Get(); |
34 | 54 |
35 ui::ContextFactory* context_factory = | 55 ui::ContextFactory* context_factory = |
36 ui::InitializeContextFactoryForTests(false); | 56 ui::InitializeContextFactoryForTests(false); |
37 | 57 |
38 compositor_.reset(new ui::Compositor(context_factory, task_runner_)); | 58 compositor_.reset(new ui::Compositor(context_factory, task_runner_)); |
39 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); | 59 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); |
40 } | 60 } |
41 void TearDown() override { | 61 void TearDown() override { |
42 compositor_.reset(); | 62 compositor_.reset(); |
43 ui::TerminateContextFactoryForTests(); | 63 ui::TerminateContextFactoryForTests(); |
44 } | 64 } |
45 | 65 |
66 void WaitForComposite() { | |
67 compositor()->ScheduleDraw(); | |
68 base::RunLoop run_loop; | |
69 WaitForCompositingObserver observer(run_loop.QuitClosure()); | |
70 compositor()->AddObserver(&observer); | |
71 run_loop.Run(); | |
72 compositor()->RemoveObserver(&observer); | |
piman
2015/10/05 22:21:26
I think you can use DrawWaiterForTest::WaitForComm
| |
73 } | |
74 | |
46 protected: | 75 protected: |
47 base::SingleThreadTaskRunner* task_runner() { return task_runner_.get(); } | 76 base::SingleThreadTaskRunner* task_runner() { return task_runner_.get(); } |
48 ui::Compositor* compositor() { return compositor_.get(); } | 77 ui::Compositor* compositor() { return compositor_.get(); } |
49 | 78 |
50 private: | 79 private: |
51 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; | 80 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; |
52 scoped_ptr<ui::Compositor> compositor_; | 81 scoped_ptr<ui::Compositor> compositor_; |
53 | 82 |
54 DISALLOW_COPY_AND_ASSIGN(CompositorTest); | 83 DISALLOW_COPY_AND_ASSIGN(CompositorTest); |
55 }; | 84 }; |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
118 // So, it is not used for newly added observer. | 147 // So, it is not used for newly added observer. |
119 EXPECT_CALL(test_observer2, OnSendBeginFrame(_)).Times(0); | 148 EXPECT_CALL(test_observer2, OnSendBeginFrame(_)).Times(0); |
120 compositor()->RemoveBeginFrameObserver(&test_observer); | 149 compositor()->RemoveBeginFrameObserver(&test_observer); |
121 compositor()->RemoveBeginFrameObserver(&test_observer2); | 150 compositor()->RemoveBeginFrameObserver(&test_observer2); |
122 compositor()->AddBeginFrameObserver(&test_observer2); | 151 compositor()->AddBeginFrameObserver(&test_observer2); |
123 Mock::VerifyAndClearExpectations(&test_observer2); | 152 Mock::VerifyAndClearExpectations(&test_observer2); |
124 | 153 |
125 compositor()->RemoveBeginFrameObserver(&test_observer2); | 154 compositor()->RemoveBeginFrameObserver(&test_observer2); |
126 } | 155 } |
127 | 156 |
157 TEST_F(CompositorTest, ReleaseWidgetWithOutputSurfaceNeverCreated) { | |
158 compositor()->SetVisible(false); | |
159 EXPECT_EQ(gfx::kNullAcceleratedWidget, | |
160 compositor()->ReleaseAcceleratedWidget()); | |
161 compositor()->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); | |
162 compositor()->SetVisible(true); | |
163 } | |
164 | |
165 TEST_F(CompositorTest, CreateAndReleaseOutputSurface) { | |
166 DCHECK(compositor()->IsVisible()); | |
167 WaitForComposite(); | |
168 compositor()->SetVisible(false); | |
169 EXPECT_EQ(gfx::kNullAcceleratedWidget, | |
170 compositor()->ReleaseAcceleratedWidget()); | |
171 compositor()->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); | |
172 compositor()->SetVisible(true); | |
173 WaitForComposite(); | |
174 } | |
175 | |
128 } // namespace ui | 176 } // namespace ui |
OLD | NEW |