blob: 1e6e3361b22935cd2efb909358341009c52cf96a [file] [log] [blame]
Ana Krulecc84d09b2019-11-02 23:10:29 +01001/*
2 * Copyright 2020 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#undef LOG_TAG
18#define LOG_TAG "LibSurfaceFlingerUnittests"
19
20#include <gmock/gmock.h>
21#include <gtest/gtest.h>
22#include <gui/LayerMetadata.h>
23
Ana Krulecc84d09b2019-11-02 23:10:29 +010024#include "BufferStateLayer.h"
Vishnu Nairfa247b12020-02-11 08:58:26 -080025#include "EffectLayer.h"
Ana Krulecc84d09b2019-11-02 23:10:29 +010026#include "Layer.h"
27#include "TestableSurfaceFlinger.h"
28#include "mock/DisplayHardware/MockComposer.h"
Ana Krulecc84d09b2019-11-02 23:10:29 +010029#include "mock/MockEventThread.h"
Ady Abraham8cb21882020-08-26 18:22:05 -070030#include "mock/MockVsyncController.h"
Ana Krulecc84d09b2019-11-02 23:10:29 +010031
32namespace android {
33
34using testing::_;
35using testing::DoAll;
36using testing::Mock;
37using testing::Return;
38using testing::SetArgPointee;
39
40using android::Hwc2::IComposer;
41using android::Hwc2::IComposerClient;
42
43using FakeHwcDisplayInjector = TestableSurfaceFlinger::FakeHwcDisplayInjector;
44
45/**
46 * This class covers all the test that are related to refresh rate selection.
47 */
48class RefreshRateSelectionTest : public testing::Test {
49public:
50 RefreshRateSelectionTest();
51 ~RefreshRateSelectionTest() override;
52
53protected:
54 static constexpr int DEFAULT_DISPLAY_WIDTH = 1920;
55 static constexpr int DEFAULT_DISPLAY_HEIGHT = 1024;
56 static constexpr uint32_t WIDTH = 100;
57 static constexpr uint32_t HEIGHT = 100;
58 static constexpr uint32_t LAYER_FLAGS = 0;
59 static constexpr int32_t PRIORITY_UNSET = -1;
60
61 void setupScheduler();
Ana Krulecc84d09b2019-11-02 23:10:29 +010062 sp<BufferStateLayer> createBufferStateLayer();
Vishnu Nairfa247b12020-02-11 08:58:26 -080063 sp<EffectLayer> createEffectLayer();
Ana Krulecc84d09b2019-11-02 23:10:29 +010064
65 void setParent(Layer* child, Layer* parent);
66 void commitTransaction(Layer* layer);
67
68 TestableSurfaceFlinger mFlinger;
Ana Krulecc84d09b2019-11-02 23:10:29 +010069
70 sp<Client> mClient;
71 sp<Layer> mParent;
72 sp<Layer> mChild;
73 sp<Layer> mGrandChild;
74};
75
76RefreshRateSelectionTest::RefreshRateSelectionTest() {
77 const ::testing::TestInfo* const test_info =
78 ::testing::UnitTest::GetInstance()->current_test_info();
79 ALOGD("**** Setting up for %s.%s\n", test_info->test_case_name(), test_info->name());
80
81 setupScheduler();
Dominik Laskowski13948602021-03-08 20:48:28 -080082 mFlinger.setupComposer(std::make_unique<Hwc2::mock::Composer>());
Ana Krulecc84d09b2019-11-02 23:10:29 +010083}
84
85RefreshRateSelectionTest::~RefreshRateSelectionTest() {
86 const ::testing::TestInfo* const test_info =
87 ::testing::UnitTest::GetInstance()->current_test_info();
88 ALOGD("**** Tearing down after %s.%s\n", test_info->test_case_name(), test_info->name());
89}
90
Ana Krulecc84d09b2019-11-02 23:10:29 +010091
92sp<BufferStateLayer> RefreshRateSelectionTest::createBufferStateLayer() {
93 sp<Client> client;
Vishnu Nair7fb9e5a2021-11-08 12:44:05 -080094 LayerCreationArgs args(mFlinger.flinger(), client, "buffer-queue-layer", LAYER_FLAGS,
95 LayerMetadata());
Ana Krulecc84d09b2019-11-02 23:10:29 +010096 return new BufferStateLayer(args);
97}
98
Vishnu Nairfa247b12020-02-11 08:58:26 -080099sp<EffectLayer> RefreshRateSelectionTest::createEffectLayer() {
Ana Krulecc84d09b2019-11-02 23:10:29 +0100100 sp<Client> client;
Vishnu Nair7fb9e5a2021-11-08 12:44:05 -0800101 LayerCreationArgs args(mFlinger.flinger(), client, "color-layer", LAYER_FLAGS, LayerMetadata());
Vishnu Nairfa247b12020-02-11 08:58:26 -0800102 return new EffectLayer(args);
Ana Krulecc84d09b2019-11-02 23:10:29 +0100103}
104
105void RefreshRateSelectionTest::setParent(Layer* child, Layer* parent) {
106 child->setParent(parent);
107}
108
109void RefreshRateSelectionTest::commitTransaction(Layer* layer) {
Robert Carr6a160312021-05-17 12:08:20 -0700110 auto c = layer->getDrawingState();
Robert Carr0758e5d2021-03-11 22:15:04 -0800111 layer->commitTransaction(c);
Ana Krulecc84d09b2019-11-02 23:10:29 +0100112}
113
114void RefreshRateSelectionTest::setupScheduler() {
115 auto eventThread = std::make_unique<mock::EventThread>();
116 auto sfEventThread = std::make_unique<mock::EventThread>();
117
118 EXPECT_CALL(*eventThread, registerDisplayEventConnection(_));
119 EXPECT_CALL(*eventThread, createEventConnection(_, _))
Ady Abraham0bb6a472020-10-12 10:22:13 -0700120 .WillOnce(Return(new EventThreadConnection(eventThread.get(), /*callingUid=*/0,
Ady Abraham62f216c2020-10-13 19:07:23 -0700121 ResyncCallback())));
Ana Krulecc84d09b2019-11-02 23:10:29 +0100122
123 EXPECT_CALL(*sfEventThread, registerDisplayEventConnection(_));
124 EXPECT_CALL(*sfEventThread, createEventConnection(_, _))
Ady Abraham0bb6a472020-10-12 10:22:13 -0700125 .WillOnce(Return(new EventThreadConnection(sfEventThread.get(), /*callingUid=*/0,
Ady Abraham62f216c2020-10-13 19:07:23 -0700126 ResyncCallback())));
Ana Krulecc84d09b2019-11-02 23:10:29 +0100127
Ady Abraham8cb21882020-08-26 18:22:05 -0700128 auto vsyncController = std::make_unique<mock::VsyncController>();
129 auto vsyncTracker = std::make_unique<mock::VSyncTracker>();
Ana Krulecc84d09b2019-11-02 23:10:29 +0100130
Ady Abraham8cb21882020-08-26 18:22:05 -0700131 EXPECT_CALL(*vsyncTracker, nextAnticipatedVSyncTimeFrom(_)).WillRepeatedly(Return(0));
132 EXPECT_CALL(*vsyncTracker, currentPeriod())
Marin Shalamanov045b7002021-01-07 16:56:24 +0100133 .WillRepeatedly(Return(FakeHwcDisplayInjector::DEFAULT_VSYNC_PERIOD));
Ady Abraham8cb21882020-08-26 18:22:05 -0700134 EXPECT_CALL(*vsyncTracker, nextAnticipatedVSyncTimeFrom(_)).WillRepeatedly(Return(0));
135 mFlinger.setupScheduler(std::move(vsyncController), std::move(vsyncTracker),
136 std::move(eventThread), std::move(sfEventThread));
Ana Krulecc84d09b2019-11-02 23:10:29 +0100137}
138
Ana Krulecc84d09b2019-11-02 23:10:29 +0100139namespace {
140/* ------------------------------------------------------------------------
141 * Test cases
142 */
Ana Krulecc84d09b2019-11-02 23:10:29 +0100143TEST_F(RefreshRateSelectionTest, testPriorityOnBufferStateLayers) {
144 mParent = createBufferStateLayer();
145 mChild = createBufferStateLayer();
146 setParent(mChild.get(), mParent.get());
147 mGrandChild = createBufferStateLayer();
148 setParent(mGrandChild.get(), mChild.get());
149
150 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
151 ASSERT_EQ(PRIORITY_UNSET, mChild->getFrameRateSelectionPriority());
152 ASSERT_EQ(PRIORITY_UNSET, mGrandChild->getFrameRateSelectionPriority());
153
154 // Child has its own priority.
155 mGrandChild->setFrameRateSelectionPriority(1);
156 commitTransaction(mGrandChild.get());
157 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
158 ASSERT_EQ(PRIORITY_UNSET, mChild->getFrameRateSelectionPriority());
159 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
160
161 // Child inherits from his parent.
162 mChild->setFrameRateSelectionPriority(1);
163 commitTransaction(mChild.get());
164 mGrandChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
165 commitTransaction(mGrandChild.get());
166 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
167 ASSERT_EQ(1, mChild->getFrameRateSelectionPriority());
168 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
169
170 // Grandchild inherits from his grand parent.
171 mParent->setFrameRateSelectionPriority(1);
172 commitTransaction(mParent.get());
173 mChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
174 commitTransaction(mChild.get());
175 mGrandChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
176 commitTransaction(mGrandChild.get());
177 ASSERT_EQ(1, mParent->getFrameRateSelectionPriority());
178 ASSERT_EQ(1, mChild->getFrameRateSelectionPriority());
179 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
180}
181
Vishnu Nairfa247b12020-02-11 08:58:26 -0800182TEST_F(RefreshRateSelectionTest, testPriorityOnEffectLayers) {
183 mParent = createEffectLayer();
184 mChild = createEffectLayer();
Ana Krulecc84d09b2019-11-02 23:10:29 +0100185 setParent(mChild.get(), mParent.get());
Vishnu Nairfa247b12020-02-11 08:58:26 -0800186 mGrandChild = createEffectLayer();
Ana Krulecc84d09b2019-11-02 23:10:29 +0100187 setParent(mGrandChild.get(), mChild.get());
188
189 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
190 ASSERT_EQ(PRIORITY_UNSET, mChild->getFrameRateSelectionPriority());
191 ASSERT_EQ(PRIORITY_UNSET, mGrandChild->getFrameRateSelectionPriority());
192
193 // Child has its own priority.
194 mGrandChild->setFrameRateSelectionPriority(1);
195 commitTransaction(mGrandChild.get());
196 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
197 ASSERT_EQ(PRIORITY_UNSET, mChild->getFrameRateSelectionPriority());
198 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
199
200 // Child inherits from his parent.
201 mChild->setFrameRateSelectionPriority(1);
202 commitTransaction(mChild.get());
203 mGrandChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
204 commitTransaction(mGrandChild.get());
205 ASSERT_EQ(PRIORITY_UNSET, mParent->getFrameRateSelectionPriority());
206 ASSERT_EQ(1, mChild->getFrameRateSelectionPriority());
207 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
208
209 // Grandchild inherits from his grand parent.
210 mParent->setFrameRateSelectionPriority(1);
211 commitTransaction(mParent.get());
212 mChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
213 commitTransaction(mChild.get());
214 mGrandChild->setFrameRateSelectionPriority(PRIORITY_UNSET);
215 commitTransaction(mGrandChild.get());
216 ASSERT_EQ(1, mParent->getFrameRateSelectionPriority());
217 ASSERT_EQ(1, mChild->getFrameRateSelectionPriority());
218 ASSERT_EQ(1, mGrandChild->getFrameRateSelectionPriority());
219}
220
221} // namespace
Ady Abraham2b55c3b2020-01-16 16:38:51 -0800222} // namespace android