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