Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(444)

Unified Diff: android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java

Issue 2833893002: [Android WebView] Trigger minidump uploading on renderer crash. (Closed)
Patch Set: Post copying-tasks to SERIAL_EXECUTOR instead of THREAD_POOL_EXECUTOR + add several comments. Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java
diff --git a/android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java b/android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java
index 0f3ab07cf519291bc114f589f4ff973deb0a6e9e..6f4cadeeafabbee375512c5afd32168c9055fcf2 100644
--- a/android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java
+++ b/android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java
@@ -23,7 +23,6 @@ import android.webkit.CookieManager;
import android.webkit.GeolocationPermissions;
import android.webkit.ServiceWorkerController;
import android.webkit.TokenBindingService;
-import android.webkit.ValueCallback;
import android.webkit.WebStorage;
import android.webkit.WebView;
import android.webkit.WebViewDatabase;
@@ -40,7 +39,6 @@ import org.chromium.android_webview.AwContentsClient;
import org.chromium.android_webview.AwContentsStatics;
import org.chromium.android_webview.AwCookieManager;
import org.chromium.android_webview.AwDevToolsServer;
-import org.chromium.android_webview.AwMetricsServiceClient;
import org.chromium.android_webview.AwNetworkChangeNotifierRegistrationPolicy;
import org.chromium.android_webview.AwQuotaManagerBridge;
import org.chromium.android_webview.AwResource;
@@ -412,26 +410,14 @@ public class WebViewChromiumFactoryProvider implements WebViewFactoryProvider {
initPlatSupportLibrary();
doNetworkInitializations(context);
final boolean isExternalService = true;
+ // The WebView package name is used to locate the separate Service to which we copy crash
+ // minidumps. This package name must be set before a render process has a chance to crash -
+ // otherwise we might try to copy a minidump without knowing what process to copy it to.
+ AwBrowserProcess.setWebViewPackageName(webViewPackageName);
AwBrowserProcess.configureChildProcessLauncher(webViewPackageName, isExternalService);
AwBrowserProcess.start();
-
- final boolean enableMinidumpUploadingForTesting = CommandLine.getInstance().hasSwitch(
- CommandLineUtil.CRASH_UPLOADS_ENABLED_FOR_TESTING_SWITCH);
- if (enableMinidumpUploadingForTesting) {
- AwBrowserProcess.handleMinidumps(webViewPackageName, true /* enabled */);
- }
-
- PlatformServiceBridge.getInstance().queryMetricsSetting(new ValueCallback<Boolean>() {
- // Actions conditioned on whether the Android Checkbox is toggled on
- public void onReceiveValue(Boolean enabled) {
- ThreadUtils.assertOnUiThread();
- AwMetricsServiceClient.setConsentSetting(context, enabled);
-
- if (!enableMinidumpUploadingForTesting) {
- AwBrowserProcess.handleMinidumps(webViewPackageName, enabled);
- }
- }
- });
+ AwBrowserProcess.handleMinidumpsAndSetMetricsConsent(
+ webViewPackageName, true /* updateMetricsConsent */);
if (CommandLineUtil.isBuildDebuggable()) {
setWebContentsDebuggingEnabled(true);

Powered by Google App Engine
This is Rietveld 408576698