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

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: Rebase Created 3 years, 7 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 6d8e29188ba6a08852315c37d1e0a5293714121e..1e7fb166c1429911486ef55c01bcee1a9cb13f26 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
@@ -24,7 +24,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;
@@ -41,13 +40,11 @@ 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;
import org.chromium.android_webview.AwSettings;
import org.chromium.android_webview.HttpAuthDatabase;
-import org.chromium.android_webview.PlatformServiceBridge;
import org.chromium.android_webview.ResourcesContextWrapperFactory;
import org.chromium.android_webview.command_line.CommandLineUtil;
import org.chromium.base.BuildConfig;
@@ -417,26 +414,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