blob: 5a6aa9279ac68e5c7f54018e59ab11b9352924bc [file] [log] [blame]
Lloyd Piqued6b579f2018-04-06 15:29:10 -07001/*
2 * Copyright 2018 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 "CompositionTest"
19
20#include <gmock/gmock.h>
21#include <gtest/gtest.h>
22
23#include <gui/IProducerListener.h>
24#include <log/log.h>
25#include <system/window.h>
26#include <utils/String8.h>
27
28#include "BufferQueueLayer.h"
29#include "ColorLayer.h"
30#include "Layer.h"
31
32#include "TestableSurfaceFlinger.h"
33#include "mock/DisplayHardware/MockComposer.h"
34#include "mock/DisplayHardware/MockDisplaySurface.h"
35#include "mock/MockDispSync.h"
36#include "mock/MockEventControlThread.h"
37#include "mock/MockEventThread.h"
38#include "mock/MockMessageQueue.h"
39#include "mock/RenderEngine/MockRenderEngine.h"
Alec Mouriba013fa2018-10-16 12:43:11 -070040#include "mock/system/window/MockNativeWindow.h"
Lloyd Piqued6b579f2018-04-06 15:29:10 -070041
42namespace android {
43namespace {
44
45using testing::_;
David Sodman15094112018-10-11 09:39:37 -070046using testing::AtLeast;
Lloyd Piqued6b579f2018-04-06 15:29:10 -070047using testing::ByMove;
48using testing::DoAll;
Alec Mouri0a9c7b82018-11-16 13:05:25 -080049using testing::Invoke;
Lloyd Piqued6b579f2018-04-06 15:29:10 -070050using testing::IsNull;
51using testing::Mock;
52using testing::NotNull;
53using testing::Ref;
54using testing::Return;
55using testing::ReturnRef;
56using testing::SetArgPointee;
57
58using android::Hwc2::Error;
59using android::Hwc2::IComposer;
60using android::Hwc2::IComposerClient;
61using android::Hwc2::Transform;
62
63using FakeHwcDisplayInjector = TestableSurfaceFlinger::FakeHwcDisplayInjector;
64using FakeDisplayDeviceInjector = TestableSurfaceFlinger::FakeDisplayDeviceInjector;
65
66constexpr hwc2_display_t HWC_DISPLAY = FakeHwcDisplayInjector::DEFAULT_HWC_DISPLAY_ID;
67constexpr hwc2_layer_t HWC_LAYER = 5000;
68constexpr Transform DEFAULT_TRANSFORM = static_cast<Transform>(0);
69
Dominik Laskowski34157762018-10-31 13:07:19 -070070constexpr DisplayId DEFAULT_DISPLAY_ID = DisplayId{42};
Lloyd Piqued6b579f2018-04-06 15:29:10 -070071constexpr int DEFAULT_DISPLAY_WIDTH = 1920;
72constexpr int DEFAULT_DISPLAY_HEIGHT = 1024;
73
74constexpr int DEFAULT_CONFIG_ID = 0;
75constexpr int DEFAULT_TEXTURE_ID = 6000;
76constexpr int DEFAULT_LAYER_STACK = 7000;
77
78constexpr int DEFAULT_DISPLAY_MAX_LUMINANCE = 500;
79
80constexpr int DEFAULT_SIDEBAND_STREAM = 51;
81
82class CompositionTest : public testing::Test {
83public:
84 CompositionTest() {
85 const ::testing::TestInfo* const test_info =
86 ::testing::UnitTest::GetInstance()->current_test_info();
87 ALOGD("**** Setting up for %s.%s\n", test_info->test_case_name(), test_info->name());
88
89 mFlinger.mutableEventControlThread().reset(mEventControlThread);
90 mFlinger.mutableEventThread().reset(mEventThread);
91 mFlinger.mutableEventQueue().reset(mMessageQueue);
92
93 mFlinger.mutablePrimaryDispSync().reset(mPrimaryDispSync);
94 EXPECT_CALL(*mPrimaryDispSync, computeNextRefresh(0)).WillRepeatedly(Return(0));
95 EXPECT_CALL(*mPrimaryDispSync, getPeriod())
96 .WillRepeatedly(Return(FakeHwcDisplayInjector::DEFAULT_REFRESH_RATE));
Alec Mourif6fd29e2018-11-17 04:56:41 +000097 EXPECT_CALL(*mNativeWindow, query(NATIVE_WINDOW_WIDTH, _))
98 .WillRepeatedly(DoAll(SetArgPointee<1>(DEFAULT_DISPLAY_WIDTH), Return(0)));
99 EXPECT_CALL(*mNativeWindow, query(NATIVE_WINDOW_HEIGHT, _))
100 .WillRepeatedly(DoAll(SetArgPointee<1>(DEFAULT_DISPLAY_HEIGHT), Return(0)));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700101
102 mFlinger.setupRenderEngine(std::unique_ptr<renderengine::RenderEngine>(mRenderEngine));
103 setupComposer(0);
104 }
105
106 ~CompositionTest() {
107 const ::testing::TestInfo* const test_info =
108 ::testing::UnitTest::GetInstance()->current_test_info();
109 ALOGD("**** Tearing down after %s.%s\n", test_info->test_case_name(), test_info->name());
110 }
111
112 void setupComposer(int virtualDisplayCount) {
113 mComposer = new Hwc2::mock::Composer();
114 EXPECT_CALL(*mComposer, getCapabilities())
115 .WillOnce(Return(std::vector<IComposer::Capability>()));
116 EXPECT_CALL(*mComposer, getMaxVirtualDisplayCount()).WillOnce(Return(virtualDisplayCount));
117 mFlinger.setupComposer(std::unique_ptr<Hwc2::Composer>(mComposer));
118
119 Mock::VerifyAndClear(mComposer);
120 }
121
122 void setupForceGeometryDirty() {
123 // TODO: This requires the visible region and other related
124 // state to be set, and is problematic for BufferLayers since they are
125 // not visible without a buffer (and setting up a buffer looks like a
126 // pain)
127 // mFlinger.mutableVisibleRegionsDirty() = true;
128
129 mFlinger.mutableGeometryInvalid() = true;
130 }
131
132 template <typename Case>
133 void displayRefreshCompositionDirtyGeometry();
134
135 template <typename Case>
136 void displayRefreshCompositionDirtyFrame();
137
138 template <typename Case>
139 void captureScreenComposition();
140
141 std::unordered_set<HWC2::Capability> mDefaultCapabilities = {HWC2::Capability::SidebandStream};
142
143 TestableSurfaceFlinger mFlinger;
144 sp<DisplayDevice> mDisplay;
145 sp<DisplayDevice> mExternalDisplay;
146 sp<mock::DisplaySurface> mDisplaySurface = new mock::DisplaySurface();
Alec Mouriba013fa2018-10-16 12:43:11 -0700147 mock::NativeWindow* mNativeWindow = new mock::NativeWindow();
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700148
Alec Mouri0a9c7b82018-11-16 13:05:25 -0800149 sp<GraphicBuffer> mBuffer = new GraphicBuffer();
150 ANativeWindowBuffer* mNativeWindowBuffer = mBuffer->getNativeBuffer();
151
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700152 mock::EventThread* mEventThread = new mock::EventThread();
153 mock::EventControlThread* mEventControlThread = new mock::EventControlThread();
154
155 Hwc2::mock::Composer* mComposer = nullptr;
156 renderengine::mock::RenderEngine* mRenderEngine = new renderengine::mock::RenderEngine();
157 mock::MessageQueue* mMessageQueue = new mock::MessageQueue();
158 mock::DispSync* mPrimaryDispSync = new mock::DispSync();
159 renderengine::mock::Image* mReImage = new renderengine::mock::Image();
160 renderengine::mock::Framebuffer* mReFrameBuffer = new renderengine::mock::Framebuffer();
161
162 sp<Fence> mClientTargetAcquireFence = Fence::NO_FENCE;
163
164 sp<GraphicBuffer> mCaptureScreenBuffer;
165};
166
167template <typename LayerCase>
168void CompositionTest::displayRefreshCompositionDirtyGeometry() {
169 setupForceGeometryDirty();
170 LayerCase::setupForDirtyGeometry(this);
171
172 // --------------------------------------------------------------------
173 // Invocation
174
175 mFlinger.onMessageReceived(MessageQueue::INVALIDATE);
176 mFlinger.onMessageReceived(MessageQueue::REFRESH);
177
178 LayerCase::cleanup(this);
179}
180
181template <typename LayerCase>
182void CompositionTest::displayRefreshCompositionDirtyFrame() {
183 LayerCase::setupForDirtyFrame(this);
184
185 // --------------------------------------------------------------------
186 // Invocation
187
188 mFlinger.onMessageReceived(MessageQueue::INVALIDATE);
189 mFlinger.onMessageReceived(MessageQueue::REFRESH);
190
191 LayerCase::cleanup(this);
192}
193
194template <typename LayerCase>
195void CompositionTest::captureScreenComposition() {
196 LayerCase::setupForScreenCapture(this);
197
198 const Rect sourceCrop(0, 0, DEFAULT_DISPLAY_WIDTH, DEFAULT_DISPLAY_HEIGHT);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700199 constexpr bool useIdentityTransform = true;
200 constexpr bool forSystem = true;
201
202 DisplayRenderArea renderArea(mDisplay, sourceCrop, DEFAULT_DISPLAY_WIDTH,
Peiyong Lin0e003c92018-09-17 11:09:51 -0700203 DEFAULT_DISPLAY_HEIGHT, ui::Dataspace::V0_SRGB,
204 ui::Transform::ROT_0);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700205
206 auto traverseLayers = [this](const LayerVector::Visitor& visitor) {
chaviw0e3479f2018-09-10 16:49:30 -0700207 return mFlinger.traverseLayersInDisplay(mDisplay, visitor);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700208 };
209
210 // TODO: Eliminate expensive/real allocation if possible.
211 const uint32_t usage = GRALLOC_USAGE_SW_READ_OFTEN | GRALLOC_USAGE_SW_WRITE_OFTEN |
212 GRALLOC_USAGE_HW_RENDER | GRALLOC_USAGE_HW_TEXTURE;
213 mCaptureScreenBuffer = new GraphicBuffer(renderArea.getReqWidth(), renderArea.getReqHeight(),
214 HAL_PIXEL_FORMAT_RGBA_8888, 1, usage, "screenshot");
215
216 int fd = -1;
217 status_t result =
218 mFlinger.captureScreenImplLocked(renderArea, traverseLayers, mCaptureScreenBuffer.get(),
219 useIdentityTransform, forSystem, &fd);
220 if (fd >= 0) {
221 close(fd);
222 }
223
224 EXPECT_EQ(NO_ERROR, result);
225
226 LayerCase::cleanup(this);
227}
228
229/* ------------------------------------------------------------------------
230 * Variants for each display configuration which can be tested
231 */
232
233template <typename Derived>
234struct BaseDisplayVariant {
235 static constexpr bool IS_SECURE = true;
236 static constexpr int INIT_POWER_MODE = HWC_POWER_MODE_NORMAL;
237
238 static void setupPreconditions(CompositionTest* test) {
Alec Mouriba013fa2018-10-16 12:43:11 -0700239 EXPECT_CALL(*test->mNativeWindow, query(NATIVE_WINDOW_WIDTH, _))
240 .WillRepeatedly(DoAll(SetArgPointee<1>(DEFAULT_DISPLAY_WIDTH), Return(0)));
241 EXPECT_CALL(*test->mNativeWindow, query(NATIVE_WINDOW_HEIGHT, _))
242 .WillRepeatedly(DoAll(SetArgPointee<1>(DEFAULT_DISPLAY_HEIGHT), Return(0)));
243
Dominik Laskowski075d3172018-05-24 15:50:06 -0700244 FakeHwcDisplayInjector(DEFAULT_DISPLAY_ID, HWC2::DisplayType::Physical,
245 true /* isPrimary */)
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700246 .setCapabilities(&test->mDefaultCapabilities)
247 .inject(&test->mFlinger, test->mComposer);
248
Dominik Laskowski075d3172018-05-24 15:50:06 -0700249 test->mDisplay = FakeDisplayDeviceInjector(test->mFlinger, DEFAULT_DISPLAY_ID,
250 false /* isVirtual */, true /* isPrimary */)
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700251 .setDisplaySurface(test->mDisplaySurface)
Alec Mouriba013fa2018-10-16 12:43:11 -0700252 .setNativeWindow(test->mNativeWindow)
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700253 .setSecure(Derived::IS_SECURE)
254 .setPowerMode(Derived::INIT_POWER_MODE)
255 .inject();
256 test->mDisplay->setLayerStack(DEFAULT_LAYER_STACK);
257 }
258
259 template <typename Case>
260 static void setupCommonCompositionCallExpectations(CompositionTest* test) {
261 EXPECT_CALL(*test->mComposer,
262 setColorTransform(HWC_DISPLAY, _, Hwc2::ColorTransform::IDENTITY))
263 .Times(1);
264 EXPECT_CALL(*test->mComposer, presentOrValidateDisplay(HWC_DISPLAY, _, _, _, _)).Times(1);
265 EXPECT_CALL(*test->mComposer, getDisplayRequests(HWC_DISPLAY, _, _, _)).Times(1);
266 EXPECT_CALL(*test->mComposer, acceptDisplayChanges(HWC_DISPLAY)).Times(1);
267 EXPECT_CALL(*test->mComposer, presentDisplay(HWC_DISPLAY, _)).Times(1);
268 EXPECT_CALL(*test->mComposer, getReleaseFences(HWC_DISPLAY, _, _)).Times(1);
269
270 EXPECT_CALL(*test->mRenderEngine, useNativeFenceSync()).WillRepeatedly(Return(true));
271 EXPECT_CALL(*test->mRenderEngine, checkErrors()).WillRepeatedly(Return());
272 EXPECT_CALL(*test->mRenderEngine, isCurrent()).WillRepeatedly(Return(true));
273
Alec Mouri0a9c7b82018-11-16 13:05:25 -0800274 EXPECT_CALL(*test->mRenderEngine, flush()).WillRepeatedly(Invoke([]() {
275 return base::unique_fd(0);
276 }));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700277
278 EXPECT_CALL(*test->mDisplaySurface, onFrameCommitted()).Times(1);
279 EXPECT_CALL(*test->mDisplaySurface, advanceFrame()).Times(1);
280
281 Case::CompositionType::setupHwcSetCallExpectations(test);
282 Case::CompositionType::setupHwcGetCallExpectations(test);
283 }
284
285 template <typename Case>
286 static void setupCommonScreensCaptureCallExpectations(CompositionTest* test) {
287 // Called once with a non-null value to set a framebuffer, and then
288 // again with nullptr to clear it.
289 EXPECT_CALL(*test->mReFrameBuffer, setNativeWindowBuffer(NotNull())).WillOnce(Return(true));
290 EXPECT_CALL(*test->mReFrameBuffer, setNativeWindowBuffer(IsNull())).WillOnce(Return(true));
291
292 EXPECT_CALL(*test->mRenderEngine, checkErrors()).WillRepeatedly(Return());
293 EXPECT_CALL(*test->mRenderEngine, createFramebuffer())
294 .WillOnce(Return(
295 ByMove(std::unique_ptr<renderengine::Framebuffer>(test->mReFrameBuffer))));
296 EXPECT_CALL(*test->mRenderEngine, bindFrameBuffer(test->mReFrameBuffer)).Times(1);
297 EXPECT_CALL(*test->mRenderEngine, unbindFrameBuffer(test->mReFrameBuffer)).Times(1);
298 EXPECT_CALL(*test->mRenderEngine, clearWithColor(0, 0, 0, 1)).Times(1);
299 EXPECT_CALL(*test->mRenderEngine, flush()).WillOnce(Return(ByMove(base::unique_fd())));
300 EXPECT_CALL(*test->mRenderEngine, finish()).WillOnce(Return(true));
301
Peiyong Lin0e003c92018-09-17 11:09:51 -0700302 EXPECT_CALL(*test->mRenderEngine, setOutputDataSpace(_)).Times(1);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700303 EXPECT_CALL(*test->mRenderEngine, setDisplayMaxLuminance(DEFAULT_DISPLAY_MAX_LUMINANCE))
304 .Times(1);
305 // This expectation retires on saturation as setViewportAndProjection is
306 // called an extra time for the code path this setup is for.
307 // TODO: Investigate this extra call
308 EXPECT_CALL(*test->mRenderEngine,
309 setViewportAndProjection(DEFAULT_DISPLAY_WIDTH, DEFAULT_DISPLAY_HEIGHT,
310 Rect(DEFAULT_DISPLAY_WIDTH, DEFAULT_DISPLAY_HEIGHT),
311 ui::Transform::ROT_0))
312 .Times(1)
313 .RetiresOnSaturation();
314 EXPECT_CALL(*test->mRenderEngine, disableTexturing()).Times(1);
315 }
316
317 static void setupNonEmptyFrameCompositionCallExpectations(CompositionTest* test) {
318 EXPECT_CALL(*test->mDisplaySurface, beginFrame(true)).Times(1);
319 }
320
321 static void setupEmptyFrameCompositionCallExpectations(CompositionTest* test) {
322 EXPECT_CALL(*test->mDisplaySurface, beginFrame(false)).Times(1);
323 }
324
325 static void setupHwcCompositionCallExpectations(CompositionTest* test) {
326 EXPECT_CALL(*test->mDisplaySurface, prepareFrame(DisplaySurface::COMPOSITION_HWC)).Times(1);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700327 }
328
329 static void setupRECompositionCallExpectations(CompositionTest* test) {
330 EXPECT_CALL(*test->mDisplaySurface, prepareFrame(DisplaySurface::COMPOSITION_GLES))
331 .Times(1);
332 EXPECT_CALL(*test->mDisplaySurface, getClientTargetAcquireFence())
333 .WillRepeatedly(ReturnRef(test->mClientTargetAcquireFence));
334
335 EXPECT_CALL(*test->mRenderEngine, setOutputDataSpace(ui::Dataspace::UNKNOWN)).Times(1);
336 EXPECT_CALL(*test->mRenderEngine, setDisplayMaxLuminance(DEFAULT_DISPLAY_MAX_LUMINANCE))
337 .Times(1);
Peiyong Lind3788632018-09-18 16:01:31 -0700338 EXPECT_CALL(*test->mRenderEngine, setColorTransform(_)).Times(2);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700339 // These expectations retire on saturation as the code path these
340 // expectations are for appears to make an extra call to them.
341 // TODO: Investigate this extra call
342 EXPECT_CALL(*test->mRenderEngine,
343 setViewportAndProjection(DEFAULT_DISPLAY_WIDTH, DEFAULT_DISPLAY_HEIGHT,
344 Rect(DEFAULT_DISPLAY_WIDTH, DEFAULT_DISPLAY_HEIGHT),
345 ui::Transform::ROT_0))
Alec Mouri0a9c7b82018-11-16 13:05:25 -0800346 .Times(1);
347 EXPECT_CALL(*test->mReFrameBuffer, setNativeWindowBuffer(NotNull())).WillOnce(Return(true));
348 EXPECT_CALL(*test->mReFrameBuffer, setNativeWindowBuffer(IsNull())).WillOnce(Return(true));
349 EXPECT_CALL(*test->mRenderEngine, createFramebuffer())
350 .WillOnce(Return(
351 ByMove(std::unique_ptr<renderengine::Framebuffer>(test->mReFrameBuffer))));
352 EXPECT_CALL(*test->mRenderEngine, bindFrameBuffer(test->mReFrameBuffer)).Times(1);
353 EXPECT_CALL(*test->mRenderEngine, unbindFrameBuffer(test->mReFrameBuffer)).Times(1);
354 EXPECT_CALL(*test->mNativeWindow, queueBuffer(_, _)).WillOnce(Return(0));
355 EXPECT_CALL(*test->mNativeWindow, dequeueBuffer(_, _))
356 .WillOnce(DoAll(SetArgPointee<0>(test->mNativeWindowBuffer), SetArgPointee<1>(-1),
357 Return(0)));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700358 }
359
360 template <typename Case>
361 static void setupRELayerCompositionCallExpectations(CompositionTest* test) {
362 Case::Layer::setupRECompositionCallExpectations(test);
363 }
364
365 template <typename Case>
366 static void setupRELayerScreenshotCompositionCallExpectations(CompositionTest* test) {
367 Case::Layer::setupREScreenshotCompositionCallExpectations(test);
368
369 EXPECT_CALL(*test->mRenderEngine, isCurrent()).WillRepeatedly(Return(true));
370 }
371};
372
373struct DefaultDisplaySetupVariant : public BaseDisplayVariant<DefaultDisplaySetupVariant> {};
374
375struct InsecureDisplaySetupVariant : public BaseDisplayVariant<InsecureDisplaySetupVariant> {
376 static constexpr bool IS_SECURE = false;
377
378 template <typename Case>
379 static void setupRELayerCompositionCallExpectations(CompositionTest* test) {
380 Case::Layer::setupInsecureRECompositionCallExpectations(test);
381
382 // TODO: Investigate this extra call
383 EXPECT_CALL(*test->mRenderEngine, disableScissor()).Times(1);
384 }
385
386 template <typename Case>
387 static void setupRELayerScreenshotCompositionCallExpectations(CompositionTest* test) {
388 Case::Layer::setupInsecureREScreenshotCompositionCallExpectations(test);
389
390 EXPECT_CALL(*test->mRenderEngine, isCurrent()).WillRepeatedly(Return(true));
391 }
392};
393
394struct PoweredOffDisplaySetupVariant : public BaseDisplayVariant<PoweredOffDisplaySetupVariant> {
395 static constexpr int INIT_POWER_MODE = HWC_POWER_MODE_OFF;
396
397 template <typename Case>
398 static void setupCommonCompositionCallExpectations(CompositionTest* test) {
399 // TODO: This seems like an unnecessary call if display is powered off.
400 EXPECT_CALL(*test->mComposer,
401 setColorTransform(HWC_DISPLAY, _, Hwc2::ColorTransform::IDENTITY))
402 .Times(1);
403
404 // TODO: This seems like an unnecessary call if display is powered off.
405 Case::CompositionType::setupHwcSetCallExpectations(test);
406 }
407
408 static void setupHwcCompositionCallExpectations(CompositionTest*) {}
409
410 static void setupRECompositionCallExpectations(CompositionTest* test) {
411 // TODO: This seems like an unnecessary call if display is powered off.
412 EXPECT_CALL(*test->mDisplaySurface, getClientTargetAcquireFence())
413 .WillRepeatedly(ReturnRef(test->mClientTargetAcquireFence));
414 }
415
416 template <typename Case>
417 static void setupRELayerCompositionCallExpectations(CompositionTest*) {}
418};
419
420/* ------------------------------------------------------------------------
421 * Variants for each layer configuration which can be tested
422 */
423
424template <typename LayerProperties>
425struct BaseLayerProperties {
426 static constexpr uint32_t WIDTH = 100;
427 static constexpr uint32_t HEIGHT = 100;
428 static constexpr PixelFormat FORMAT = PIXEL_FORMAT_RGBA_8888;
429 static constexpr uint64_t USAGE =
430 GraphicBuffer::USAGE_SW_READ_NEVER | GraphicBuffer::USAGE_SW_WRITE_NEVER;
431 static constexpr android_dataspace DATASPACE = HAL_DATASPACE_UNKNOWN;
432 static constexpr uint32_t SCALING_MODE = 0;
433 static constexpr uint32_t TRANSFORM = 0;
434 static constexpr uint32_t LAYER_FLAGS = 0;
435 static constexpr float COLOR[] = {1.f, 1.f, 1.f, 1.f};
436 static constexpr IComposerClient::BlendMode BLENDMODE =
437 IComposerClient::BlendMode::PREMULTIPLIED;
438
439 static void enqueueBuffer(CompositionTest*, sp<BufferQueueLayer> layer) {
440 auto producer = layer->getProducer();
441
442 IGraphicBufferProducer::QueueBufferOutput qbo;
443 status_t result = producer->connect(nullptr, NATIVE_WINDOW_API_EGL, false, &qbo);
444 if (result != NO_ERROR) {
445 ALOGE("Failed to connect() (%d)", result);
446 return;
447 }
448
449 int slot;
450 sp<Fence> fence;
451 result = producer->dequeueBuffer(&slot, &fence, LayerProperties::WIDTH,
452 LayerProperties::HEIGHT, LayerProperties::FORMAT,
453 LayerProperties::USAGE, nullptr, nullptr);
454 if (result != IGraphicBufferProducer::BUFFER_NEEDS_REALLOCATION) {
455 ALOGE("Failed to dequeueBuffer() (%d)", result);
456 return;
457 }
458
459 sp<GraphicBuffer> buffer;
460 result = producer->requestBuffer(slot, &buffer);
461 if (result != NO_ERROR) {
462 ALOGE("Failed to requestBuffer() (%d)", result);
463 return;
464 }
465
466 IGraphicBufferProducer::QueueBufferInput qbi(systemTime(), false /* isAutoTimestamp */,
467 LayerProperties::DATASPACE,
468 Rect(LayerProperties::WIDTH,
469 LayerProperties::HEIGHT),
470 LayerProperties::SCALING_MODE,
471 LayerProperties::TRANSFORM, Fence::NO_FENCE);
472 result = producer->queueBuffer(slot, qbi, &qbo);
473 if (result != NO_ERROR) {
474 ALOGE("Failed to queueBuffer (%d)", result);
475 return;
476 }
477 }
478
479 static void setupLatchedBuffer(CompositionTest* test, sp<BufferQueueLayer> layer) {
480 // TODO: Eliminate the complexity of actually creating a buffer
481 EXPECT_CALL(*test->mRenderEngine, getMaxTextureSize()).WillOnce(Return(16384));
482 EXPECT_CALL(*test->mRenderEngine, getMaxViewportDims()).WillOnce(Return(16384));
483 status_t err =
484 layer->setDefaultBufferProperties(LayerProperties::WIDTH, LayerProperties::HEIGHT,
485 LayerProperties::FORMAT);
486 ASSERT_EQ(NO_ERROR, err);
487 Mock::VerifyAndClear(test->mRenderEngine);
488
489 EXPECT_CALL(*test->mMessageQueue, invalidate()).Times(1);
490 enqueueBuffer(test, layer);
491 Mock::VerifyAndClear(test->mMessageQueue);
492
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700493 EXPECT_CALL(*test->mRenderEngine, useNativeFenceSync()).WillRepeatedly(Return(true));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700494 bool ignoredRecomputeVisibleRegions;
Alec Mouri86770e52018-09-24 22:40:58 +0000495 layer->latchBuffer(ignoredRecomputeVisibleRegions, 0, Fence::NO_FENCE);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700496 Mock::VerifyAndClear(test->mRenderEngine);
497 Mock::VerifyAndClear(test->mReImage);
498 }
499
500 static void setupLayerState(CompositionTest* test, sp<BufferQueueLayer> layer) {
501 setupLatchedBuffer(test, layer);
502 }
503
504 static void setupBufferLayerPostFrameCallExpectations(CompositionTest* test) {
505 // BufferLayer::onPostComposition(), when there is no present fence
506 EXPECT_CALL(*test->mComposer, getActiveConfig(HWC_DISPLAY, _))
507 .WillOnce(DoAll(SetArgPointee<1>(DEFAULT_CONFIG_ID), Return(Error::NONE)));
508 }
509
510 static void setupHwcSetGeometryCallExpectations(CompositionTest* test) {
511 // TODO: Coverage of other values
512 EXPECT_CALL(*test->mComposer,
513 setLayerBlendMode(HWC_DISPLAY, HWC_LAYER, LayerProperties::BLENDMODE))
514 .Times(1);
515 // TODO: Coverage of other values for origin
516 EXPECT_CALL(*test->mComposer,
517 setLayerDisplayFrame(HWC_DISPLAY, HWC_LAYER,
518 IComposerClient::Rect({0, 0, LayerProperties::WIDTH,
519 LayerProperties::HEIGHT})))
520 .Times(1);
521 EXPECT_CALL(*test->mComposer,
522 setLayerPlaneAlpha(HWC_DISPLAY, HWC_LAYER, LayerProperties::COLOR[3]))
523 .Times(1);
524 // TODO: Coverage of other values
525 EXPECT_CALL(*test->mComposer, setLayerZOrder(HWC_DISPLAY, HWC_LAYER, 0u)).Times(1);
526 // TODO: Coverage of other values
527 EXPECT_CALL(*test->mComposer, setLayerInfo(HWC_DISPLAY, HWC_LAYER, 0u, 0u)).Times(1);
528
529 // These expectations retire on saturation as the code path these
530 // expectations are for appears to make an extra call to them.
531 // TODO: Investigate this extra call
532 EXPECT_CALL(*test->mComposer, setLayerTransform(HWC_DISPLAY, HWC_LAYER, DEFAULT_TRANSFORM))
David Sodman15094112018-10-11 09:39:37 -0700533 .Times(AtLeast(1))
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700534 .RetiresOnSaturation();
535 }
536
537 static void setupHwcSetSourceCropBufferCallExpectations(CompositionTest* test) {
538 EXPECT_CALL(*test->mComposer,
539 setLayerSourceCrop(HWC_DISPLAY, HWC_LAYER,
540 IComposerClient::FRect({0.f, 0.f, LayerProperties::WIDTH,
541 LayerProperties::HEIGHT})))
542 .Times(1);
543 }
544
545 static void setupHwcSetSourceCropColorCallExpectations(CompositionTest* test) {
546 EXPECT_CALL(*test->mComposer,
547 setLayerSourceCrop(HWC_DISPLAY, HWC_LAYER,
548 IComposerClient::FRect({0.f, 0.f, 0.f, 0.f})))
549 .Times(1);
550 }
551
552 static void setupHwcSetPerFrameCallExpectations(CompositionTest* test) {
553 EXPECT_CALL(*test->mComposer,
554 setLayerVisibleRegion(HWC_DISPLAY, HWC_LAYER,
555 std::vector<IComposerClient::Rect>({IComposerClient::Rect(
556 {0, 0, LayerProperties::WIDTH,
557 LayerProperties::HEIGHT})})))
558 .Times(1);
559 }
560
561 static void setupHwcSetPerFrameColorCallExpectations(CompositionTest* test) {
562 EXPECT_CALL(*test->mComposer, setLayerSurfaceDamage(HWC_DISPLAY, HWC_LAYER, _)).Times(1);
563
564 // TODO: use COLOR
565 EXPECT_CALL(*test->mComposer,
566 setLayerColor(HWC_DISPLAY, HWC_LAYER,
567 IComposerClient::Color({0xff, 0xff, 0xff, 0xff})))
568 .Times(1);
569
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700570 }
571
572 static void setupHwcSetPerFrameBufferCallExpectations(CompositionTest* test) {
573 EXPECT_CALL(*test->mComposer, setLayerSurfaceDamage(HWC_DISPLAY, HWC_LAYER, _)).Times(1);
574 EXPECT_CALL(*test->mComposer, setLayerBuffer(HWC_DISPLAY, HWC_LAYER, _, _, _)).Times(1);
575
576 setupBufferLayerPostFrameCallExpectations(test);
577 }
578
579 static void setupREBufferCompositionCommonCallExpectations(CompositionTest* test) {
580 EXPECT_CALL(*test->mRenderEngine,
581 setupLayerBlending(true, false, false,
582 half4(LayerProperties::COLOR[0], LayerProperties::COLOR[1],
Lucas Dupin1b6531c2018-07-05 17:18:21 -0700583 LayerProperties::COLOR[2], LayerProperties::COLOR[3]),
584 0.0f))
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700585 .Times(1);
586
Alec Mouri39801c02018-10-10 10:44:47 -0700587 EXPECT_CALL(*test->mRenderEngine, createImage())
588 .WillOnce(Return(ByMove(std::unique_ptr<renderengine::Image>(test->mReImage))));
589 EXPECT_CALL(*test->mReImage, setNativeWindowBuffer(_, _)).WillOnce(Return(true));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700590 EXPECT_CALL(*test->mRenderEngine, bindExternalTextureImage(DEFAULT_TEXTURE_ID, _)).Times(1);
591 EXPECT_CALL(*test->mRenderEngine, setupLayerTexturing(_)).Times(1);
592 EXPECT_CALL(*test->mRenderEngine, setSourceDataSpace(ui::Dataspace::UNKNOWN)).Times(1);
593 EXPECT_CALL(*test->mRenderEngine, drawMesh(_)).Times(1);
594 EXPECT_CALL(*test->mRenderEngine, disableBlending()).Times(1);
595 EXPECT_CALL(*test->mRenderEngine, setSourceY410BT2020(false)).Times(1);
596 // This call retires on saturation as the code that renders a texture disables the state,
597 // along with a top-level disable to ensure it is disabled for non-buffer layers.
598 EXPECT_CALL(*test->mRenderEngine, disableTexturing()).Times(1).RetiresOnSaturation();
599 }
600
601 static void setupREBufferCompositionCallExpectations(CompositionTest* test) {
602 LayerProperties::setupREBufferCompositionCommonCallExpectations(test);
603
604 // TODO - Investigate and eliminate these differences between display
605 // composition and screenshot composition.
606 EXPECT_CALL(*test->mRenderEngine, disableScissor()).Times(1);
607 }
608
609 static void setupInsecureREBufferCompositionCallExpectations(CompositionTest* test) {
610 setupREBufferCompositionCallExpectations(test);
611 }
612
613 static void setupREBufferScreenshotCompositionCallExpectations(CompositionTest* test) {
614 LayerProperties::setupREBufferCompositionCommonCallExpectations(test);
615 }
616
617 static void setupInsecureREBufferScreenshotCompositionCallExpectations(CompositionTest* test) {
618 LayerProperties::setupREBufferCompositionCommonCallExpectations(test);
619 }
620
621 static void setupREColorCompositionCommonCallExpectations(CompositionTest* test) {
622 EXPECT_CALL(*test->mRenderEngine, disableScissor()).Times(1);
623 }
624
625 static void setupREColorCompositionCallExpectations(CompositionTest* test) {
626 EXPECT_CALL(*test->mRenderEngine, setSourceDataSpace(ui::Dataspace::UNKNOWN)).Times(1);
627 EXPECT_CALL(*test->mRenderEngine,
628 setupLayerBlending(true, false, true,
629 half4(LayerProperties::COLOR[0], LayerProperties::COLOR[1],
Lucas Dupin1b6531c2018-07-05 17:18:21 -0700630 LayerProperties::COLOR[2], LayerProperties::COLOR[3]),
631 0.0f))
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700632 .Times(1);
633 EXPECT_CALL(*test->mRenderEngine, drawMesh(_)).Times(1);
634 EXPECT_CALL(*test->mRenderEngine, disableBlending()).Times(1);
635 }
636
637 static void setupREColorScreenshotCompositionCallExpectations(CompositionTest* test) {
638 setupREColorCompositionCallExpectations(test);
639 }
640};
641
642struct DefaultLayerProperties : public BaseLayerProperties<DefaultLayerProperties> {};
643
644struct ColorLayerProperties : public BaseLayerProperties<ColorLayerProperties> {};
645
646struct SidebandLayerProperties : public BaseLayerProperties<SidebandLayerProperties> {
647 using Base = BaseLayerProperties<SidebandLayerProperties>;
648 static constexpr IComposerClient::BlendMode BLENDMODE = IComposerClient::BlendMode::NONE;
649
650 static void setupLayerState(CompositionTest* test, sp<BufferQueueLayer> layer) {
651 sp<NativeHandle> stream =
652 NativeHandle::create(reinterpret_cast<native_handle_t*>(DEFAULT_SIDEBAND_STREAM),
653 false);
654 test->mFlinger.setLayerSidebandStream(layer, stream);
655 }
656
657 static void setupHwcSetSourceCropBufferCallExpectations(CompositionTest* test) {
658 EXPECT_CALL(*test->mComposer,
659 setLayerSourceCrop(HWC_DISPLAY, HWC_LAYER,
660 IComposerClient::FRect({0.f, 0.f, -1.f, -1.f})))
661 .Times(1);
662 }
663
664 static void setupHwcSetPerFrameBufferCallExpectations(CompositionTest* test) {
665 EXPECT_CALL(*test->mComposer,
666 setLayerSidebandStream(HWC_DISPLAY, HWC_LAYER,
667 reinterpret_cast<native_handle_t*>(
668 DEFAULT_SIDEBAND_STREAM)))
669 .WillOnce(Return(Error::NONE));
670
671 EXPECT_CALL(*test->mComposer, setLayerSurfaceDamage(HWC_DISPLAY, HWC_LAYER, _)).Times(1);
672 }
673
674 static void setupREBufferCompositionCommonCallExpectations(CompositionTest* test) {
675 EXPECT_CALL(*test->mRenderEngine, setupFillWithColor(0, 0, 0, 1)).Times(1);
676 EXPECT_CALL(*test->mRenderEngine, drawMesh(_)).Times(1);
677 }
678};
679
680struct SecureLayerProperties : public BaseLayerProperties<SecureLayerProperties> {
681 using Base = BaseLayerProperties<SecureLayerProperties>;
682
683 static constexpr uint32_t LAYER_FLAGS = ISurfaceComposerClient::eSecure;
684
685 static void setupInsecureREBufferCompositionCommonCallExpectations(CompositionTest* test) {
Alec Mouri39801c02018-10-10 10:44:47 -0700686 EXPECT_CALL(*test->mRenderEngine, createImage())
687 .WillOnce(Return(ByMove(std::unique_ptr<renderengine::Image>(test->mReImage))));
688 EXPECT_CALL(*test->mReImage, setNativeWindowBuffer(_, _)).WillOnce(Return(true));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700689 EXPECT_CALL(*test->mRenderEngine, bindExternalTextureImage(DEFAULT_TEXTURE_ID, _)).Times(1);
690 EXPECT_CALL(*test->mRenderEngine, setupLayerBlackedOut()).Times(1);
691
692 EXPECT_CALL(*test->mRenderEngine,
693 setupLayerBlending(true, false, false,
694 half4(Base::COLOR[0], Base::COLOR[1], Base::COLOR[2],
Lucas Dupin1b6531c2018-07-05 17:18:21 -0700695 Base::COLOR[3]), 0.0f))
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700696 .Times(1);
697 EXPECT_CALL(*test->mRenderEngine, setSourceDataSpace(ui::Dataspace::UNKNOWN)).Times(1);
698 EXPECT_CALL(*test->mRenderEngine, drawMesh(_)).Times(1);
699 EXPECT_CALL(*test->mRenderEngine, disableBlending()).Times(1);
700 EXPECT_CALL(*test->mRenderEngine, setSourceY410BT2020(false)).Times(1);
701 // This call retires on saturation as the code that renders a texture disables the state,
702 // along with a top-level disable to ensure it is disabled for non-buffer layers.
703 EXPECT_CALL(*test->mRenderEngine, disableTexturing()).Times(1).RetiresOnSaturation();
704 }
705
706 static void setupInsecureREBufferCompositionCallExpectations(CompositionTest* test) {
707 setupInsecureREBufferCompositionCommonCallExpectations(test);
708 Base::setupBufferLayerPostFrameCallExpectations(test);
709 }
710
711 static void setupInsecureREBufferScreenshotCompositionCallExpectations(CompositionTest* test) {
712 setupInsecureREBufferCompositionCommonCallExpectations(test);
713 }
714};
715
716struct CursorLayerProperties : public BaseLayerProperties<CursorLayerProperties> {
717 using Base = BaseLayerProperties<CursorLayerProperties>;
718
719 static void setupLayerState(CompositionTest* test, sp<BufferQueueLayer> layer) {
720 Base::setupLayerState(test, layer);
721 test->mFlinger.setLayerPotentialCursor(layer, true);
722 }
723};
724
725struct NoLayerVariant {
726 using FlingerLayerType = sp<BufferQueueLayer>;
727
728 static FlingerLayerType createLayer(CompositionTest*) { return FlingerLayerType(); }
729 static void injectLayer(CompositionTest*, FlingerLayerType) {}
730 static void cleanupInjectedLayers(CompositionTest*) {}
731
732 static void setupCallExpectationsForDirtyGeometry(CompositionTest*) {}
733 static void setupCallExpectationsForDirtyFrame(CompositionTest*) {}
734};
735
736template <typename LayerProperties>
737struct BaseLayerVariant {
738 template <typename L, typename F>
739 static sp<L> createLayerWithFactory(CompositionTest* test, F factory) {
740 EXPECT_CALL(*test->mMessageQueue, postMessage(_, 0)).Times(0);
741
742 sp<L> layer = factory();
743
744 Mock::VerifyAndClear(test->mComposer);
745 Mock::VerifyAndClear(test->mRenderEngine);
746 Mock::VerifyAndClear(test->mMessageQueue);
747
748 auto& layerDrawingState = test->mFlinger.mutableLayerDrawingState(layer);
749 layerDrawingState.layerStack = DEFAULT_LAYER_STACK;
750 layerDrawingState.active.w = 100;
751 layerDrawingState.active.h = 100;
752 layerDrawingState.color = half4(LayerProperties::COLOR[0], LayerProperties::COLOR[1],
753 LayerProperties::COLOR[2], LayerProperties::COLOR[3]);
754
755 layer->setVisibleRegion(Region(Rect(0, 0, 100, 100)));
756
757 return layer;
758 }
759
760 static void injectLayer(CompositionTest* test, sp<Layer> layer) {
761 EXPECT_CALL(*test->mComposer, createLayer(HWC_DISPLAY, _))
762 .WillOnce(DoAll(SetArgPointee<1>(HWC_LAYER), Return(Error::NONE)));
763
Dominik Laskowski075d3172018-05-24 15:50:06 -0700764 const auto displayId = test->mDisplay->getId();
765 ASSERT_TRUE(displayId);
766 layer->createHwcLayer(test->mFlinger.mFlinger->getBE().mHwc.get(), *displayId);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700767
768 Mock::VerifyAndClear(test->mComposer);
769
770 Vector<sp<Layer>> layers;
771 layers.add(layer);
772 test->mDisplay->setVisibleLayersSortedByZ(layers);
773 test->mFlinger.mutableDrawingState().layersSortedByZ.add(layer);
774 }
775
776 static void cleanupInjectedLayers(CompositionTest* test) {
777 EXPECT_CALL(*test->mComposer, destroyLayer(HWC_DISPLAY, HWC_LAYER))
778 .WillOnce(Return(Error::NONE));
Dominik Laskowski075d3172018-05-24 15:50:06 -0700779 const auto displayId = test->mDisplay->getId();
780 ASSERT_TRUE(displayId);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700781 for (auto layer : test->mFlinger.mutableDrawingState().layersSortedByZ) {
Dominik Laskowski075d3172018-05-24 15:50:06 -0700782 layer->destroyHwcLayer(*displayId);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700783 }
784 test->mFlinger.mutableDrawingState().layersSortedByZ.clear();
785 }
786};
787
788template <typename LayerProperties>
789struct ColorLayerVariant : public BaseLayerVariant<LayerProperties> {
790 using Base = BaseLayerVariant<LayerProperties>;
791 using FlingerLayerType = sp<ColorLayer>;
792
793 static FlingerLayerType createLayer(CompositionTest* test) {
794 FlingerLayerType layer = Base::template createLayerWithFactory<ColorLayer>(test, [test]() {
Lloyd Pique42ab75e2018-09-12 20:46:03 -0700795 return new ColorLayer(LayerCreationArgs(test->mFlinger.mFlinger.get(), sp<Client>(),
796 String8("test-layer"), LayerProperties::WIDTH,
797 LayerProperties::HEIGHT,
798 LayerProperties::LAYER_FLAGS));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700799 });
Vishnu Nair60356342018-11-13 13:00:45 -0800800
801 auto& layerDrawingState = test->mFlinger.mutableLayerDrawingState(layer);
802 layerDrawingState.crop_legacy = Rect(0, 0, LayerProperties::HEIGHT, LayerProperties::WIDTH);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700803 return layer;
804 }
805
806 static void setupRECompositionCallExpectations(CompositionTest* test) {
807 LayerProperties::setupREColorCompositionCommonCallExpectations(test);
808 LayerProperties::setupREColorCompositionCallExpectations(test);
809 }
810
811 static void setupREScreenshotCompositionCallExpectations(CompositionTest* test) {
812 LayerProperties::setupREColorScreenshotCompositionCallExpectations(test);
813 }
814
815 static void setupCallExpectationsForDirtyGeometry(CompositionTest* test) {
816 LayerProperties::setupHwcSetGeometryCallExpectations(test);
817 LayerProperties::setupHwcSetSourceCropColorCallExpectations(test);
818 }
819
820 static void setupCallExpectationsForDirtyFrame(CompositionTest* test) {
821 LayerProperties::setupHwcSetPerFrameCallExpectations(test);
822 LayerProperties::setupHwcSetPerFrameColorCallExpectations(test);
823 }
824};
825
826template <typename LayerProperties>
827struct BufferLayerVariant : public BaseLayerVariant<LayerProperties> {
828 using Base = BaseLayerVariant<LayerProperties>;
829 using FlingerLayerType = sp<BufferQueueLayer>;
830
831 static FlingerLayerType createLayer(CompositionTest* test) {
832 test->mFlinger.mutableTexturePool().push_back(DEFAULT_TEXTURE_ID);
833
834 FlingerLayerType layer =
835 Base::template createLayerWithFactory<BufferQueueLayer>(test, [test]() {
Lloyd Pique42ab75e2018-09-12 20:46:03 -0700836 return new BufferQueueLayer(
837 LayerCreationArgs(test->mFlinger.mFlinger.get(), sp<Client>(),
838 String8("test-layer"), LayerProperties::WIDTH,
839 LayerProperties::HEIGHT,
840 LayerProperties::LAYER_FLAGS));
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700841 });
842
843 LayerProperties::setupLayerState(test, layer);
844
845 return layer;
846 }
847
848 static void cleanupInjectedLayers(CompositionTest* test) {
849 EXPECT_CALL(*test->mMessageQueue, postMessage(_, 0)).Times(2);
850 Base::cleanupInjectedLayers(test);
851 }
852
853 static void setupCallExpectationsForDirtyGeometry(CompositionTest* test) {
854 LayerProperties::setupHwcSetGeometryCallExpectations(test);
855 LayerProperties::setupHwcSetSourceCropBufferCallExpectations(test);
856 }
857
858 static void setupCallExpectationsForDirtyFrame(CompositionTest* test) {
859 LayerProperties::setupHwcSetPerFrameCallExpectations(test);
860 LayerProperties::setupHwcSetPerFrameBufferCallExpectations(test);
861 }
862
863 static void setupRECompositionCallExpectations(CompositionTest* test) {
864 LayerProperties::setupREBufferCompositionCallExpectations(test);
865 }
866
867 static void setupInsecureRECompositionCallExpectations(CompositionTest* test) {
868 LayerProperties::setupInsecureREBufferCompositionCallExpectations(test);
869 }
870
871 static void setupREScreenshotCompositionCallExpectations(CompositionTest* test) {
872 LayerProperties::setupREBufferScreenshotCompositionCallExpectations(test);
873 }
874
875 static void setupInsecureREScreenshotCompositionCallExpectations(CompositionTest* test) {
876 LayerProperties::setupInsecureREBufferScreenshotCompositionCallExpectations(test);
877 }
878};
879
880/* ------------------------------------------------------------------------
881 * Variants to control how the composition type is changed
882 */
883
884struct NoCompositionTypeVariant {
885 static void setupHwcSetCallExpectations(CompositionTest*) {}
886
887 static void setupHwcGetCallExpectations(CompositionTest* test) {
888 EXPECT_CALL(*test->mComposer, getChangedCompositionTypes(HWC_DISPLAY, _, _)).Times(1);
889 }
890};
891
892template <IComposerClient::Composition CompositionType>
893struct KeepCompositionTypeVariant {
894 static constexpr HWC2::Composition TYPE = static_cast<HWC2::Composition>(CompositionType);
895
896 static void setupHwcSetCallExpectations(CompositionTest* test) {
897 EXPECT_CALL(*test->mComposer,
898 setLayerCompositionType(HWC_DISPLAY, HWC_LAYER, CompositionType))
899 .Times(1);
900 }
901
902 static void setupHwcGetCallExpectations(CompositionTest* test) {
903 EXPECT_CALL(*test->mComposer, getChangedCompositionTypes(HWC_DISPLAY, _, _)).Times(1);
904 }
905};
906
907template <IComposerClient::Composition InitialCompositionType,
908 IComposerClient::Composition FinalCompositionType>
909struct ChangeCompositionTypeVariant {
910 static constexpr HWC2::Composition TYPE = static_cast<HWC2::Composition>(FinalCompositionType);
911
912 static void setupHwcSetCallExpectations(CompositionTest* test) {
913 EXPECT_CALL(*test->mComposer,
914 setLayerCompositionType(HWC_DISPLAY, HWC_LAYER, InitialCompositionType))
915 .Times(1);
916 }
917
918 static void setupHwcGetCallExpectations(CompositionTest* test) {
919 EXPECT_CALL(*test->mComposer, getChangedCompositionTypes(HWC_DISPLAY, _, _))
920 .WillOnce(DoAll(SetArgPointee<1>(std::vector<Hwc2::Layer>{
921 static_cast<Hwc2::Layer>(HWC_LAYER)}),
922 SetArgPointee<2>(std::vector<IComposerClient::Composition>{
923 FinalCompositionType}),
924 Return(Error::NONE)));
925 }
926};
927
928/* ------------------------------------------------------------------------
929 * Variants to select how the composition is expected to be handled
930 */
931
932struct CompositionResultBaseVariant {
933 static void setupLayerState(CompositionTest*, sp<Layer>) {}
934
935 template <typename Case>
936 static void setupCallExpectationsForDirtyGeometry(CompositionTest* test) {
937 Case::Layer::setupCallExpectationsForDirtyGeometry(test);
938 }
939
940 template <typename Case>
941 static void setupCallExpectationsForDirtyFrame(CompositionTest* test) {
942 Case::Layer::setupCallExpectationsForDirtyFrame(test);
943 }
944};
945
946struct NoCompositionResultVariant : public CompositionResultBaseVariant {
947 template <typename Case>
948 static void setupCallExpectations(CompositionTest* test) {
949 Case::Display::setupEmptyFrameCompositionCallExpectations(test);
950 Case::Display::setupHwcCompositionCallExpectations(test);
951 }
952};
953
954struct HwcCompositionResultVariant : public CompositionResultBaseVariant {
955 template <typename Case>
956 static void setupCallExpectations(CompositionTest* test) {
957 Case::Display::setupNonEmptyFrameCompositionCallExpectations(test);
958 Case::Display::setupHwcCompositionCallExpectations(test);
959 }
960};
961
962struct RECompositionResultVariant : public CompositionResultBaseVariant {
963 template <typename Case>
964 static void setupCallExpectations(CompositionTest* test) {
965 Case::Display::setupNonEmptyFrameCompositionCallExpectations(test);
966 Case::Display::setupRECompositionCallExpectations(test);
967 Case::Display::template setupRELayerCompositionCallExpectations<Case>(test);
968 }
969};
970
971struct ForcedClientCompositionResultVariant : public RECompositionResultVariant {
972 static void setupLayerState(CompositionTest*, sp<Layer> layer) {
Dominik Laskowski075d3172018-05-24 15:50:06 -0700973 layer->forceClientComposition(DEFAULT_DISPLAY_ID);
Lloyd Piqued6b579f2018-04-06 15:29:10 -0700974 }
975
976 template <typename Case>
977 static void setupCallExpectationsForDirtyGeometry(CompositionTest*) {}
978
979 template <typename Case>
980 static void setupCallExpectationsForDirtyFrame(CompositionTest*) {}
981};
982
983struct EmptyScreenshotResultVariant {
984 static void setupLayerState(CompositionTest*, sp<Layer>) {}
985
986 template <typename Case>
987 static void setupCallExpectations(CompositionTest*) {}
988};
989
990struct REScreenshotResultVariant : public EmptyScreenshotResultVariant {
991 using Base = EmptyScreenshotResultVariant;
992
993 template <typename Case>
994 static void setupCallExpectations(CompositionTest* test) {
995 Base::template setupCallExpectations<Case>(test);
996 Case::Display::template setupRELayerScreenshotCompositionCallExpectations<Case>(test);
997 }
998};
999
1000/* ------------------------------------------------------------------------
1001 * Composition test case, containing all the variants being tested
1002 */
1003
1004template <typename DisplayCase, typename LayerCase, typename CompositionTypeCase,
1005 typename CompositionResultCase>
1006struct CompositionCase {
1007 using ThisCase =
1008 CompositionCase<DisplayCase, LayerCase, CompositionTypeCase, CompositionResultCase>;
1009 using Display = DisplayCase;
1010 using Layer = LayerCase;
1011 using CompositionType = CompositionTypeCase;
1012 using CompositionResult = CompositionResultCase;
1013
1014 static void setupCommon(CompositionTest* test) {
1015 Display::setupPreconditions(test);
1016
1017 auto layer = Layer::createLayer(test);
1018 Layer::injectLayer(test, layer);
1019 CompositionResult::setupLayerState(test, layer);
1020 }
1021
1022 static void setupForDirtyGeometry(CompositionTest* test) {
1023 setupCommon(test);
1024
1025 Display::template setupCommonCompositionCallExpectations<ThisCase>(test);
1026 CompositionResult::template setupCallExpectationsForDirtyGeometry<ThisCase>(test);
1027 CompositionResult::template setupCallExpectationsForDirtyFrame<ThisCase>(test);
1028 CompositionResult::template setupCallExpectations<ThisCase>(test);
1029 }
1030
1031 static void setupForDirtyFrame(CompositionTest* test) {
1032 setupCommon(test);
1033
1034 Display::template setupCommonCompositionCallExpectations<ThisCase>(test);
1035 CompositionResult::template setupCallExpectationsForDirtyFrame<ThisCase>(test);
1036 CompositionResult::template setupCallExpectations<ThisCase>(test);
1037 }
1038
1039 static void setupForScreenCapture(CompositionTest* test) {
1040 setupCommon(test);
1041
1042 Display::template setupCommonScreensCaptureCallExpectations<ThisCase>(test);
1043 CompositionResult::template setupCallExpectations<ThisCase>(test);
1044 }
1045
1046 static void cleanup(CompositionTest* test) {
1047 Layer::cleanupInjectedLayers(test);
1048
1049 for (auto& hwcDisplay : test->mFlinger.mFakeHwcDisplays) {
1050 hwcDisplay->mutableLayers().clear();
1051 }
1052
1053 test->mDisplay->setVisibleLayersSortedByZ(Vector<sp<android::Layer>>());
1054 }
1055};
1056
1057/* ------------------------------------------------------------------------
1058 * Composition cases to test
1059 */
1060
1061TEST_F(CompositionTest, noLayersDoesMinimalWorkWithDirtyGeometry) {
1062 displayRefreshCompositionDirtyGeometry<
1063 CompositionCase<DefaultDisplaySetupVariant, NoLayerVariant, NoCompositionTypeVariant,
1064 NoCompositionResultVariant>>();
1065}
1066
1067TEST_F(CompositionTest, noLayersDoesMinimalWorkWithDirtyFrame) {
1068 displayRefreshCompositionDirtyFrame<
1069 CompositionCase<DefaultDisplaySetupVariant, NoLayerVariant, NoCompositionTypeVariant,
1070 NoCompositionResultVariant>>();
1071}
1072
1073TEST_F(CompositionTest, noLayersDoesMinimalWorkToCaptureScreen) {
1074 captureScreenComposition<
1075 CompositionCase<DefaultDisplaySetupVariant, NoLayerVariant, NoCompositionTypeVariant,
1076 EmptyScreenshotResultVariant>>();
1077}
1078
1079/* ------------------------------------------------------------------------
1080 * Simple buffer layers
1081 */
1082
1083TEST_F(CompositionTest, HWCComposedNormalBufferLayerWithDirtyGeometry) {
1084 displayRefreshCompositionDirtyGeometry<
1085 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1086 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1087 HwcCompositionResultVariant>>();
1088}
1089
1090TEST_F(CompositionTest, HWCComposedNormalBufferLayerWithDirtyFrame) {
1091 displayRefreshCompositionDirtyFrame<
1092 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1093 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1094 HwcCompositionResultVariant>>();
1095}
1096
1097TEST_F(CompositionTest, REComposedNormalBufferLayer) {
1098 displayRefreshCompositionDirtyFrame<
1099 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1100 ChangeCompositionTypeVariant<IComposerClient::Composition::DEVICE,
1101 IComposerClient::Composition::CLIENT>,
1102 RECompositionResultVariant>>();
1103}
1104
1105TEST_F(CompositionTest, captureScreenNormalBufferLayer) {
1106 captureScreenComposition<
1107 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1108 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1109}
1110
1111/* ------------------------------------------------------------------------
1112 * Single-color layers
1113 */
1114
1115TEST_F(CompositionTest, HWCComposedColorLayerWithDirtyGeometry) {
1116 displayRefreshCompositionDirtyGeometry<
1117 CompositionCase<DefaultDisplaySetupVariant, ColorLayerVariant<ColorLayerProperties>,
1118 KeepCompositionTypeVariant<IComposerClient::Composition::SOLID_COLOR>,
1119 HwcCompositionResultVariant>>();
1120}
1121
1122TEST_F(CompositionTest, HWCComposedColorLayerWithDirtyFrame) {
1123 displayRefreshCompositionDirtyFrame<
1124 CompositionCase<DefaultDisplaySetupVariant, ColorLayerVariant<ColorLayerProperties>,
1125 KeepCompositionTypeVariant<IComposerClient::Composition::SOLID_COLOR>,
1126 HwcCompositionResultVariant>>();
1127}
1128
1129TEST_F(CompositionTest, REComposedColorLayer) {
1130 displayRefreshCompositionDirtyFrame<
1131 CompositionCase<DefaultDisplaySetupVariant, ColorLayerVariant<ColorLayerProperties>,
1132 ChangeCompositionTypeVariant<IComposerClient::Composition::SOLID_COLOR,
1133 IComposerClient::Composition::CLIENT>,
1134 RECompositionResultVariant>>();
1135}
1136
1137TEST_F(CompositionTest, captureScreenColorLayer) {
1138 captureScreenComposition<
1139 CompositionCase<DefaultDisplaySetupVariant, ColorLayerVariant<ColorLayerProperties>,
1140 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1141}
1142
1143/* ------------------------------------------------------------------------
1144 * Layers with sideband buffers
1145 */
1146
1147TEST_F(CompositionTest, HWCComposedSidebandBufferLayerWithDirtyGeometry) {
1148 displayRefreshCompositionDirtyGeometry<
1149 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SidebandLayerProperties>,
1150 KeepCompositionTypeVariant<IComposerClient::Composition::SIDEBAND>,
1151 HwcCompositionResultVariant>>();
1152}
1153
1154TEST_F(CompositionTest, HWCComposedSidebandBufferLayerWithDirtyFrame) {
1155 displayRefreshCompositionDirtyFrame<
1156 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SidebandLayerProperties>,
1157 KeepCompositionTypeVariant<IComposerClient::Composition::SIDEBAND>,
1158 HwcCompositionResultVariant>>();
1159}
1160
1161TEST_F(CompositionTest, REComposedSidebandBufferLayer) {
1162 displayRefreshCompositionDirtyFrame<
1163 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SidebandLayerProperties>,
1164 ChangeCompositionTypeVariant<IComposerClient::Composition::SIDEBAND,
1165 IComposerClient::Composition::CLIENT>,
1166 RECompositionResultVariant>>();
1167}
1168
1169TEST_F(CompositionTest, captureScreenSidebandBufferLayer) {
1170 captureScreenComposition<
1171 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SidebandLayerProperties>,
1172 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1173}
1174
1175/* ------------------------------------------------------------------------
1176 * Layers with ISurfaceComposerClient::eSecure, on a secure display
1177 */
1178
1179TEST_F(CompositionTest, HWCComposedSecureBufferLayerWithDirtyGeometry) {
1180 displayRefreshCompositionDirtyGeometry<
1181 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1182 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1183 HwcCompositionResultVariant>>();
1184}
1185
1186TEST_F(CompositionTest, HWCComposedSecureBufferLayerWithDirtyFrame) {
1187 displayRefreshCompositionDirtyFrame<
1188 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1189 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1190 HwcCompositionResultVariant>>();
1191}
1192
1193TEST_F(CompositionTest, REComposedSecureBufferLayer) {
1194 displayRefreshCompositionDirtyFrame<
1195 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1196 ChangeCompositionTypeVariant<IComposerClient::Composition::DEVICE,
1197 IComposerClient::Composition::CLIENT>,
1198 RECompositionResultVariant>>();
1199}
1200
1201TEST_F(CompositionTest, captureScreenSecureBufferLayerOnSecureDisplay) {
1202 captureScreenComposition<
1203 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1204 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1205}
1206
1207/* ------------------------------------------------------------------------
1208 * Layers with ISurfaceComposerClient::eSecure, on a non-secure display
1209 */
1210
1211TEST_F(CompositionTest, HWCComposedSecureBufferLayerOnInsecureDisplayWithDirtyGeometry) {
1212 displayRefreshCompositionDirtyGeometry<
1213 CompositionCase<InsecureDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1214 KeepCompositionTypeVariant<IComposerClient::Composition::CLIENT>,
1215 ForcedClientCompositionResultVariant>>();
1216}
1217
1218TEST_F(CompositionTest, HWCComposedSecureBufferLayerOnInsecureDisplayWithDirtyFrame) {
1219 displayRefreshCompositionDirtyFrame<
1220 CompositionCase<InsecureDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1221 KeepCompositionTypeVariant<IComposerClient::Composition::CLIENT>,
1222 ForcedClientCompositionResultVariant>>();
1223}
1224
1225TEST_F(CompositionTest, captureScreenSecureBufferLayerOnInsecureDisplay) {
1226 captureScreenComposition<
1227 CompositionCase<InsecureDisplaySetupVariant, BufferLayerVariant<SecureLayerProperties>,
1228 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1229}
1230
1231/* ------------------------------------------------------------------------
1232 * Cursor layers
1233 */
1234
1235TEST_F(CompositionTest, HWCComposedCursorLayerWithDirtyGeometry) {
1236 displayRefreshCompositionDirtyGeometry<
1237 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<CursorLayerProperties>,
1238 KeepCompositionTypeVariant<IComposerClient::Composition::CURSOR>,
1239 HwcCompositionResultVariant>>();
1240}
1241
1242TEST_F(CompositionTest, HWCComposedCursorLayerWithDirtyFrame) {
1243 displayRefreshCompositionDirtyFrame<
1244 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<CursorLayerProperties>,
1245 KeepCompositionTypeVariant<IComposerClient::Composition::CURSOR>,
1246 HwcCompositionResultVariant>>();
1247}
1248
1249TEST_F(CompositionTest, REComposedCursorLayer) {
1250 displayRefreshCompositionDirtyFrame<
1251 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<CursorLayerProperties>,
1252 ChangeCompositionTypeVariant<IComposerClient::Composition::CURSOR,
1253 IComposerClient::Composition::CLIENT>,
1254 RECompositionResultVariant>>();
1255}
1256
1257TEST_F(CompositionTest, captureScreenCursorLayer) {
1258 captureScreenComposition<
1259 CompositionCase<DefaultDisplaySetupVariant, BufferLayerVariant<CursorLayerProperties>,
1260 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1261}
1262
1263/* ------------------------------------------------------------------------
1264 * Simple buffer layer on a display which is powered off.
1265 */
1266
1267TEST_F(CompositionTest, displayOffHWCComposedNormalBufferLayerWithDirtyGeometry) {
1268 displayRefreshCompositionDirtyGeometry<CompositionCase<
1269 PoweredOffDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1270 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1271 HwcCompositionResultVariant>>();
1272}
1273
1274TEST_F(CompositionTest, displayOffHWCComposedNormalBufferLayerWithDirtyFrame) {
1275 displayRefreshCompositionDirtyFrame<CompositionCase<
1276 PoweredOffDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1277 KeepCompositionTypeVariant<IComposerClient::Composition::DEVICE>,
1278 HwcCompositionResultVariant>>();
1279}
1280
1281TEST_F(CompositionTest, displayOffREComposedNormalBufferLayer) {
1282 displayRefreshCompositionDirtyFrame<CompositionCase<
1283 PoweredOffDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1284 ChangeCompositionTypeVariant<IComposerClient::Composition::DEVICE,
1285 IComposerClient::Composition::CLIENT>,
1286 RECompositionResultVariant>>();
1287}
1288
1289TEST_F(CompositionTest, captureScreenNormalBufferLayerOnPoweredOffDisplay) {
1290 captureScreenComposition<CompositionCase<
1291 PoweredOffDisplaySetupVariant, BufferLayerVariant<DefaultLayerProperties>,
1292 NoCompositionTypeVariant, REScreenshotResultVariant>>();
1293}
1294
1295} // namespace
1296} // namespace android