summaryrefslogtreecommitdiff
path: root/apct-tests/perftests/core
diff options
context:
space:
mode:
authorRiddle Hsu <riddlehsu@google.com>2019-06-14 00:21:55 +0800
committerRiddle Hsu <riddlehsu@google.com>2019-06-21 16:17:52 +0800
commitb8d89f7a1125fd2af947dfa976caa9c64985ae8d (patch)
tree99677c71117c1107d192c8277811eaf66acbf725 /apct-tests/perftests/core
parentbd07d4d69f924d24e8d7a934560ad320a46caf00 (diff)
Add performance test for relayout
Bug: 131727899 Test: atest RelayoutPerfTest Change-Id: Id9aa4929d3b80a5ba1e407b1411d54b8a313b85a
Diffstat (limited to 'apct-tests/perftests/core')
-rw-r--r--apct-tests/perftests/core/src/android/wm/RelayoutPerfTest.java166
1 files changed, 166 insertions, 0 deletions
diff --git a/apct-tests/perftests/core/src/android/wm/RelayoutPerfTest.java b/apct-tests/perftests/core/src/android/wm/RelayoutPerfTest.java
new file mode 100644
index 000000000000..1f12ae6e42c6
--- /dev/null
+++ b/apct-tests/perftests/core/src/android/wm/RelayoutPerfTest.java
@@ -0,0 +1,166 @@
+/*
+ * Copyright (C) 2019 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package android.wm;
+
+import static androidx.test.platform.app.InstrumentationRegistry.getInstrumentation;
+
+import android.app.Activity;
+import android.content.Context;
+import android.graphics.Rect;
+import android.os.RemoteException;
+import android.perftests.utils.BenchmarkState;
+import android.perftests.utils.PerfStatusReporter;
+import android.perftests.utils.StubActivity;
+import android.util.MergedConfiguration;
+import android.view.DisplayCutout;
+import android.view.IWindow;
+import android.view.IWindowSession;
+import android.view.InsetsState;
+import android.view.SurfaceControl;
+import android.view.View;
+import android.view.WindowManager;
+import android.view.WindowManagerGlobal;
+import android.widget.LinearLayout;
+
+import androidx.test.filters.LargeTest;
+import androidx.test.rule.ActivityTestRule;
+
+import org.junit.Before;
+import org.junit.Rule;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.junit.runners.Parameterized;
+
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.function.IntSupplier;
+
+@RunWith(Parameterized.class)
+@LargeTest
+public class RelayoutPerfTest {
+ private static final IWindowSession sSession = WindowManagerGlobal.getWindowSession();
+
+ private int mIteration;
+
+ @Rule
+ public final PerfStatusReporter mPerfStatusReporter = new PerfStatusReporter();
+
+ @Rule
+ public final ActivityTestRule<StubActivity> mActivityRule =
+ new ActivityTestRule<>(StubActivity.class);
+
+ /** This is only a placement to match the input parameters from {@link #getParameters}. */
+ @Parameterized.Parameter(0)
+ public String testName;
+
+ /** The visibilities to loop for relayout. */
+ @Parameterized.Parameter(1)
+ public int[] visibilities;
+
+ /**
+ * Each row will be mapped into {@link #testName} and {@link #visibilities} of a new test
+ * instance according to the index of the parameter.
+ */
+ @Parameterized.Parameters(name = "{0}")
+ public static Collection<Object[]> getParameters() {
+ return Arrays.asList(new Object[][] {
+ { "Visible", new int[] { View.VISIBLE } },
+ { "Invisible~Visible", new int[] { View.INVISIBLE, View.VISIBLE } },
+ { "Gone~Visible", new int[] { View.GONE, View.VISIBLE } },
+ { "Gone~Invisible", new int[] { View.GONE, View.INVISIBLE } }
+ });
+ }
+
+ @Before
+ public void setUp() {
+ getInstrumentation().getUiAutomation().executeShellCommand("input keyevent KEYCODE_WAKEUP");
+ getInstrumentation().getUiAutomation().executeShellCommand("wm dismiss-keyguard");
+ }
+
+ @Test
+ public void testRelayout() throws Throwable {
+ final Activity activity = mActivityRule.getActivity();
+ final ContentView contentView = new ContentView(activity);
+ mActivityRule.runOnUiThread(() -> {
+ activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
+ activity.setContentView(contentView);
+ });
+ getInstrumentation().waitForIdleSync();
+
+ final RelayoutRunner relayoutRunner = new RelayoutRunner(activity, contentView.getWindow(),
+ () -> visibilities[mIteration++ % visibilities.length]);
+ relayoutRunner.runBenchmark(mPerfStatusReporter.getBenchmarkState());
+ }
+
+ /** A dummy view to get IWindow. */
+ private static class ContentView extends LinearLayout {
+ ContentView(Context context) {
+ super(context);
+ }
+
+ @Override
+ protected IWindow getWindow() {
+ return super.getWindow();
+ }
+ }
+
+ private static class RelayoutRunner {
+ final Rect mOutFrame = new Rect();
+ final Rect mOutOverscanInsets = new Rect();
+ final Rect mOutContentInsets = new Rect();
+ final Rect mOutVisibleInsets = new Rect();
+ final Rect mOutStableInsets = new Rect();
+ final Rect mOutOutsets = new Rect();
+ final Rect mOutBackDropFrame = new Rect();
+ final DisplayCutout.ParcelableWrapper mOutDisplayCutout =
+ new DisplayCutout.ParcelableWrapper(DisplayCutout.NO_CUTOUT);
+ final MergedConfiguration mOutMergedConfiguration = new MergedConfiguration();
+ final InsetsState mOutInsetsState = new InsetsState();
+ final IWindow mWindow;
+ final View mView;
+ final WindowManager.LayoutParams mParams;
+ final int mWidth;
+ final int mHeight;
+ final SurfaceControl mOutSurfaceControl;
+
+ final IntSupplier mViewVisibility;
+
+ int mSeq;
+ int mFrameNumber;
+ int mFlags;
+
+ RelayoutRunner(Activity activity, IWindow window, IntSupplier visibilitySupplier) {
+ mWindow = window;
+ mView = activity.getWindow().getDecorView();
+ mParams = (WindowManager.LayoutParams) mView.getLayoutParams();
+ mWidth = mView.getMeasuredWidth();
+ mHeight = mView.getMeasuredHeight();
+ mOutSurfaceControl = mView.getViewRootImpl().getSurfaceControl();
+ mViewVisibility = visibilitySupplier;
+ }
+
+ void runBenchmark(BenchmarkState state) throws RemoteException {
+ while (state.keepRunning()) {
+ sSession.relayout(mWindow, mSeq, mParams, mWidth, mHeight,
+ mViewVisibility.getAsInt(), mFlags, mFrameNumber, mOutFrame,
+ mOutOverscanInsets, mOutContentInsets, mOutVisibleInsets, mOutStableInsets,
+ mOutOutsets, mOutBackDropFrame, mOutDisplayCutout, mOutMergedConfiguration,
+ mOutSurfaceControl, mOutInsetsState);
+ }
+ }
+ }
+}