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