/* * Copyright (C) 2016 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.documentsui; import android.app.Activity; import android.app.ActivityManager; import android.content.Context; import android.content.Intent; import android.content.pm.PackageManager; import android.content.pm.ResolveInfo; import android.os.Bundle; import android.provider.DocumentsContract; import android.support.test.uiautomator.UiDevice; import android.test.InstrumentationTestCase; import android.test.suitebuilder.annotation.LargeTest; import androidx.test.InstrumentationRegistry; import androidx.test.runner.AndroidJUnit4; import org.junit.BeforeClass; import org.junit.Test; import org.junit.runner.RunWith; import java.util.Arrays; import java.util.List; import java.util.concurrent.CountDownLatch; @RunWith(AndroidJUnit4.class) public class FilesAppPerfTest { // Keys used to report metrics to APCT. private static final String KEY_FILES_COLD_START_PERFORMANCE_MEDIAN = "files-cold-start-performance-median"; private static final String KEY_FILES_WARM_START_PERFORMANCE_MEDIAN = "files-warm-start-performance-median"; private static final String TARGET_PACKAGE = "com.android.documentsui"; private static final int NUM_MEASUREMENTS = 10; private LauncherActivity mActivity; private static UiDevice mDevice; @BeforeClass public static void setUp() { mDevice = UiDevice.getInstance(InstrumentationRegistry.getInstrumentation()); } @Test public void testFilesColdStartPerformance() throws Exception { runFilesStartPerformanceTest(true); } @Test public void testFilesWarmStartPerformance() throws Exception { runFilesStartPerformanceTest(false); } public void runFilesStartPerformanceTest(boolean cold) throws Exception { long[] measurements = new long[NUM_MEASUREMENTS]; for (int i = 0; i < NUM_MEASUREMENTS; i++) { if (cold) { // Kill all providers, as well as DocumentsUI to measure a cold start. killProviders(); mDevice.executeShellCommand("am force-stop " + TARGET_PACKAGE); } mDevice.waitForIdle(); LauncherActivity.testCaseLatch = new CountDownLatch(1); mActivity = launchActivity( InstrumentationRegistry.getInstrumentation().getTargetContext() .getPackageName(), LauncherActivity.class, null); LauncherActivity.testCaseLatch.await(); measurements[i] = LauncherActivity.measurement; } reportMetrics(cold ? KEY_FILES_COLD_START_PERFORMANCE_MEDIAN : KEY_FILES_WARM_START_PERFORMANCE_MEDIAN, measurements); } private void reportMetrics(String key, long[] measurements) { final Bundle status = new Bundle(); Arrays.sort(measurements); final long median = measurements[NUM_MEASUREMENTS / 2 - 1]; status.putDouble(key, median); InstrumentationRegistry.getInstrumentation().sendStatus(Activity.RESULT_OK, status); } private void killProviders() throws Exception { final Context context = InstrumentationRegistry.getInstrumentation().getContext(); final PackageManager pm = context.getPackageManager(); final ActivityManager am = (ActivityManager) context.getSystemService( Context.ACTIVITY_SERVICE); final Intent intent = new Intent(DocumentsContract.PROVIDER_INTERFACE); final List providers = pm.queryIntentContentProviders(intent, 0); for (ResolveInfo info : providers) { final String packageName = info.providerInfo.packageName; am.killBackgroundProcesses(packageName); } } private final T launchActivity( String pkg, Class activityCls, Bundle extras) { Intent intent = new Intent(Intent.ACTION_MAIN); if (extras != null) { intent.putExtras(extras); } return launchActivityWithIntent(pkg, activityCls, intent); } private final T launchActivityWithIntent( String pkg, Class activityCls, Intent intent) { intent.setClassName(pkg, activityCls.getName()); intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); T activity = (T) InstrumentationRegistry.getInstrumentation().startActivitySync(intent); InstrumentationRegistry.getInstrumentation().waitForIdleSync(); return activity; } }