/* * Copyright (C) 2024 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 com.android.launcher3.util.rule; import static com.android.launcher3.util.TestUtil.grantWriteSecurePermission; import android.app.Instrumentation; import android.content.ContentResolver; import android.provider.Settings; import android.util.Log; import android.view.ViewConfiguration; import androidx.test.InstrumentationRegistry; import org.junit.rules.TestRule; import org.junit.runner.Description; import org.junit.runners.model.Statement; public class ExtendedLongPressTimeoutRule implements TestRule { private static final String TAG = "ExtendedLongPressTimeoutRule"; private static final float LONG_PRESS_TIMEOUT_MULTIPLIER = 10f; @Override public Statement apply(Statement base, Description description) { return new Statement() { @Override public void evaluate() throws Throwable { ContentResolver contentResolver = InstrumentationRegistry.getInstrumentation() .getContext() .getContentResolver(); int prevLongPressTimeout = Settings.Secure.getInt( contentResolver, Settings.Secure.LONG_PRESS_TIMEOUT, ViewConfiguration.getLongPressTimeout()); int newLongPressTimeout = (int) (prevLongPressTimeout * LONG_PRESS_TIMEOUT_MULTIPLIER); try { Log.d(TAG, "In try-block: Setting long press timeout from " + prevLongPressTimeout + "ms to " + newLongPressTimeout + "ms"); grantWriteSecurePermission(); Settings.Secure.putInt( contentResolver, Settings.Secure.LONG_PRESS_TIMEOUT, (int) (prevLongPressTimeout * LONG_PRESS_TIMEOUT_MULTIPLIER)); base.evaluate(); } catch (Exception e) { Log.e(TAG, "Error", e); throw e; } finally { Log.d(TAG, "In finally-block: resetting long press timeout to " + prevLongPressTimeout + "ms"); grantWriteSecurePermission(); Settings.Secure.putInt( contentResolver, Settings.Secure.LONG_PRESS_TIMEOUT, prevLongPressTimeout); } } }; } }