| 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..a202d61a0e6b6408382d9b5b1885f48d376970b3 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"
|
| @@ -13,16 +14,49 @@
|
| #include "content/public/browser/web_contents_user_data.h"
|
|
|
| namespace content {
|
| +
|
| class NavigationHandle;
|
| class RenderFrameHost;
|
| +
|
| } // namespace content
|
|
|
| namespace IPC {
|
| +
|
| class Message;
|
| +
|
| } // namespace IPC
|
|
|
| namespace page_load_metrics {
|
|
|
| +class PageLoadTracker {
|
| + public:
|
| + PageLoadTracker(bool in_foreground);
|
| + ~PageLoadTracker();
|
| + void Commit();
|
| + // Either the onload handler was called, or the page load failed.
|
| + void Finish();
|
| + void WebContentsHidden();
|
| +
|
| + // Returns true if the timing was successfully updated.
|
| + bool UpdateTiming(const PageLoadTiming& timing);
|
| +
|
| + private:
|
| + void RecordTimingHistograms();
|
| +
|
| + bool has_commit_;
|
| + bool has_finished_;
|
| +
|
| + // True if the web contents stayed in the foreground for the entire
|
| + // page load. We record separate metrics for any web contents that have been
|
| + // backgrounded, because metrics like layout/paint are delayed artificially
|
| + // when they occur in the bacground.
|
| + bool page_load_stayed_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
|
| @@ -36,7 +70,20 @@ class MetricsWebContentsObserver
|
| content::RenderFrameHost* render_frame_host) override;
|
| void DidFinishNavigation(
|
| content::NavigationHandle* navigation_handle) override;
|
| - void RenderProcessGone(base::TerminationStatus status) override;
|
| + void DidStartNavigation(
|
| + content::NavigationHandle* navigation_handle) override;
|
| +
|
| + // This method is called after the onload event is dispatched.
|
| + void DidFinishLoad(content::RenderFrameHost* render_frame_host,
|
| + const GURL& validated_url) override;
|
| + void DidFailLoad(content::RenderFrameHost* render_frame_host,
|
| + const GURL& validated_url,
|
| + int error_code,
|
| + const base::string16& error_description,
|
| + bool was_ignored_by_handler) override;
|
| +
|
| + void WasShown() override;
|
| + void WasHidden() override;
|
|
|
| private:
|
| explicit MetricsWebContentsObserver(content::WebContents* web_contents);
|
| @@ -44,13 +91,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);
|
| };
|
|
|