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