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

Unified Diff: chrome/browser/metrics/renderer_uptime_web_contents_observer.cc

Issue 2697323004: Adds UMA metrics for renderer uptime (Closed)
Patch Set: Removed metric provider Created 3 years, 10 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: chrome/browser/metrics/renderer_uptime_web_contents_observer.cc
diff --git a/chrome/browser/metrics/renderer_uptime_web_contents_observer.cc b/chrome/browser/metrics/renderer_uptime_web_contents_observer.cc
new file mode 100644
index 0000000000000000000000000000000000000000..c45e2384806f803f928d88879f643b0276d42b47
--- /dev/null
+++ b/chrome/browser/metrics/renderer_uptime_web_contents_observer.cc
@@ -0,0 +1,42 @@
+// Copyright 2017 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.
+
+#include "chrome/browser/metrics/renderer_uptime_web_contents_observer.h"
+
+#include "chrome/browser/metrics/renderer_uptime_tracker.h"
+#include "content/public/browser/render_process_host.h"
+
+DEFINE_WEB_CONTENTS_USER_DATA_KEY(metrics::RendererUptimeWebContentsObserver);
+
+namespace metrics {
+
+RendererUptimeWebContentsObserver::RendererUptimeWebContentsObserver(
+ content::WebContents* web_contents)
+ : content::WebContentsObserver(web_contents) {}
+
+// static
+RendererUptimeWebContentsObserver*
+RendererUptimeWebContentsObserver::CreateForWebContents(
+ content::WebContents* web_contents) {
+ DCHECK(web_contents);
+
+ if (!RendererUptimeTracker::IsInitialized())
+ return nullptr;
+
+ RendererUptimeWebContentsObserver* observer = FromWebContents(web_contents);
+ if (!observer) {
+ observer = new RendererUptimeWebContentsObserver(web_contents);
+ web_contents->SetUserData(UserDataKey(), observer);
+ }
+ return observer;
+}
+
+void RendererUptimeWebContentsObserver::DocumentAvailableInMainFrame() {
+ if (!RendererUptimeTracker::IsInitialized())
+ return;
+ ::RendererUptimeTracker::Get()->OnLoadInMainFrame(
Alexei Svitkine (slow) 2017/03/01 15:50:18 Nit: No ::
keishi 2017/03/02 09:37:14 Done.
+ web_contents()->GetRenderProcessHost()->GetID());
+}
+
+} // namespace metrics

Powered by Google App Engine
This is Rietveld 408576698