/* * 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 android.util.Log; import java.util.Arrays; import java.util.List; import java.util.concurrent.CountDownLatch; @LargeTest public class FilesAppPerfTest extends InstrumentationTestCase { // 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 UiDevice mDevice; @Override public void setUp() { mDevice = UiDevice.getInstance(getInstrumentation()); } public void testFilesColdStartPerformance() throws Exception { runFilesStartPerformanceTest(true); } 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(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); getInstrumentation().sendStatus(Activity.RESULT_OK, status); } private void killProviders() throws Exception { final Context context = 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<ResolveInfo> providers = pm.queryIntentContentProviders(intent, 0); for (ResolveInfo info : providers) { final String packageName = info.providerInfo.packageName; am.killBackgroundProcesses(packageName); } } }