Index: components/page_load_metrics/browser/metrics_web_contents_observer.h |
diff --git a/components/page_load_metrics/browser/metrics_web_contents_observer.h b/components/page_load_metrics/browser/metrics_web_contents_observer.h |
index 5fa52c00a18fa2f0cc740c3c6770c23e21d0ca40..45780c10314b8299d30896b9c7e4127739fec65b 100644 |
--- a/components/page_load_metrics/browser/metrics_web_contents_observer.h |
+++ b/components/page_load_metrics/browser/metrics_web_contents_observer.h |
@@ -5,6 +5,7 @@ |
#ifndef COMPONENTS_PAGE_LOAD_METRICS_BROWSER_PAGE_LOAD_METRICS_WEB_CONTENTS_OBSERVER_H_ |
#define COMPONENTS_PAGE_LOAD_METRICS_BROWSER_PAGE_LOAD_METRICS_WEB_CONTENTS_OBSERVER_H_ |
+#include "base/containers/scoped_ptr_map.h" |
#include "base/macros.h" |
#include "base/time/time.h" |
#include "components/page_load_metrics/common/page_load_timing.h" |
@@ -23,6 +24,32 @@ class Message; |
namespace page_load_metrics { |
+class PageLoadTracker { |
+ public: |
+ explicit PageLoadTracker(bool in_foreground); |
+ ~PageLoadTracker(); |
+ void Commit(); |
+ void WebContentsHidden(); |
+ |
+ // Returns true if the timing was successfully updated. |
+ bool UpdateTiming(const PageLoadTiming& timing); |
+ |
+ private: |
+ void RecordTimingHistograms(); |
+ |
+ bool has_commit_; |
+ |
+ // We record separate metrics for events that occur after a background, |
+ // because metrics like layout/paint are delayed artificially |
+ // when they occur in the bacground. |
+ base::TimeTicks background_time_; |
+ bool started_in_foreground_; |
+ |
+ PageLoadTiming timing_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(PageLoadTracker); |
+}; |
+ |
// MetricsWebContentsObserver logs page load UMA metrics based on |
// IPC messages received from a MetricsRenderFrameObserver. |
class MetricsWebContentsObserver |
@@ -34,8 +61,14 @@ class MetricsWebContentsObserver |
// content::WebContentsObserver implementation: |
bool OnMessageReceived(const IPC::Message& message, |
content::RenderFrameHost* render_frame_host) override; |
+ void DidStartNavigation( |
+ content::NavigationHandle* navigation_handle) override; |
void DidFinishNavigation( |
content::NavigationHandle* navigation_handle) override; |
+ |
+ void WasShown() override; |
+ void WasHidden() override; |
+ |
void RenderProcessGone(base::TerminationStatus status) override; |
private: |
@@ -44,13 +77,19 @@ class MetricsWebContentsObserver |
friend class MetricsWebContentsObserverTest; |
void OnTimingUpdated(content::RenderFrameHost*, const PageLoadTiming& timing); |
- void RecordTimingHistograms(); |
bool IsRelevantNavigation(content::NavigationHandle* navigation_handle); |
- // Will be null before any navigations have committed. When a navigation |
- // commits we will initialize this as empty. |
- scoped_ptr<PageLoadTiming> current_timing_; |
+ // True if the web contents is currently in the foreground. |
+ bool in_foreground_; |
+ |
+ // This map tracks all of the navigations ongoing that are not committed |
+ // yet. Once a navigation is committed, it moves from the map to |
+ // committed_load_. Note that a PageLoadTrackers NavigationHandle is only |
+ // valid until commit time, when we remove it from the map. |
+ base::ScopedPtrMap<content::NavigationHandle*, scoped_ptr<PageLoadTracker>> |
+ provisional_loads_; |
+ scoped_ptr<PageLoadTracker> committed_load_; |
DISALLOW_COPY_AND_ASSIGN(MetricsWebContentsObserver); |
}; |