1 /*
2  * Copyright (C) 2010 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 package com.android.tradefed.device;
17 
18 import com.android.ddmlib.IDevice;
19 import com.android.ddmlib.Log;
20 import com.android.ddmlib.testrunner.RemoteAndroidTestRunner;
21 import com.android.ddmlib.testrunner.TestResult.TestStatus;
22 import com.android.tradefed.TestAppConstants;
23 import com.android.tradefed.config.Option;
24 import com.android.tradefed.result.CollectingTestListener;
25 import com.android.tradefed.testtype.DeviceTestCase;
26 import com.android.tradefed.util.FileUtil;
27 
28 import java.io.File;
29 import java.io.IOException;
30 
31 /**
32  * Long running functional tests for {@link TestDevice} that verify an operation can be run
33  * many times in sequence
34  * <p/>
35  * Requires a physical device to be connected.
36  */
37 public class TestDeviceStressTest extends DeviceTestCase {
38 
39     @Option(name = "iterations", description = "number of iterations to test")
40     private int mIterations = 50;
41 
42     @Option(name = "stop-on-failure", description =
43             "stops the rest of the iteration on a failure")
44     private boolean mStopOnFailure = true;
45 
46     private static final String LOG_TAG = "TestDeviceStressTest";
47     private static final int TEST_FILE_COUNT= 200;
48     private TestDevice mTestDevice;
49     private IDeviceStateMonitor mMonitor;
50 
51     @Override
setUp()52     protected void setUp() throws Exception {
53         super.setUp();
54         mTestDevice = (TestDevice)getDevice();
55         mMonitor = mTestDevice.getDeviceStateMonitor();
56     }
57 
createTempTestFiles()58     private File createTempTestFiles() throws IOException {
59         File tmpDir = null;
60         File tmpFile = null;
61 
62         tmpDir = FileUtil.createTempDir("testDir");
63 
64         final String fileContents = "this is the test file contents";
65         for (int i = 0; i < TEST_FILE_COUNT; i++) {
66             tmpFile = FileUtil.createTempFile(String.format("tmp_%d", i), ".txt", tmpDir);
67             FileUtil.writeToFile(fileContents, tmpFile);
68         }
69         return tmpDir;
70 
71     }
72 
testManyReboots()73     public void testManyReboots() throws DeviceNotAvailableException {
74         for (int i=0; i < mIterations; i++) {
75             Log.i(LOG_TAG, String.format("testReboot attempt %d", i));
76             mTestDevice.reboot();
77             assertEquals(TestDeviceState.ONLINE, mMonitor.getDeviceState());
78         }
79     }
80 
testManyRebootBootloaders()81     public void testManyRebootBootloaders() throws DeviceNotAvailableException {
82         for (int i=0; i < mIterations; i++) {
83             Log.i(LOG_TAG, String.format("testRebootBootloader attempt %d", i));
84             mTestDevice.rebootIntoBootloader();
85             assertEquals(TestDeviceState.FASTBOOT, mMonitor.getDeviceState());
86             mTestDevice.reboot();
87             assertEquals(TestDeviceState.ONLINE, mMonitor.getDeviceState());
88         }
89     }
90 
testManyDisableKeyguard()91     public void testManyDisableKeyguard() throws DeviceNotAvailableException {
92         int passed = 0;
93         boolean iterationPassed;
94         for (int i=0; i < mIterations; i++) {
95             Log.i(LOG_TAG, String.format("testDisableKeyguard attempt %d", i));
96             mTestDevice.reboot();
97             iterationPassed = runUITests();
98             if (mStopOnFailure){
99                 assertTrue(iterationPassed);
100             }
101             passed += iterationPassed? 1 : 0;
102         }
103         assertEquals(mIterations, passed);
104     }
105 
106     /**
107      * Stress test to push a folder which contains 200 text file to device
108      * internal storage.
109      */
testPushFolderWithManyFiles()110     public void testPushFolderWithManyFiles() throws IOException, DeviceNotAvailableException {
111         File tmpDir = null;
112         String deviceFilePath = null;
113         String externalStorePath = mTestDevice.getMountPoint(IDevice.MNT_EXTERNAL_STORAGE);
114         assertNotNull(externalStorePath);
115         deviceFilePath = String.format("%s/%s", externalStorePath, "testDir");
116 
117         // start the stress test
118         try {
119             // Create the test folder and make sure the test folder doesn't exist in
120             // device before the test start.
121             tmpDir = createTempTestFiles();
122             for (int i = 0; i < mIterations; i++) {
123                 mTestDevice.executeShellCommand(String.format("rm -r %s", deviceFilePath));
124                 assertFalse(String.format("%s exists", deviceFilePath),
125                         mTestDevice.doesFileExist(deviceFilePath));
126                 assertTrue(mTestDevice.pushDir(tmpDir, deviceFilePath));
127                 assertTrue(mTestDevice.doesFileExist(deviceFilePath));
128             }
129         } finally {
130             if (tmpDir != null) {
131                 FileUtil.recursiveDelete(tmpDir);
132             }
133             mTestDevice.executeShellCommand(String.format("rm -r %s", deviceFilePath));
134             assertFalse(String.format("%s exists", deviceFilePath),
135                     mTestDevice.doesFileExist(deviceFilePath));
136         }
137     }
138 
139     /**
140      * Test to sync a host side folder to device
141      */
testSyncDataWithManyFiles()142     public void testSyncDataWithManyFiles() throws IOException, DeviceNotAvailableException {
143         File tmpDir = null;
144         String deviceFilePath = null;
145         String externalStorePath = mTestDevice.getMountPoint(IDevice.MNT_EXTERNAL_STORAGE);
146         assertNotNull(externalStorePath);
147         deviceFilePath = String.format("%s/%s", externalStorePath, "testDir");
148 
149         // start the stress test
150         try {
151             // Create the test folder and make sure the test folder doesn't exist in
152             // device before the test start.
153             tmpDir = createTempTestFiles();
154             assertTrue(String.format(
155                     "failed to sync test data from local-data-path %s to %s on device %s",
156                     tmpDir.getAbsolutePath(), deviceFilePath, mTestDevice.getSerialNumber()),
157                     mTestDevice.syncFiles(tmpDir, deviceFilePath));
158         } finally {
159             if (tmpDir != null) {
160                 FileUtil.recursiveDelete(tmpDir);
161             }
162             mTestDevice.executeShellCommand(String.format("rm -r %s", deviceFilePath));
163             assertFalse(String.format("%s exists", deviceFilePath),
164                     mTestDevice.doesFileExist(deviceFilePath));
165         }
166     }
167 
168     /**
169      * Run the test app UI tests and return true if they all pass.
170      */
runUITests()171     private boolean runUITests() throws DeviceNotAvailableException {
172         RemoteAndroidTestRunner uirunner = new RemoteAndroidTestRunner(
173                 TestAppConstants.UITESTAPP_PACKAGE, getDevice().getIDevice());
174         CollectingTestListener uilistener = new CollectingTestListener();
175         getDevice().runInstrumentationTests(uirunner, uilistener);
176         return TestAppConstants.UI_TOTAL_TESTS == uilistener.getNumTestsInState(TestStatus.PASSED);
177     }
178 
179     /**
180      * Return the number of iterations.
181      * <p/>
182      * Exposed for unit testing
183      */
getIterations()184     public int getIterations() {
185         return mIterations;
186     }
187 
188     /**
189      * Set the iterations
190      */
setIterations(int iterations)191     void setIterations(int iterations) {
192         mIterations = iterations;
193     }
194 }
195