blob: f8e81883ae3109cb2738f3fd975096cc1026154e [file] [log] [blame]
// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_METRICS_STABILITY_METRICS_HELPER_H_
#define COMPONENTS_METRICS_STABILITY_METRICS_HELPER_H_
#include <string>
#include "base/memory/raw_ptr.h"
#include "base/process/kill.h"
#include "build/build_config.h"
#if BUILDFLAG(IS_WIN)
#include "base/win/windows_types.h"
#endif
class PrefRegistrySimple;
class PrefService;
namespace metrics {
// The values here correspond to values in the Stability message in
// system_profile.proto.
// This must stay 1-1 with the StabilityEventType enum in enums.xml.
// GENERATED_JAVA_ENUM_PACKAGE: org.chromium.components.metrics
enum class StabilityEventType {
kPageLoad = 2,
kRendererCrash = 3,
// kRendererHang = 4, // Removed due to disuse and correctness issues.
kExtensionCrash = 5,
// kChildProcessCrash = 6, // Removed due to disuse and alternative metrics.
kLaunch = 15,
kBrowserCrash = 16,
// kIncompleteShutdown = 17, // Removed due to disuse and correctness issues.
// kPluginCrash = 22, // Removed due to plugin deprecation.
kRendererFailedLaunch = 24,
kExtensionRendererFailedLaunch = 25,
kRendererLaunch = 26,
kExtensionRendererLaunch = 27,
kGpuCrash = 31,
kUtilityCrash = 32,
kUtilityLaunch = 33,
kMaxValue = kUtilityLaunch,
};
// Types of content hosted by a renderer process.
//
// Used for metrics. Keep in sync with the "RendererHostedContentType" histogram
// enum. Do not repurpose previously used indexes.
enum class RendererHostedContentType {
// Hosting an extension
kExtension = 0,
// Hosting an active foreground main frame
kForegroundMainFrame = 1,
// Hosting an active foreground subframe (but no active foreground main frame)
kForegroundSubframe = 2,
// Hosting an active background frame (but no active foreground frame)
kBackgroundFrame = 3,
// Hosting an inactive frame (but no active frame)
// Examples of inactive frames: pending commit, prerendering, in BFCache...
kInactiveFrame = 4,
// Not hosting any frame or extension
kNoFrameOrExtension = 5,
kMaxValue = kNoFrameOrExtension,
};
class SystemProfileProto;
// Responsible for providing functionality common to different embedders'
// stability metrics providers.
class StabilityMetricsHelper {
public:
explicit StabilityMetricsHelper(PrefService* local_state);
StabilityMetricsHelper(const StabilityMetricsHelper&) = delete;
StabilityMetricsHelper& operator=(const StabilityMetricsHelper&) = delete;
~StabilityMetricsHelper();
#if BUILDFLAG(IS_ANDROID)
// A couple Local-State-pref-based stability counts are retained for Android
// WebView. Other platforms, including Android Chrome and WebLayer, should use
// Stability.Counts2 as the source of truth for these counts.
// Provides stability metrics.
void ProvideStabilityMetrics(SystemProfileProto* system_profile_proto);
// Clears the gathered stability metrics.
void ClearSavedStabilityMetrics();
#endif // BUILDFLAG(IS_ANDROID)
// Records a utility process launch with name |metrics_name|.
void BrowserUtilityProcessLaunched(const std::string& metrics_name);
// Records a utility process crash with name |metrics_name|.
void BrowserUtilityProcessCrashed(const std::string& metrics_name,
int exit_code);
// Records that a utility process with name |metrics_name| failed to launch.
// The |launch_error_code| is a platform-specific error code. On Windows, a
// |last_error| is also supplied to help diagnose the launch failure.
void BrowserUtilityProcessLaunchFailed(const std::string& metrics_name,
int launch_error_code
#if BUILDFLAG(IS_WIN)
,
DWORD last_error
#endif
);
// Records a CDM utility process launch with name |metrics_name|.
void CdmUtilityProcessLaunched(const std::string& metrics_name);
// Records a CDM utility process crash with name |metrics_name|.
void CdmUtilityProcessCrashed(const std::string& metrics_name, int exit_code);
// Records that a CDM utility process process with name |metrics_name| failed
// to launch. The |launch_error_code| is a platform-specific error code. On
// Windows, a |last_error| is also supplied to help diagnose the launch
// failure.
void CdmUtilityProcessLaunchFailed(const std::string& metrics_name,
int launch_error_code
#if BUILDFLAG(IS_WIN)
,
DWORD last_error
#endif
);
// Logs the initiation of a page load.
void LogLoadStarted();
// Records a renderer process crash.
#if BUILDFLAG(IS_IOS)
void LogRendererCrash();
#elif !BUILDFLAG(IS_ANDROID)
void LogRendererCrash(RendererHostedContentType hosted_content_type,
base::TerminationStatus status,
int exit_code);
#endif
// Records that a new renderer process was successfully launched.
void LogRendererLaunched(bool was_extension_process);
// Registers local state prefs used by this class.
static void RegisterPrefs(PrefRegistrySimple* registry);
// Increments the RendererCrash pref.
void IncreaseRendererCrashCount();
// Increments the GpuCrash pref.
// Note: This is currently only used on Android. If you want to call this on
// another platform, server-side processing code needs to be updated for that
// platform to use the new data. Server-side currently assumes Android-only.
void IncreaseGpuCrashCount();
// Records a histogram for the input |stability_event_type|.
static void RecordStabilityEvent(StabilityEventType stability_event_type);
private:
// Used for metrics. Keep in sync with the corresponding enums.xml definition.
// Do not repurpose previously used indexes.
enum class CoarseRendererType {
kRenderer = 1,
kExtension = 2,
kMaxValue = kExtension,
};
// Increments an Integer pref value specified by |path|.
void IncrementPrefValue(const char* path);
// Records metrics specific to these termination statuses:
// - TERMINATION_STATUS_PROCESS_CRASHED
// - TERMINATION_STATUS_ABNORMAL_TERMINATION
// - TERMINATION_STATUS_OOM
// Extracted to a helper method to allow sharing between desktop and iOS.
void LogRendererCrashImpl(CoarseRendererType coarse_renderer_type,
int exit_code);
raw_ptr<PrefService> local_state_;
};
} // namespace metrics
#endif // COMPONENTS_METRICS_STABILITY_METRICS_HELPER_H_