Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 3b83af05 authored by Haoyu Zhang's avatar Haoyu Zhang
Browse files

Add benchmark for HandwritingInitiator

Benchmark results:
android.view.HandwritingInitiatorPerfTest#onTouchEvent_actionMove_toolTypeFinger: PASSED (8.111s)
  onTouchEvent_actionMove_toolTypeFinger_min (ns): 86
  onTouchEvent_actionMove_toolTypeFinger_mean (ns): 88
  onTouchEvent_actionMove_toolTypeFinger_median (ns): 88
  onTouchEvent_actionMove_toolTypeFinger_standardDeviation: 2

android.view.HandwritingInitiatorPerfTest#onTouchEvent_actionDown_toolTypeFinger: PASSED (8.701s)
  onTouchEvent_actionDown_toolTypeFinger_min (ns): 27
  onTouchEvent_actionDown_toolTypeFinger_mean (ns): 30
  onTouchEvent_actionDown_toolTypeFinger_median (ns): 30
  onTouchEvent_actionDown_toolTypeFinger_standardDeviation: 2

ndroid.view.HandwritingInitiatorPerfTest#onTouchEvent_actionUp_toolTypeFinger: PASSED (9.227s)
  onTouchEvent_actionUp_toolTypeFinger_min (ns): 50
  onTouchEvent_actionUp_toolTypeFinger_mean (ns): 50
  onTouchEvent_actionUp_toolTypeFinger_median (ns): 51
  onTouchEvent_actionUp_toolTypeFinger_standardDeviation: 0

android.view.HandwritingInitiatorPerfTest#onTouchEvent_actionMove_toolTypeStylus: PASSED (9.732s)
  onTouchEvent_actionMove_toolTypeStylus_min (ns): 129
  onTouchEvent_actionMove_toolTypeStylus_mean (ns): 131
  onTouchEvent_actionMove_toolTypeStylus_median (ns): 129
  onTouchEvent_actionMove_toolTypeStylus_standardDeviation: 2

android.view.HandwritingInitiatorPerfTest#onTouchEvent_actionDown_toolTypeStylus: PASSED (9.254s)
  onTouchEvent_actionDown_toolTypeStylus_min (ns): 97
  onTouchEvent_actionDown_toolTypeStylus_mean (ns): 99
  onTouchEvent_actionDown_toolTypeStylus_median (ns): 98
  onTouchEvent_actionDown_toolTypeStylus_standardDeviation: 3

android.view.HandwritingInitiatorPerfTest#onTouchEvent_actionUp_toolTypeStylus: PASSED (9.304s)
  onTouchEvent_actionUp_toolTypeStylus_min (ns): 62
  onTouchEvent_actionUp_toolTypeStylus_mean (ns): 64
  onTouchEvent_actionUp_toolTypeStylus_median (ns): 64
  onTouchEvent_actionUp_toolTypeStylus_standardDeviation: 1

android.view.HandwritingInitiatorPerfTest#updateEditorBoundary: PASSED (8.498s)
  updateEditorBoundary_min (ns): 6
  updateEditorBoundary_mean (ns): 6
  updateEditorBoundary_median (ns): 6
  updateEditorBoundary_standardDeviation: 0

android.view.HandwritingInitiatorPerfTest#onInputConnectionCreated: PASSED (8.926s)
  onInputConnectionCreated_min (ns): 60
  onInputConnectionCreated_mean (ns): 60
  onInputConnectionCreated_median (ns): 60
  onInputConnectionCreated_standardDeviation: 0

android.view.HandwritingInitiatorPerfTest#onInputConnectionClosed: PASSED (8.975s)
  onInputConnectionClosed_min (ns): 47
  onInputConnectionClosed_mean (ns): 49
  onInputConnectionClosed_median (ns): 49
  onInputConnectionClosed_standardDeviation: 1

Bug: 213216947
Test: atest CorePerfTests:android.view.HandwritingInitiatorPerfTest
Change-Id: I3a506572691cbb6ab78ae475823a2e3628ff9fae
parent a58ffd37
Loading
Loading
Loading
Loading
+235 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2022 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.view;

import static android.view.MotionEvent.ACTION_DOWN;
import static android.view.MotionEvent.ACTION_MOVE;
import static android.view.MotionEvent.ACTION_UP;
import static android.view.MotionEvent.TOOL_TYPE_FINGER;
import static android.view.MotionEvent.TOOL_TYPE_STYLUS;


import android.app.Instrumentation;
import android.content.Context;
import android.graphics.Rect;
import android.perftests.utils.BenchmarkState;
import android.perftests.utils.PerfStatusReporter;
import android.view.inputmethod.EditorInfo;
import android.view.inputmethod.InputMethodManager;

import androidx.test.filters.LargeTest;
import androidx.test.platform.app.InstrumentationRegistry;
import androidx.test.runner.AndroidJUnit4;

import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;

/**
 * Benchmark tests for {@link HandwritingInitiator}
 *
 * Build/Install/Run:
 * atest CorePerfTests:android.view.HandwritingInitiatorPerfTest
 */
@LargeTest
@RunWith(AndroidJUnit4.class)
public class HandwritingInitiatorPerfTest {
    private Context mContext;
    private HandwritingInitiator mHandwritingInitiator;
    private int mTouchSlop;

    @Rule
    public PerfStatusReporter mPerfStatusReporter = new PerfStatusReporter();

    @Before
    public void setup() {
        final Instrumentation mInstrumentation = InstrumentationRegistry.getInstrumentation();
        mContext = mInstrumentation.getTargetContext();
        ViewConfiguration viewConfiguration = ViewConfiguration.get(mContext);
        mTouchSlop = viewConfiguration.getScaledTouchSlop();
        InputMethodManager inputMethodManager = mContext.getSystemService(InputMethodManager.class);
        mHandwritingInitiator = new HandwritingInitiator(viewConfiguration, inputMethodManager);
    }

    @Test
    public void onTouchEvent_actionDown_toolTypeStylus() {
        final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
        final MotionEvent downEvent =
                createMotionEvent(ACTION_DOWN, TOOL_TYPE_STYLUS, 10, 10, 0);
        final MotionEvent upEvent =
                createMotionEvent(ACTION_UP, TOOL_TYPE_STYLUS, 11, 11, 1);

        while (state.keepRunning()) {
            mHandwritingInitiator.onTouchEvent(downEvent);
            state.pauseTiming();
            mHandwritingInitiator.onTouchEvent(upEvent);
            state.resumeTiming();
        }
    }

    @Test
    public void onTouchEvent_actionUp_toolTypeStylus() {
        final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
        final MotionEvent downEvent =
                createMotionEvent(ACTION_DOWN, TOOL_TYPE_STYLUS, 10, 10, 0);
        final MotionEvent upEvent =
                createMotionEvent(ACTION_UP, TOOL_TYPE_STYLUS, 11, 11, 1);

        while (state.keepRunning()) {
            state.pauseTiming();
            mHandwritingInitiator.onTouchEvent(downEvent);
            state.resumeTiming();
            mHandwritingInitiator.onTouchEvent(upEvent);
        }
    }

    @Test
    public void onTouchEvent_actionMove_toolTypeStylus() {
        final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
        final int initX = 10;
        final int initY = 10;
        final MotionEvent downEvent =
                createMotionEvent(ACTION_DOWN, TOOL_TYPE_STYLUS, initX, initY, 0);

        final int x = initX + mTouchSlop;
        final int y = initY + mTouchSlop;
        final MotionEvent moveEvent =
                createMotionEvent(ACTION_MOVE, TOOL_TYPE_STYLUS, x, y, 1);
        final MotionEvent upEvent =
                createMotionEvent(ACTION_UP, TOOL_TYPE_STYLUS, x, y, 1);

        while (state.keepRunning()) {
            state.pauseTiming();
            mHandwritingInitiator.onTouchEvent(downEvent);
            state.resumeTiming();

            mHandwritingInitiator.onTouchEvent(moveEvent);

            state.pauseTiming();
            mHandwritingInitiator.onTouchEvent(upEvent);
            state.resumeTiming();
        }
    }

    @Test
    public void onTouchEvent_actionDown_toolTypeFinger() {
        final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
        final MotionEvent downEvent =
                createMotionEvent(ACTION_DOWN, TOOL_TYPE_FINGER, 10, 10, 0);
        final MotionEvent upEvent =
                createMotionEvent(ACTION_UP, TOOL_TYPE_FINGER, 11, 11, 1);

        while (state.keepRunning()) {
            mHandwritingInitiator.onTouchEvent(downEvent);
            mHandwritingInitiator.onTouchEvent(upEvent);
        }
    }

    @Test
    public void onTouchEvent_actionUp_toolTypeFinger() {
        final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
        final MotionEvent downEvent =
                createMotionEvent(ACTION_DOWN, TOOL_TYPE_FINGER, 10, 10, 0);
        final MotionEvent upEvent =
                createMotionEvent(ACTION_UP, TOOL_TYPE_FINGER, 11, 11, 1);

        while (state.keepRunning()) {
            mHandwritingInitiator.onTouchEvent(downEvent);
            state.pauseTiming();
            mHandwritingInitiator.onTouchEvent(upEvent);
            state.resumeTiming();
        }
    }

    @Test
    public void onTouchEvent_actionMove_toolTypeFinger() {
        final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
        final int initX = 10;
        final int initY = 10;
        final MotionEvent downEvent =
                createMotionEvent(ACTION_DOWN, TOOL_TYPE_FINGER, initX, initY, 0);

        final int x = initX + mTouchSlop;
        final int y = initY + mTouchSlop;
        final MotionEvent moveEvent =
                createMotionEvent(ACTION_MOVE, TOOL_TYPE_FINGER, x, y, 1);
        final MotionEvent upEvent =
                createMotionEvent(ACTION_UP, TOOL_TYPE_FINGER, x, y, 1);

        while (state.keepRunning()) {
            state.pauseTiming();
            mHandwritingInitiator.onTouchEvent(downEvent);
            state.resumeTiming();

            mHandwritingInitiator.onTouchEvent(moveEvent);

            state.pauseTiming();
            mHandwritingInitiator.onTouchEvent(upEvent);
            state.resumeTiming();
        }
    }

    @Test
    public void onInputConnectionCreated() {
        final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
        final View view = new View(mContext);
        final EditorInfo editorInfo = new EditorInfo();
        while (state.keepRunning()) {
            mHandwritingInitiator.onInputConnectionCreated(view, editorInfo);
            state.pauseTiming();
            mHandwritingInitiator.onInputConnectionClosed(view);
            state.resumeTiming();
        }
    }

    @Test
    public void onInputConnectionClosed() {
        final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
        final View view = new View(mContext);
        final EditorInfo editorInfo = new EditorInfo();
        while (state.keepRunning()) {
            state.pauseTiming();
            mHandwritingInitiator.onInputConnectionCreated(view, editorInfo);
            state.resumeTiming();
            mHandwritingInitiator.onInputConnectionClosed(view);
        }
    }

    @Test
    public void updateEditorBoundary() {
        final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
        final Rect rect = new Rect(0, 0, 100, 100);
        while (state.keepRunning()) {
            mHandwritingInitiator.updateEditorBound(rect);
        }
    }

    private MotionEvent createMotionEvent(int action, int toolType, int x, int y, long eventTime) {
        MotionEvent.PointerProperties[] properties = MotionEvent.PointerProperties.createArray(1);
        properties[0].toolType = toolType;

        MotionEvent.PointerCoords[] coords = MotionEvent.PointerCoords.createArray(1);
        coords[0].x = x;
        coords[0].y = y;

        return MotionEvent.obtain(0 /* downTime */, eventTime /* eventTime */, action, 1,
                properties, coords, 0 /* metaState */, 0 /* buttonState */, 1 /* xPrecision */,
                1 /* yPrecision */, 0 /* deviceId */, 0 /* edgeFlags */,
                InputDevice.SOURCE_TOUCHSCREEN, 0 /* flags */);
    }
}