Chromium Code Reviews| Index: chrome/android/java/src/org/chromium/chrome/browser/crash/MinidumpDirectoryObserver.java |
| diff --git a/chrome/android/java/src/org/chromium/chrome/browser/crash/MinidumpDirectoryObserver.java b/chrome/android/java/src/org/chromium/chrome/browser/crash/MinidumpDirectoryObserver.java |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..1ad73722c5a4ef6b1339b87b4d4f514c971e8139 |
| --- /dev/null |
| +++ b/chrome/android/java/src/org/chromium/chrome/browser/crash/MinidumpDirectoryObserver.java |
| @@ -0,0 +1,57 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +package org.chromium.chrome.browser.crash; |
| + |
| +import android.content.Context; |
| +import android.content.Intent; |
| +import android.os.FileObserver; |
| + |
| +import org.chromium.base.ApplicationStatus; |
| +import org.chromium.base.Log; |
| +import org.chromium.base.ThreadUtils; |
| +import org.chromium.base.metrics.RecordUserAction; |
| + |
| +import java.io.File; |
| + |
| +/** |
| + * This class is a singleton that holds utilities for observer to monitor the minidump directory. |
| + */ |
| +public final class MinidumpDirectoryObserver extends FileObserver { |
| + |
| + private static final String TAG = "MinidumpDirObserver"; |
| + |
| + private static MinidumpDirectoryObserver sMinidumpDirectoryObserver; |
| + private static Context sContext = ApplicationStatus.getApplicationContext(); |
| + |
| + public static final String MINIDUMP_EXPERIMENT_NAME = "AddMinidumpDirObserver"; |
| + |
| + public static void startObserverWatching() { |
| + ThreadUtils.assertOnUiThread(); |
| + if (sMinidumpDirectoryObserver == null) { |
| + sMinidumpDirectoryObserver = new MinidumpDirectoryObserver(); |
| + } |
| + sMinidumpDirectoryObserver.startWatching(); |
| + } |
| + |
| + private MinidumpDirectoryObserver() { |
| + // The file observer detects MOVED_TO for renderer crash and GPU crash; |
|
no sievers
2016/01/29 23:52:34
nit: I'd just say 'child processes'. There's also
Menglin
2016/01/30 00:29:11
Done.
|
| + // it detects CREATE for browser crash |
| + super(new File(sContext.getCacheDir(), CrashFileManager.CRASH_DUMP_DIR).toString(), |
| + FileObserver.MOVED_TO); |
| + } |
| + |
| + /** |
| + * When a miniudump is detected, upload it to Google crash server |
| + */ |
| + @Override |
| + public void onEvent(int event, String path) { |
|
no sievers
2016/01/29 23:52:34
nit: Can you put a comment that this is happening
Menglin
2016/01/30 00:29:11
Done.
|
| + if (CrashFileManager.isMinidumpMIMEFirstTry(path)) { |
| + Intent intent = MinidumpUploadService.createFindAndUploadLastCrashIntent(sContext); |
| + sContext.startService(intent); |
| + Log.i(TAG, "Detects a new minidump %s sending intent to MinidumpUploadService", path); |
| + RecordUserAction.record("MobileBreakpadUploadAttempt"); |
|
no sievers
2016/01/29 23:52:34
This stat is still a bit broken, since the name su
Menglin
2016/01/30 00:29:12
I will leave it as it is for now and fix that in a
|
| + } |
| + } |
| +} |