diff options
author | Wu-cheng Li <wuchengli@google.com> | 2010-08-19 16:38:21 -0700 |
---|---|---|
committer | Wu-cheng Li <wuchengli@google.com> | 2010-08-20 16:10:01 -0700 |
commit | dcd762a819f195fdbd441334ca5b97a07f1aa8dd (patch) | |
tree | 8f55a8d17635beb282b0b5f9b0dc26d38feacfe7 | |
parent | 0eda94c5e2302a9e26d6c572ece84fe5428815e2 (diff) | |
download | LegacyCamera-dcd762a819f195fdbd441334ca5b97a07f1aa8dd.zip LegacyCamera-dcd762a819f195fdbd441334ca5b97a07f1aa8dd.tar.gz LegacyCamera-dcd762a819f195fdbd441334ca5b97a07f1aa8dd.tar.bz2 |
Close the video file descriptor earlier.
The file descriptor will be closed in finalize() eventually.
But it is better to close it as soon when we are done with it.
bug:2912676
Change-Id: I04e1abfdc946c2f218cca30d9140627444bce706
-rw-r--r-- | src/com/android/camera/VideoCamera.java | 44 | ||||
-rw-r--r-- | tests/src/com/android/camera/functional/CameraTest.java | 31 |
2 files changed, 55 insertions, 20 deletions
diff --git a/src/com/android/camera/VideoCamera.java b/src/com/android/camera/VideoCamera.java index b5cafe3..8916b1b 100644 --- a/src/com/android/camera/VideoCamera.java +++ b/src/com/android/camera/VideoCamera.java @@ -45,6 +45,7 @@ import android.os.Build; import android.os.Bundle; import android.os.Environment; import android.os.Handler; +import android.os.ParcelFileDescriptor; import android.os.Message; import android.os.StatFs; import android.os.SystemClock; @@ -71,7 +72,6 @@ import android.widget.TextView; import android.widget.Toast; import java.io.File; -import java.io.FileDescriptor; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.ArrayList; @@ -146,8 +146,8 @@ public class VideoCamera extends NoSearchActivity private long mRecordingStartTime; // The video file that the hardware camera is about to record into // (or is recording into.) - private String mCameraVideoFilename; - private FileDescriptor mCameraVideoFileDescriptor; + private String mVideoFilename; + private ParcelFileDescriptor mVideoFileDescriptor; // The video file that has already been recorded, and that is being // examined by the user. @@ -877,11 +877,11 @@ public class VideoCamera extends NoSearchActivity } private void cleanupEmptyFile() { - if (mCameraVideoFilename != null) { - File f = new File(mCameraVideoFilename); + if (mVideoFilename != null) { + File f = new File(mVideoFilename); if (f.length() == 0 && f.delete()) { - Log.v(TAG, "Empty video file deleted: " + mCameraVideoFilename); - mCameraVideoFilename = null; + Log.v(TAG, "Empty video file deleted: " + mVideoFilename); + mVideoFilename = null; } } } @@ -905,9 +905,8 @@ public class VideoCamera extends NoSearchActivity Uri saveUri = (Uri) myExtras.getParcelable(MediaStore.EXTRA_OUTPUT); if (saveUri != null) { try { - mCameraVideoFileDescriptor = - mContentResolver.openFileDescriptor(saveUri, "rw") - .getFileDescriptor(); + mVideoFileDescriptor = + mContentResolver.openFileDescriptor(saveUri, "rw"); mCurrentVideoUri = saveUri; } catch (java.io.FileNotFoundException ex) { // invalid uri @@ -930,11 +929,16 @@ public class VideoCamera extends NoSearchActivity } else { // Try Uri in the intent first. If it doesn't exist, use our own // instead. - if (mCameraVideoFileDescriptor != null) { - mMediaRecorder.setOutputFile(mCameraVideoFileDescriptor); + if (mVideoFileDescriptor != null) { + mMediaRecorder.setOutputFile(mVideoFileDescriptor.getFileDescriptor()); + try { + mVideoFileDescriptor.close(); + } catch (IOException e) { + Log.e(TAG, "Fail to close fd", e); + } } else { createVideoPath(); - mMediaRecorder.setOutputFile(mCameraVideoFilename); + mMediaRecorder.setOutputFile(mVideoFilename); } } @@ -961,7 +965,7 @@ public class VideoCamera extends NoSearchActivity try { mMediaRecorder.prepare(); } catch (IOException e) { - Log.e(TAG, "prepare failed for " + mCameraVideoFilename); + Log.e(TAG, "prepare failed for " + mVideoFilename); releaseMediaRecorder(); throw new RuntimeException(e); } @@ -1000,13 +1004,13 @@ public class VideoCamera extends NoSearchActivity values.put(Video.Media.DATE_TAKEN, dateTaken); values.put(Video.Media.MIME_TYPE, "video/3gpp"); values.put(Video.Media.DATA, filePath); - mCameraVideoFilename = filePath; - Log.v(TAG, "Current camera video filename: " + mCameraVideoFilename); + mVideoFilename = filePath; + Log.v(TAG, "Current camera video filename: " + mVideoFilename); mCurrentVideoValues = values; } private void registerVideo() { - if (mCameraVideoFileDescriptor == null) { + if (mVideoFileDescriptor == null) { Uri videoTable = Uri.parse("content://media/external/video/media"); mCurrentVideoValues.put(Video.Media.SIZE, new File(mCurrentVideoFilename).length()); @@ -1308,7 +1312,7 @@ public class VideoCamera extends NoSearchActivity Log.e(TAG, "stop fail: " + e.getMessage()); } mHeadUpDisplay.setEnabled(true); - mCurrentVideoFilename = mCameraVideoFilename; + mCurrentVideoFilename = mVideoFilename; Log.v(TAG, "Setting current video filename: " + mCurrentVideoFilename); needToRegisterRecording = true; @@ -1323,8 +1327,8 @@ public class VideoCamera extends NoSearchActivity registerVideo(); } - mCameraVideoFilename = null; - mCameraVideoFileDescriptor = null; + mVideoFilename = null; + mVideoFileDescriptor = null; } private void resetScreenOn() { diff --git a/tests/src/com/android/camera/functional/CameraTest.java b/tests/src/com/android/camera/functional/CameraTest.java new file mode 100644 index 0000000..9eca03e --- /dev/null +++ b/tests/src/com/android/camera/functional/CameraTest.java @@ -0,0 +1,31 @@ +package com.android.camera.functional; + +import android.content.Intent; +import android.net.Uri; +import android.os.Environment; +import android.os.Process; +import android.provider.MediaStore; +import android.test.InstrumentationTestCase; +import android.test.suitebuilder.annotation.LargeTest; + +import java.io.File; + +public class CameraTest extends InstrumentationTestCase { + private static final String CAMERA_PACKAGE = "com.google.android.camera"; + private static final String CAMCORDER_ACTIVITY = "com.android.camera.VideoCamera"; + + @LargeTest + public void testVideoCaptureIntentFdLeak() throws Exception { + Intent intent = new Intent(MediaStore.ACTION_VIDEO_CAPTURE); + intent.setClassName(CAMERA_PACKAGE, CAMCORDER_ACTIVITY); + intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); + intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.parse("file://" + + Environment.getExternalStorageDirectory().toString() + + "test_fd_leak.3gp")); + getInstrumentation().startActivitySync(intent).finish(); + // Test if the fd is closed. + for (File f: new File("/proc/" + Process.myPid() + "/fd").listFiles()) { + assertEquals(-1, f.getCanonicalPath().indexOf("test_fd_leak.3gp")); + } + } +} |