1 /* 2 * Copyright (C) 2009 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package com.android.camera.stress; 18 19 import android.app.Activity; 20 import android.app.Instrumentation; 21 import android.content.Intent; 22 import android.os.Environment; 23 import android.test.InstrumentationTestCase; 24 import android.util.Log; 25 26 import androidx.test.filters.LargeTest; 27 28 import com.android.camera.Camera; 29 import com.android.camera.VideoCamera; 30 31 import java.io.BufferedWriter; 32 import java.io.FileWriter; 33 34 /** 35 * Test cases to measure the camera and video recorder startup time. 36 */ 37 public class CameraStartUp extends InstrumentationTestCase { 38 39 private static final int TOTAL_NUMBER_OF_STARTUP = 20; 40 41 private String TAG = "CameraStartUp"; 42 private static final String CAMERA_TEST_OUTPUT_FILE = 43 Environment.getExternalStorageDirectory().toString() + "/mediaStressOut.txt"; 44 private static int WAIT_TIME_FOR_PREVIEW = 1500; //1.5 second 45 launchCamera()46 private long launchCamera() { 47 long startupTime = 0; 48 try { 49 Intent intent = new Intent(Intent.ACTION_MAIN); 50 intent.setClass(getInstrumentation().getTargetContext(), Camera.class); 51 intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 52 long beforeStart = System.currentTimeMillis(); 53 Instrumentation inst = getInstrumentation(); 54 Activity cameraActivity = inst.startActivitySync(intent); 55 long cameraStarted = System.currentTimeMillis(); 56 cameraActivity.finish(); 57 startupTime = cameraStarted - beforeStart; 58 Thread.sleep(1000); 59 Log.v(TAG, "camera startup time: " + startupTime); 60 } catch (Exception e) { 61 Log.v(TAG, "Got exception", e); 62 fail("Fails to get the output file"); 63 } 64 return startupTime; 65 } 66 launchVideo()67 private long launchVideo() { 68 long startupTime = 0; 69 70 try { 71 Intent intent = new Intent(Intent.ACTION_MAIN); 72 intent.setClass(getInstrumentation().getTargetContext(), VideoCamera.class); 73 intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 74 long beforeStart = System.currentTimeMillis(); 75 Instrumentation inst = getInstrumentation(); 76 Activity recorderActivity = inst.startActivitySync(intent); 77 long cameraStarted = System.currentTimeMillis(); 78 recorderActivity.finish(); 79 startupTime = cameraStarted - beforeStart; 80 Log.v(TAG, "Video Startup Time = " + startupTime); 81 // wait for 1s to make sure it reach a clean stage 82 Thread.sleep(WAIT_TIME_FOR_PREVIEW); 83 Log.v(TAG, "video startup time: " + startupTime); 84 } catch (Exception e) { 85 Log.v(TAG, "Got exception", e); 86 fail("Fails to launch video output file"); 87 } 88 return startupTime; 89 } 90 writeToOutputFile(long totalStartupTime, String individualStartupTime, boolean firstStartUp, String Type)91 private void writeToOutputFile(long totalStartupTime, 92 String individualStartupTime, boolean firstStartUp, String Type) throws Exception { 93 // TODO (yslau) : Need to integrate the output data with central 94 // dashboard 95 try { 96 FileWriter fstream = null; 97 fstream = new FileWriter(CAMERA_TEST_OUTPUT_FILE, true); 98 BufferedWriter out = new BufferedWriter(fstream); 99 if (firstStartUp) { 100 out.write("First " + Type + " Startup: " + totalStartupTime + "\n"); 101 } else { 102 long averageStartupTime = totalStartupTime / (TOTAL_NUMBER_OF_STARTUP -1); 103 out.write(Type + "startup time: " + "\n"); 104 out.write("Number of loop: " + (TOTAL_NUMBER_OF_STARTUP -1) + "\n"); 105 out.write(individualStartupTime + "\n\n"); 106 out.write(Type + " average startup time: " + averageStartupTime + " ms\n\n"); 107 } 108 out.close(); 109 fstream.close(); 110 } catch (Exception e) { 111 fail("Camera write output to file"); 112 } 113 } 114 115 @LargeTest testLaunchVideo()116 public void testLaunchVideo() throws Exception { 117 String individualStartupTime; 118 individualStartupTime = "Individual Video Startup Time = "; 119 long totalStartupTime = 0; 120 long startupTime = 0; 121 for (int i = 0; i < TOTAL_NUMBER_OF_STARTUP; i++) { 122 if (i == 0) { 123 // Capture the first startup time individually 124 long firstStartUpTime = launchVideo(); 125 writeToOutputFile(firstStartUpTime, "na", true, "Video"); 126 } else { 127 startupTime = launchVideo(); 128 totalStartupTime += startupTime; 129 individualStartupTime += startupTime + " ,"; 130 } 131 } 132 Log.v(TAG, "totalStartupTime =" + totalStartupTime); 133 writeToOutputFile(totalStartupTime, individualStartupTime, false, "Video"); 134 } 135 136 @LargeTest testLaunchCamera()137 public void testLaunchCamera() throws Exception { 138 String individualStartupTime; 139 individualStartupTime = "Individual Camera Startup Time = "; 140 long totalStartupTime = 0; 141 long startupTime = 0; 142 for (int i = 0; i < TOTAL_NUMBER_OF_STARTUP; i++) { 143 if (i == 0) { 144 // Capture the first startup time individually 145 long firstStartUpTime = launchCamera(); 146 writeToOutputFile(firstStartUpTime, "na", true, "Camera"); 147 } else { 148 startupTime = launchCamera(); 149 totalStartupTime += startupTime; 150 individualStartupTime += startupTime + " ,"; 151 } 152 } 153 Log.v(TAG, "totalStartupTime =" + totalStartupTime); 154 writeToOutputFile(totalStartupTime, 155 individualStartupTime, false, "Camera"); 156 } 157 }