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 <stdint.h> | 5 #include <stdint.h> |
6 | 6 |
7 #include "base/macros.h" | 7 #include "base/macros.h" |
8 #include "base/run_loop.h" | 8 #include "base/run_loop.h" |
9 #include "base/threading/thread_task_runner_handle.h" | 9 #include "base/threading/thread_task_runner_handle.h" |
10 #include "cc/output/begin_frame_args.h" | 10 #include "cc/output/begin_frame_args.h" |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
55 base::SingleThreadTaskRunner* task_runner() { return task_runner_.get(); } | 55 base::SingleThreadTaskRunner* task_runner() { return task_runner_.get(); } |
56 ui::Compositor* compositor() { return compositor_.get(); } | 56 ui::Compositor* compositor() { return compositor_.get(); } |
57 | 57 |
58 private: | 58 private: |
59 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; | 59 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; |
60 std::unique_ptr<ui::Compositor> compositor_; | 60 std::unique_ptr<ui::Compositor> compositor_; |
61 | 61 |
62 DISALLOW_COPY_AND_ASSIGN(CompositorTest); | 62 DISALLOW_COPY_AND_ASSIGN(CompositorTest); |
63 }; | 63 }; |
64 | 64 |
| 65 class MockCompositorLockClient |
| 66 : NON_EXPORTED_BASE(public ui::CompositorLockClient) { |
| 67 public: |
| 68 MOCK_METHOD0(CompositorLockTimedOut, void()); |
| 69 }; |
| 70 |
65 } // namespace | 71 } // namespace |
66 | 72 |
67 TEST_F(CompositorTest, LocksTimeOut) { | 73 TEST_F(CompositorTest, LocksTimeOut) { |
68 scoped_refptr<ui::CompositorLock> lock; | 74 scoped_refptr<ui::CompositorLock> lock; |
| 75 |
| 76 base::TimeDelta timeout = base::TimeDelta::FromMilliseconds(100); |
| 77 |
69 { | 78 { |
| 79 testing::StrictMock<MockCompositorLockClient> lock_client; |
70 base::RunLoop run_loop; | 80 base::RunLoop run_loop; |
71 // Ensure that the lock times out by default. | 81 // This lock has a timeout. |
72 lock = compositor()->GetCompositorLock(); | 82 lock = compositor()->GetCompositorLock(&lock_client, timeout); |
73 EXPECT_TRUE(compositor()->IsLocked()); | 83 EXPECT_TRUE(compositor()->IsLocked()); |
74 task_runner()->PostDelayedTask( | 84 task_runner()->PostDelayedTask(FROM_HERE, run_loop.QuitClosure(), timeout); |
75 FROM_HERE, run_loop.QuitClosure(), | 85 EXPECT_CALL(lock_client, CompositorLockTimedOut()).Times(1); |
76 base::TimeDelta::FromMilliseconds(kCompositorLockTimeoutMs)); | |
77 run_loop.Run(); | 86 run_loop.Run(); |
78 EXPECT_FALSE(compositor()->IsLocked()); | 87 EXPECT_FALSE(compositor()->IsLocked()); |
79 } | 88 } |
80 | 89 |
81 { | 90 { |
| 91 testing::StrictMock<MockCompositorLockClient> lock_client; |
82 base::RunLoop run_loop; | 92 base::RunLoop run_loop; |
83 // Ensure that the lock does not time out when set. | 93 // This lock has no timeout. |
84 compositor()->SetLocksWillTimeOut(false); | 94 lock = compositor()->GetCompositorLock(&lock_client, base::TimeDelta()); |
85 lock = compositor()->GetCompositorLock(); | |
86 EXPECT_TRUE(compositor()->IsLocked()); | 95 EXPECT_TRUE(compositor()->IsLocked()); |
87 task_runner()->PostDelayedTask( | 96 task_runner()->PostDelayedTask(FROM_HERE, run_loop.QuitClosure(), timeout); |
88 FROM_HERE, run_loop.QuitClosure(), | 97 EXPECT_CALL(lock_client, CompositorLockTimedOut()).Times(0); |
89 base::TimeDelta::FromMilliseconds(kCompositorLockTimeoutMs)); | |
90 run_loop.Run(); | 98 run_loop.Run(); |
91 EXPECT_TRUE(compositor()->IsLocked()); | 99 EXPECT_TRUE(compositor()->IsLocked()); |
92 } | 100 } |
93 } | 101 } |
94 | 102 |
95 TEST_F(CompositorTest, ReleaseWidgetWithOutputSurfaceNeverCreated) { | 103 TEST_F(CompositorTest, ReleaseWidgetWithOutputSurfaceNeverCreated) { |
96 compositor()->SetVisible(false); | 104 compositor()->SetVisible(false); |
97 EXPECT_EQ(gfx::kNullAcceleratedWidget, | 105 EXPECT_EQ(gfx::kNullAcceleratedWidget, |
98 compositor()->ReleaseAcceleratedWidget()); | 106 compositor()->ReleaseAcceleratedWidget()); |
99 compositor()->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); | 107 compositor()->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); |
(...skipping 19 matching lines...) Expand all Loading... |
119 EXPECT_EQ(gfx::kNullAcceleratedWidget, | 127 EXPECT_EQ(gfx::kNullAcceleratedWidget, |
120 compositor()->ReleaseAcceleratedWidget()); | 128 compositor()->ReleaseAcceleratedWidget()); |
121 compositor()->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); | 129 compositor()->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); |
122 compositor()->SetVisible(true); | 130 compositor()->SetVisible(true); |
123 compositor()->ScheduleDraw(); | 131 compositor()->ScheduleDraw(); |
124 DrawWaiterForTest::WaitForCompositingEnded(compositor()); | 132 DrawWaiterForTest::WaitForCompositingEnded(compositor()); |
125 compositor()->SetRootLayer(nullptr); | 133 compositor()->SetRootLayer(nullptr); |
126 } | 134 } |
127 | 135 |
128 } // namespace ui | 136 } // namespace ui |
OLD | NEW |