summaryrefslogtreecommitdiffstats
path: root/media/tests
diff options
context:
space:
mode:
authorZhijun He <zhijunhe@google.com>2013-09-25 16:33:35 -0700
committerZhijun He <zhijunhe@google.com>2013-09-25 19:33:31 -0700
commit7b7a154026f5660de68180de8a2158dff51889e6 (patch)
tree035ed312948fda7ab6bd9cf91c09f596f378e827 /media/tests
parent2001188be30649198972a3199a4322d6f7f5f93d (diff)
downloadframeworks_base-7b7a154026f5660de68180de8a2158dff51889e6.zip
frameworks_base-7b7a154026f5660de68180de8a2158dff51889e6.tar.gz
frameworks_base-7b7a154026f5660de68180de8a2158dff51889e6.tar.bz2
Camera2: Fix Camera integration test deadlock
The problem was: when SurfaceTexture is used, test didn't acquire/release images when they are produced, then it starves the producer and cause deadlock. This change replaces SurfaceTexture with ImageReader, release every image produced immediately. Bug: 10360518 Change-Id: I9aabaee23013277c2da6f5825ac931bc10511fbc
Diffstat (limited to 'media/tests')
-rw-r--r--media/tests/MediaFrameworkTest/src/com/android/mediaframeworktest/integration/CameraDeviceBinderTest.java40
1 files changed, 33 insertions, 7 deletions
diff --git a/media/tests/MediaFrameworkTest/src/com/android/mediaframeworktest/integration/CameraDeviceBinderTest.java b/media/tests/MediaFrameworkTest/src/com/android/mediaframeworktest/integration/CameraDeviceBinderTest.java
index aef61c7..13ce52e 100644
--- a/media/tests/MediaFrameworkTest/src/com/android/mediaframeworktest/integration/CameraDeviceBinderTest.java
+++ b/media/tests/MediaFrameworkTest/src/com/android/mediaframeworktest/integration/CameraDeviceBinderTest.java
@@ -16,6 +16,7 @@
package com.android.mediaframeworktest.integration;
+import android.graphics.ImageFormat;
import android.graphics.SurfaceTexture;
import android.hardware.camera2.CameraMetadata;
import android.hardware.camera2.CameraCharacteristics;
@@ -24,6 +25,10 @@ import android.hardware.camera2.ICameraDeviceCallbacks;
import android.hardware.camera2.ICameraDeviceUser;
import android.hardware.camera2.impl.CameraMetadataNative;
import android.hardware.camera2.utils.BinderHolder;
+import android.media.Image;
+import android.media.ImageReader;
+import android.os.Handler;
+import android.os.HandlerThread;
import android.os.RemoteException;
import android.test.AndroidTestCase;
import android.test.suitebuilder.annotation.SmallTest;
@@ -43,19 +48,32 @@ public class CameraDeviceBinderTest extends AndroidTestCase {
private static int NUM_CALLBACKS_CHECKED = 10;
// Wait for capture result timeout value: 1500ms
private final static int WAIT_FOR_COMPLETE_TIMEOUT_MS = 1500;
+ // Default size is VGA, which is mandatory camera supported image size by CDD.
+ private static final int DEFAULT_IMAGE_WIDTH = 640;
+ private static final int DEFAULT_IMAGE_HEIGHT = 480;
+ private static final int MAX_NUM_IMAGES = 5;
private int mCameraId;
private ICameraDeviceUser mCameraUser;
private CameraBinderTestUtils mUtils;
private ICameraDeviceCallbacks.Stub mMockCb;
private Surface mSurface;
- // Need hold a Surfacetexture reference during a test execution, otherwise,
- // it could be GCed during a test, which causes camera run into bad state.
- private SurfaceTexture mSurfaceTexture;
+ private HandlerThread mHandlerThread;
+ private Handler mHandler;
+ ImageReader mImageReader;
public CameraDeviceBinderTest() {
}
+ private class ImageDropperListener implements ImageReader.OnImageAvailableListener {
+
+ @Override
+ public void onImageAvailable(ImageReader reader) {
+ Image image = reader.acquireNextImage();
+ if (image != null) image.close();
+ }
+ }
+
public class DummyCameraDeviceCallbacks extends ICameraDeviceCallbacks.Stub {
@Override
@@ -75,9 +93,13 @@ public class CameraDeviceBinderTest extends AndroidTestCase {
}
private void createDefaultSurface() {
- mSurfaceTexture = new SurfaceTexture(/* ignored */0);
- mSurfaceTexture.setDefaultBufferSize(640, 480);
- mSurface = new Surface(mSurfaceTexture);
+ mImageReader =
+ ImageReader.newInstance(DEFAULT_IMAGE_WIDTH,
+ DEFAULT_IMAGE_HEIGHT,
+ ImageFormat.YUV_420_888,
+ MAX_NUM_IMAGES);
+ mImageReader.setOnImageAvailableListener(new ImageDropperListener(), mHandler);
+ mSurface = mImageReader.getSurface();
}
private CaptureRequest.Builder createDefaultBuilder(boolean needStream) throws Exception {
@@ -134,6 +156,9 @@ public class CameraDeviceBinderTest extends AndroidTestCase {
clientPackageName, CameraBinderTestUtils.USE_CALLING_UID, holder);
mCameraUser = ICameraDeviceUser.Stub.asInterface(holder.getBinder());
assertNotNull(String.format("Camera %s was null", mCameraId), mCameraUser);
+ mHandlerThread = new HandlerThread(TAG);
+ mHandlerThread.start();
+ mHandler = new Handler(mHandlerThread.getLooper());
createDefaultSurface();
Log.v(TAG, String.format("Camera %s connected", mCameraId));
@@ -144,7 +169,8 @@ public class CameraDeviceBinderTest extends AndroidTestCase {
mCameraUser.disconnect();
mCameraUser = null;
mSurface.release();
- mSurfaceTexture.release();
+ mImageReader.close();
+ mHandlerThread.quitSafely();
}
@SmallTest