diff options
author | The Android Open Source Project <initial-contribution@android.com> | 2009-02-10 15:44:04 -0800 |
---|---|---|
committer | The Android Open Source Project <initial-contribution@android.com> | 2009-02-10 15:44:04 -0800 |
commit | dee42a6e53cb1d0c7194b0cb92028cca353d7c5c (patch) | |
tree | 4fe26dbb188bf5ec71455fa71ce93470342269a0 /tests | |
parent | 8250896ab37545f4499da79f54c19af2e5018b80 (diff) | |
download | packages_apps_LegacyCamera-dee42a6e53cb1d0c7194b0cb92028cca353d7c5c.zip packages_apps_LegacyCamera-dee42a6e53cb1d0c7194b0cb92028cca353d7c5c.tar.gz packages_apps_LegacyCamera-dee42a6e53cb1d0c7194b0cb92028cca353d7c5c.tar.bz2 |
auto import from //branches/cupcake/...@130745
Diffstat (limited to 'tests')
-rw-r--r-- | tests/Android.mk | 3 | ||||
-rw-r--r-- | tests/AndroidManifest.xml | 5 | ||||
-rwxr-xr-x | tests/src/com/android/camera/CameraStressTestRunner.java | 50 | ||||
-rwxr-xr-x | tests/src/com/android/camera/stress/ImageCapture.java | 96 | ||||
-rwxr-xr-x | tests/src/com/android/camera/stress/SwitchPreview.java | 74 |
5 files changed, 228 insertions, 0 deletions
diff --git a/tests/Android.mk b/tests/Android.mk index 714e078..f5972cb 100644 --- a/tests/Android.mk +++ b/tests/Android.mk @@ -1,3 +1,4 @@ +LOCAL_PATH:= $(call my-dir) include $(CLEAR_VARS) # We only want this apk build for tests. @@ -14,3 +15,5 @@ LOCAL_PACKAGE_NAME := CameraTests LOCAL_INSTRUMENTATION_FOR := Camera include $(BUILD_PACKAGE) + + diff --git a/tests/AndroidManifest.xml b/tests/AndroidManifest.xml index b8074f5..1b7abd2 100644 --- a/tests/AndroidManifest.xml +++ b/tests/AndroidManifest.xml @@ -25,5 +25,10 @@ android:targetPackage="com.android.camera" android:label="Camera Launch Performance"> </instrumentation> + + <instrumentation android:name=".CameraStressTestRunner" + android:targetPackage="com.android.camera" + android:label="Camera Stress Test InstrumentationRunner"> + </instrumentation> </manifest> diff --git a/tests/src/com/android/camera/CameraStressTestRunner.java b/tests/src/com/android/camera/CameraStressTestRunner.java new file mode 100755 index 0000000..e34204c --- /dev/null +++ b/tests/src/com/android/camera/CameraStressTestRunner.java @@ -0,0 +1,50 @@ +/* + * Copyright (C) 2009 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.camera.tests; + +import android.test.InstrumentationTestRunner; +import android.test.InstrumentationTestSuite; +import com.android.camera.tests.stress.SwitchPreview; +import com.android.camera.tests.stress.ImageCapture; + +import junit.framework.TestSuite; + + +/** + * Instrumentation Test Runner for all Camera tests. + * + * Running all tests: + * + * adb shell am instrument -w \ + * com.android.camera.tests/.CameraStressTestRunner + */ + +public class CameraStressTestRunner extends InstrumentationTestRunner { + + @Override + public TestSuite getAllTests() { + TestSuite suite = new InstrumentationTestSuite(this); + suite.addTestSuite(SwitchPreview.class); + suite.addTestSuite(ImageCapture.class); + return suite; + } + + @Override + public ClassLoader getLoader() { + return CameraStressTestRunner.class.getClassLoader(); + } +} diff --git a/tests/src/com/android/camera/stress/ImageCapture.java b/tests/src/com/android/camera/stress/ImageCapture.java new file mode 100755 index 0000000..dbb1f64 --- /dev/null +++ b/tests/src/com/android/camera/stress/ImageCapture.java @@ -0,0 +1,96 @@ +/* + * Copyright (C) 2009 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.camera.tests.stress; + +import android.app.Activity; +import android.app.Instrumentation; +import android.test.ActivityInstrumentationTestCase2; +import android.util.Log; +import android.view.KeyEvent; +import android.test.suitebuilder.annotation.LargeTest; + +import com.android.camera.Camera; + +/** + * Junit / Instrumentation test case for camera test + * + */ + +public class ImageCapture extends ActivityInstrumentationTestCase2 <Camera> { + private String TAG = "ImageCapture"; + private static final int TOTAL_NUMBER_OF_IMAGECAPTURE = 100; + private static final int TOTAL_NUMBER_OF_VIDEOCAPTURE = 100; + private static final long WAIT_FOR_IMAGE_CAPTURE_TO_BE_TAKEN = 1000; + private static final long WAIT_FOR_VIDEO_CAPTURE_TO_BE_TAKEN = 50000; //50seconds + private static final long WAIT_FOR_PREVIEW = 1000; //1 seconds + + public ImageCapture() { + super("com.android.camera", Camera.class); + } + + @Override + protected void setUp() throws Exception { + getActivity(); + super.setUp(); + } + + @Override + protected void tearDown() throws Exception { + super.tearDown(); + } + + @LargeTest + public void testImageCapture() { + Instrumentation inst = getInstrumentation(); + try { + for (int i = 0; i < TOTAL_NUMBER_OF_IMAGECAPTURE; i++) { + Thread.sleep(WAIT_FOR_IMAGE_CAPTURE_TO_BE_TAKEN); + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_UP); + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_CENTER); + Thread.sleep(WAIT_FOR_IMAGE_CAPTURE_TO_BE_TAKEN); + } + } catch (Exception e) { + Log.v(TAG, e.toString()); + } + assertTrue("testImageCapture", true); + } + + @LargeTest + public void testVideoCapture() { + Instrumentation inst = getInstrumentation(); + //Switch to the video mode + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_MENU); + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_CENTER); + try { + for (int i = 0; i < TOTAL_NUMBER_OF_VIDEOCAPTURE; i++) { + Thread.sleep(WAIT_FOR_PREVIEW); + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_UP); + //record an video + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_CENTER); + Thread.sleep(WAIT_FOR_VIDEO_CAPTURE_TO_BE_TAKEN); + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_CENTER); + Thread.sleep(WAIT_FOR_PREVIEW); + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_CENTER); + } + } catch (Exception e) { + Log.v(TAG, e.toString()); + } + assertTrue("testVideoCapture", true); + } + +} + diff --git a/tests/src/com/android/camera/stress/SwitchPreview.java b/tests/src/com/android/camera/stress/SwitchPreview.java new file mode 100755 index 0000000..c00e553 --- /dev/null +++ b/tests/src/com/android/camera/stress/SwitchPreview.java @@ -0,0 +1,74 @@ +/* + * Copyright (C) 2009 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.camera.tests.stress; + +import android.app.Activity; +import android.app.Instrumentation; +import android.test.ActivityInstrumentationTestCase2; +import android.util.Log; +import android.view.KeyEvent; +import android.test.suitebuilder.annotation.LargeTest; + +import com.android.camera.Camera; +import com.android.camera.VideoCamera; + +/** + * Junit / Instrumentation test case for camera test + * + */ + +public class SwitchPreview extends ActivityInstrumentationTestCase2 <VideoCamera>{ + private String TAG = "SwitchPreview"; + private static final int TOTAL_NUMBER_OF_SWITCHING = 200; + private static final long WAIT_FOR_PREVIEW = 2000; + + + public SwitchPreview() { + super("com.android.camera", VideoCamera.class); + } + + @Override + protected void setUp() throws Exception { + getActivity(); + super.setUp(); + } + + @Override + protected void tearDown() throws Exception { + getActivity().finish(); + super.tearDown(); + } + + @LargeTest + public void testSwitchMode() { + //Switching the video and the video recorder mode + Instrumentation inst = getInstrumentation(); + try{ + for (int i=0; i< TOTAL_NUMBER_OF_SWITCHING; i++) { + Thread.sleep(WAIT_FOR_PREVIEW); + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_MENU); + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_LEFT); + inst.sendKeyDownUpSync(KeyEvent.KEYCODE_DPAD_CENTER); + Thread.sleep(WAIT_FOR_PREVIEW); + } + } catch (Exception e){ + Log.v(TAG, e.toString()); + } + assertTrue("testSwitchMode",true); + } +} + |