| Lloyd Pique | 70d9136 | 2018-10-18 16:02:55 -0700 | [diff] [blame] | 1 | /* | 
|  | 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 |  | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 17 | #include <compositionengine/CompositionRefreshArgs.h> | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 18 | #include <compositionengine/LayerFECompositionState.h> | 
| Lloyd Pique | 70d9136 | 2018-10-18 16:02:55 -0700 | [diff] [blame] | 19 | #include <compositionengine/impl/CompositionEngine.h> | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 20 | #include <compositionengine/mock/LayerFE.h> | 
|  | 21 | #include <compositionengine/mock/Output.h> | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 22 | #include <compositionengine/mock/OutputLayer.h> | 
| Lloyd Pique | 70d9136 | 2018-10-18 16:02:55 -0700 | [diff] [blame] | 23 | #include <gtest/gtest.h> | 
| Lloyd Pique | b97e04f | 2018-10-18 17:07:05 -0700 | [diff] [blame] | 24 | #include <renderengine/mock/RenderEngine.h> | 
| Lloyd Pique | 70d9136 | 2018-10-18 16:02:55 -0700 | [diff] [blame] | 25 |  | 
| Lloyd Pique | 441d504 | 2018-10-18 16:49:51 -0700 | [diff] [blame] | 26 | #include "MockHWComposer.h" | 
| Alec Mouri | e4034bb | 2019-11-19 12:45:54 -0800 | [diff] [blame] | 27 | #include "TimeStats/TimeStats.h" | 
| Lloyd Pique | 441d504 | 2018-10-18 16:49:51 -0700 | [diff] [blame] | 28 |  | 
| Lloyd Pique | 70d9136 | 2018-10-18 16:02:55 -0700 | [diff] [blame] | 29 | namespace android::compositionengine { | 
|  | 30 | namespace { | 
|  | 31 |  | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 32 | using ::testing::_; | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 33 | using ::testing::InSequence; | 
|  | 34 | using ::testing::Ref; | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 35 | using ::testing::Return; | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 36 | using ::testing::ReturnRef; | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 37 | using ::testing::SaveArg; | 
| Lloyd Pique | 441d504 | 2018-10-18 16:49:51 -0700 | [diff] [blame] | 38 | using ::testing::StrictMock; | 
|  | 39 |  | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 40 | struct CompositionEngineTest : public testing::Test { | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 41 | android::mock::HWComposer* mHwc = new StrictMock<android::mock::HWComposer>(); | 
| Lloyd Pique | b97e04f | 2018-10-18 17:07:05 -0700 | [diff] [blame] | 42 | renderengine::mock::RenderEngine* mRenderEngine = | 
|  | 43 | new StrictMock<renderengine::mock::RenderEngine>(); | 
| Alec Mouri | e4034bb | 2019-11-19 12:45:54 -0800 | [diff] [blame] | 44 | std::shared_ptr<TimeStats> mTimeStats; | 
|  | 45 |  | 
| Lloyd Pique | 441d504 | 2018-10-18 16:49:51 -0700 | [diff] [blame] | 46 | impl::CompositionEngine mEngine; | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 47 | CompositionRefreshArgs mRefreshArgs; | 
|  | 48 |  | 
|  | 49 | std::shared_ptr<mock::Output> mOutput1{std::make_shared<StrictMock<mock::Output>>()}; | 
|  | 50 | std::shared_ptr<mock::Output> mOutput2{std::make_shared<StrictMock<mock::Output>>()}; | 
|  | 51 | std::shared_ptr<mock::Output> mOutput3{std::make_shared<StrictMock<mock::Output>>()}; | 
| Lloyd Pique | 70d9136 | 2018-10-18 16:02:55 -0700 | [diff] [blame] | 52 | }; | 
|  | 53 |  | 
| Lloyd Pique | 70d9136 | 2018-10-18 16:02:55 -0700 | [diff] [blame] | 54 | TEST_F(CompositionEngineTest, canInstantiateCompositionEngine) { | 
|  | 55 | auto engine = impl::createCompositionEngine(); | 
|  | 56 | EXPECT_TRUE(engine.get() != nullptr); | 
|  | 57 | } | 
|  | 58 |  | 
| Lloyd Pique | 441d504 | 2018-10-18 16:49:51 -0700 | [diff] [blame] | 59 | TEST_F(CompositionEngineTest, canSetHWComposer) { | 
|  | 60 | mEngine.setHwComposer(std::unique_ptr<android::HWComposer>(mHwc)); | 
|  | 61 |  | 
|  | 62 | EXPECT_EQ(mHwc, &mEngine.getHwComposer()); | 
|  | 63 | } | 
|  | 64 |  | 
| Lloyd Pique | b97e04f | 2018-10-18 17:07:05 -0700 | [diff] [blame] | 65 | TEST_F(CompositionEngineTest, canSetRenderEngine) { | 
|  | 66 | mEngine.setRenderEngine(std::unique_ptr<renderengine::RenderEngine>(mRenderEngine)); | 
|  | 67 |  | 
|  | 68 | EXPECT_EQ(mRenderEngine, &mEngine.getRenderEngine()); | 
|  | 69 | } | 
|  | 70 |  | 
| Alec Mouri | e4034bb | 2019-11-19 12:45:54 -0800 | [diff] [blame] | 71 | TEST_F(CompositionEngineTest, canSetTimeStats) { | 
|  | 72 | mEngine.setTimeStats(mTimeStats); | 
|  | 73 |  | 
|  | 74 | EXPECT_EQ(mTimeStats.get(), &mEngine.getTimeStats()); | 
|  | 75 | } | 
|  | 76 |  | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 77 | /* | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 78 | * CompositionEngine::present | 
|  | 79 | */ | 
|  | 80 |  | 
|  | 81 | struct CompositionEnginePresentTest : public CompositionEngineTest { | 
|  | 82 | struct CompositionEnginePartialMock : public impl::CompositionEngine { | 
|  | 83 | // These are the overridable functions CompositionEngine::present() may | 
|  | 84 | // call, and have separate test coverage. | 
|  | 85 | MOCK_METHOD1(preComposition, void(CompositionRefreshArgs&)); | 
|  | 86 | }; | 
|  | 87 |  | 
|  | 88 | StrictMock<CompositionEnginePartialMock> mEngine; | 
|  | 89 | }; | 
|  | 90 |  | 
|  | 91 | TEST_F(CompositionEnginePresentTest, worksWithEmptyRequest) { | 
|  | 92 | // present() always calls preComposition() | 
|  | 93 | EXPECT_CALL(mEngine, preComposition(Ref(mRefreshArgs))); | 
|  | 94 |  | 
|  | 95 | mEngine.present(mRefreshArgs); | 
|  | 96 | } | 
|  | 97 |  | 
|  | 98 | TEST_F(CompositionEnginePresentTest, worksAsExpected) { | 
|  | 99 | // Expect calls to in a certain sequence | 
|  | 100 | InSequence seq; | 
|  | 101 |  | 
|  | 102 | // present() always calls preComposition() | 
|  | 103 | EXPECT_CALL(mEngine, preComposition(Ref(mRefreshArgs))); | 
|  | 104 |  | 
|  | 105 | // The first step in presenting is to make sure all outputs are prepared. | 
|  | 106 | EXPECT_CALL(*mOutput1, prepare(Ref(mRefreshArgs), _)); | 
|  | 107 | EXPECT_CALL(*mOutput2, prepare(Ref(mRefreshArgs), _)); | 
|  | 108 | EXPECT_CALL(*mOutput3, prepare(Ref(mRefreshArgs), _)); | 
|  | 109 |  | 
|  | 110 | // The next step in presenting is to make sure all outputs have the latest | 
|  | 111 | // state from the front-end (SurfaceFlinger). | 
|  | 112 | EXPECT_CALL(*mOutput1, updateLayerStateFromFE(Ref(mRefreshArgs))); | 
|  | 113 | EXPECT_CALL(*mOutput2, updateLayerStateFromFE(Ref(mRefreshArgs))); | 
|  | 114 | EXPECT_CALL(*mOutput3, updateLayerStateFromFE(Ref(mRefreshArgs))); | 
|  | 115 |  | 
|  | 116 | // The last step is to actually present each output. | 
|  | 117 | EXPECT_CALL(*mOutput1, present(Ref(mRefreshArgs))); | 
|  | 118 | EXPECT_CALL(*mOutput2, present(Ref(mRefreshArgs))); | 
|  | 119 | EXPECT_CALL(*mOutput3, present(Ref(mRefreshArgs))); | 
|  | 120 |  | 
|  | 121 | mRefreshArgs.outputs = {mOutput1, mOutput2, mOutput3}; | 
|  | 122 | mEngine.present(mRefreshArgs); | 
|  | 123 | } | 
|  | 124 |  | 
|  | 125 | /* | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 126 | * CompositionEngine::updateCursorAsync | 
|  | 127 | */ | 
|  | 128 |  | 
|  | 129 | struct CompositionEngineUpdateCursorAsyncTest : public CompositionEngineTest { | 
|  | 130 | public: | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 131 | struct Layer { | 
|  | 132 | Layer() { EXPECT_CALL(outputLayer, getLayerFE()).WillRepeatedly(ReturnRef(layerFE)); } | 
|  | 133 |  | 
|  | 134 | StrictMock<mock::OutputLayer> outputLayer; | 
|  | 135 | StrictMock<mock::LayerFE> layerFE; | 
|  | 136 | LayerFECompositionState layerFEState; | 
|  | 137 | }; | 
|  | 138 |  | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 139 | CompositionEngineUpdateCursorAsyncTest() { | 
| Lloyd Pique | 0a45623 | 2020-01-16 17:51:13 -0800 | [diff] [blame] | 140 | EXPECT_CALL(*mOutput1, getOutputLayerCount()).WillRepeatedly(Return(0u)); | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 141 | EXPECT_CALL(*mOutput1, getOutputLayerOrderedByZByIndex(_)).Times(0); | 
|  | 142 |  | 
| Lloyd Pique | 0a45623 | 2020-01-16 17:51:13 -0800 | [diff] [blame] | 143 | EXPECT_CALL(*mOutput2, getOutputLayerCount()).WillRepeatedly(Return(1u)); | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 144 | EXPECT_CALL(*mOutput2, getOutputLayerOrderedByZByIndex(0)) | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 145 | .WillRepeatedly(Return(&mOutput2Layer1.outputLayer)); | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 146 |  | 
| Lloyd Pique | 0a45623 | 2020-01-16 17:51:13 -0800 | [diff] [blame] | 147 | EXPECT_CALL(*mOutput3, getOutputLayerCount()).WillRepeatedly(Return(2u)); | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 148 | EXPECT_CALL(*mOutput3, getOutputLayerOrderedByZByIndex(0)) | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 149 | .WillRepeatedly(Return(&mOutput3Layer1.outputLayer)); | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 150 | EXPECT_CALL(*mOutput3, getOutputLayerOrderedByZByIndex(1)) | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 151 | .WillRepeatedly(Return(&mOutput3Layer2.outputLayer)); | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 152 | } | 
|  | 153 |  | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 154 | Layer mOutput2Layer1; | 
|  | 155 | Layer mOutput3Layer1; | 
|  | 156 | Layer mOutput3Layer2; | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 157 | }; | 
|  | 158 |  | 
|  | 159 | TEST_F(CompositionEngineUpdateCursorAsyncTest, handlesNoOutputs) { | 
|  | 160 | mEngine.updateCursorAsync(mRefreshArgs); | 
|  | 161 | } | 
|  | 162 |  | 
|  | 163 | TEST_F(CompositionEngineUpdateCursorAsyncTest, handlesNoLayersBeingCursorLayers) { | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 164 | EXPECT_CALL(mOutput3Layer1.outputLayer, isHardwareCursor()).WillRepeatedly(Return(false)); | 
|  | 165 | EXPECT_CALL(mOutput3Layer2.outputLayer, isHardwareCursor()).WillRepeatedly(Return(false)); | 
|  | 166 | EXPECT_CALL(mOutput2Layer1.outputLayer, isHardwareCursor()).WillRepeatedly(Return(false)); | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 167 |  | 
|  | 168 | mRefreshArgs.outputs = {mOutput1, mOutput2, mOutput3}; | 
|  | 169 |  | 
|  | 170 | mEngine.updateCursorAsync(mRefreshArgs); | 
|  | 171 | } | 
|  | 172 |  | 
|  | 173 | TEST_F(CompositionEngineUpdateCursorAsyncTest, handlesMultipleLayersBeingCursorLayers) { | 
|  | 174 | { | 
|  | 175 | InSequence seq; | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 176 | EXPECT_CALL(mOutput2Layer1.outputLayer, isHardwareCursor()).WillRepeatedly(Return(true)); | 
|  | 177 | EXPECT_CALL(mOutput2Layer1.layerFE, prepareCompositionState(LayerFE::StateSubset::Cursor)); | 
|  | 178 | EXPECT_CALL(mOutput2Layer1.outputLayer, writeCursorPositionToHWC()); | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 179 | } | 
|  | 180 |  | 
|  | 181 | { | 
|  | 182 | InSequence seq; | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 183 | EXPECT_CALL(mOutput3Layer1.outputLayer, isHardwareCursor()).WillRepeatedly(Return(true)); | 
|  | 184 | EXPECT_CALL(mOutput3Layer1.layerFE, prepareCompositionState(LayerFE::StateSubset::Cursor)); | 
|  | 185 | EXPECT_CALL(mOutput3Layer1.outputLayer, writeCursorPositionToHWC()); | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 186 | } | 
|  | 187 |  | 
|  | 188 | { | 
|  | 189 | InSequence seq; | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 190 | EXPECT_CALL(mOutput3Layer2.outputLayer, isHardwareCursor()).WillRepeatedly(Return(true)); | 
|  | 191 | EXPECT_CALL(mOutput3Layer2.layerFE, prepareCompositionState(LayerFE::StateSubset::Cursor)); | 
|  | 192 | EXPECT_CALL(mOutput3Layer2.outputLayer, writeCursorPositionToHWC()); | 
| Lloyd Pique | aed56ab | 2019-11-13 22:34:11 -0800 | [diff] [blame] | 193 | } | 
|  | 194 |  | 
|  | 195 | mRefreshArgs.outputs = {mOutput1, mOutput2, mOutput3}; | 
|  | 196 |  | 
|  | 197 | mEngine.updateCursorAsync(mRefreshArgs); | 
|  | 198 | } | 
|  | 199 |  | 
|  | 200 | /* | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 201 | * CompositionEngine::preComposition | 
|  | 202 | */ | 
|  | 203 |  | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 204 | struct CompositionTestPreComposition : public CompositionEngineTest { | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 205 | sp<StrictMock<mock::LayerFE>> mLayer1FE{new StrictMock<mock::LayerFE>()}; | 
|  | 206 | sp<StrictMock<mock::LayerFE>> mLayer2FE{new StrictMock<mock::LayerFE>()}; | 
|  | 207 | sp<StrictMock<mock::LayerFE>> mLayer3FE{new StrictMock<mock::LayerFE>()}; | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 208 | }; | 
|  | 209 |  | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 210 | TEST_F(CompositionTestPreComposition, preCompositionSetsFrameTimestamp) { | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 211 | const nsecs_t before = systemTime(SYSTEM_TIME_MONOTONIC); | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 212 | mEngine.preComposition(mRefreshArgs); | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 213 | const nsecs_t after = systemTime(SYSTEM_TIME_MONOTONIC); | 
|  | 214 |  | 
|  | 215 | // The frame timestamp should be between the before and after timestamps | 
|  | 216 | EXPECT_GE(mEngine.getLastFrameRefreshTimestamp(), before); | 
|  | 217 | EXPECT_LE(mEngine.getLastFrameRefreshTimestamp(), after); | 
|  | 218 | } | 
|  | 219 |  | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 220 | TEST_F(CompositionTestPreComposition, preCompositionInvokesLayerPreCompositionWithFrameTimestamp) { | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 221 | nsecs_t ts1 = 0; | 
|  | 222 | nsecs_t ts2 = 0; | 
|  | 223 | nsecs_t ts3 = 0; | 
|  | 224 | EXPECT_CALL(*mLayer1FE, onPreComposition(_)).WillOnce(DoAll(SaveArg<0>(&ts1), Return(false))); | 
|  | 225 | EXPECT_CALL(*mLayer2FE, onPreComposition(_)).WillOnce(DoAll(SaveArg<0>(&ts2), Return(false))); | 
|  | 226 | EXPECT_CALL(*mLayer3FE, onPreComposition(_)).WillOnce(DoAll(SaveArg<0>(&ts3), Return(false))); | 
|  | 227 |  | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 228 | mRefreshArgs.outputs = {mOutput1}; | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 229 | mRefreshArgs.layers = {mLayer1FE, mLayer2FE, mLayer3FE}; | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 230 |  | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 231 | mEngine.preComposition(mRefreshArgs); | 
|  | 232 |  | 
|  | 233 | // Each of the onPreComposition calls should used the same refresh timestamp | 
|  | 234 | EXPECT_EQ(ts1, mEngine.getLastFrameRefreshTimestamp()); | 
|  | 235 | EXPECT_EQ(ts2, mEngine.getLastFrameRefreshTimestamp()); | 
|  | 236 | EXPECT_EQ(ts3, mEngine.getLastFrameRefreshTimestamp()); | 
|  | 237 | } | 
|  | 238 |  | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 239 | TEST_F(CompositionTestPreComposition, preCompositionDefaultsToNoUpdateNeeded) { | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 240 | EXPECT_CALL(*mLayer1FE, onPreComposition(_)).WillOnce(Return(false)); | 
|  | 241 | EXPECT_CALL(*mLayer2FE, onPreComposition(_)).WillOnce(Return(false)); | 
|  | 242 | EXPECT_CALL(*mLayer3FE, onPreComposition(_)).WillOnce(Return(false)); | 
|  | 243 |  | 
|  | 244 | mEngine.setNeedsAnotherUpdateForTest(true); | 
|  | 245 |  | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 246 | mRefreshArgs.outputs = {mOutput1}; | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 247 | mRefreshArgs.layers = {mLayer1FE, mLayer2FE, mLayer3FE}; | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 248 |  | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 249 | mEngine.preComposition(mRefreshArgs); | 
|  | 250 |  | 
|  | 251 | // The call should have cleared the needsAnotherUpdate flag | 
|  | 252 | EXPECT_FALSE(mEngine.needsAnotherUpdate()); | 
|  | 253 | } | 
|  | 254 |  | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 255 | TEST_F(CompositionTestPreComposition, | 
|  | 256 | preCompositionSetsNeedsAnotherUpdateIfAtLeastOneLayerRequestsIt) { | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 257 | EXPECT_CALL(*mLayer1FE, onPreComposition(_)).WillOnce(Return(true)); | 
|  | 258 | EXPECT_CALL(*mLayer2FE, onPreComposition(_)).WillOnce(Return(false)); | 
|  | 259 | EXPECT_CALL(*mLayer3FE, onPreComposition(_)).WillOnce(Return(false)); | 
|  | 260 |  | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 261 | mRefreshArgs.outputs = {mOutput1}; | 
| Lloyd Pique | de19665 | 2020-01-22 17:29:58 -0800 | [diff] [blame] | 262 | mRefreshArgs.layers = {mLayer1FE, mLayer2FE, mLayer3FE}; | 
| Lloyd Pique | e82ed2d | 2019-11-13 19:28:12 -0800 | [diff] [blame] | 263 |  | 
| Lloyd Pique | ab039b5 | 2019-02-13 14:22:42 -0800 | [diff] [blame] | 264 | mEngine.preComposition(mRefreshArgs); | 
|  | 265 |  | 
|  | 266 | EXPECT_TRUE(mEngine.needsAnotherUpdate()); | 
|  | 267 | } | 
|  | 268 |  | 
| Lloyd Pique | 70d9136 | 2018-10-18 16:02:55 -0700 | [diff] [blame] | 269 | } // namespace | 
|  | 270 | } // namespace android::compositionengine |