Chromium Code Reviews| Index: chrome/browser/page_load_metrics/observers/webui_page_load_metrics_observer.cc |
| diff --git a/chrome/browser/page_load_metrics/observers/webui_page_load_metrics_observer.cc b/chrome/browser/page_load_metrics/observers/webui_page_load_metrics_observer.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..c439af3c92dde23e9b938f11f6f2f5327b602b81 |
| --- /dev/null |
| +++ b/chrome/browser/page_load_metrics/observers/webui_page_load_metrics_observer.cc |
| @@ -0,0 +1,71 @@ |
| +// Copyright 2016 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/page_load_metrics/observers/webui_page_load_metrics_observer.h" |
| + |
| +#include "chrome/browser/page_load_metrics/page_load_metrics_util.h" |
| +#include "chrome/common/url_constants.h" |
| +#include "content/public/browser/navigation_handle.h" |
| + |
| +namespace internal { |
| + |
| +const char kHistogramExtensionsParseDuration[] = |
| + "PageLoad.Clients.WebUI.Extensions.ParseTiming." |
| + "ParseDuration"; |
| + |
| +} // namespace internal |
| +WebUIPageLoadMetricsObserver::WebUIPageLoadMetricsObserver() {} |
| + |
| +page_load_metrics::TrackingPolicy WebUIPageLoadMetricsObserver::ShouldTrackLoad( |
| + content::NavigationHandle* navigation_handle) { |
| + const GURL& url = navigation_handle->GetURL(); |
| + if (url.SchemeIs("chrome")) { |
|
Devlin
2016/09/20 22:59:15
kChromeUIScheme
|
| + if (url.path_piece().find(chrome::kChromeUIExtensionsHost) == 1) { |
|
Devlin
2016/09/20 22:59:15
more information than you ever wanted:
In the curr
Charlie Harrison
2016/09/21 00:32:48
Hmm this is tricky with the current architecture,
Devlin
2016/09/21 00:47:22
This would still be useful for MD extensions, then
Charlie Harrison
2016/09/26 20:05:57
I did an experiment and it still seems like (most
Devlin
2016/09/26 20:39:54
If this turns out to be very complicated, could we
Charlie Harrison
2016/09/26 21:38:19
SG. I will amend the patch to only log for MD.
|
| + tracked_page_ = EXTENSIONS; |
| + } |
| + } |
| + return tracked_page_ == NONE ? page_load_metrics::IGNORE |
| + : page_load_metrics::TRACK; |
| +} |
| + |
| +void WebUIPageLoadMetricsObserver::OnParseStop( |
| + const page_load_metrics::PageLoadTiming& timing, |
| + const page_load_metrics::PageLoadExtraInfo& info) { |
| + if (!WasStartedInForegroundOptionalEventInForeground(timing.parse_stop, |
| + info)) { |
| + return; |
| + } |
| + |
| + switch (tracked_page_) { |
| + case EXTENSIONS: |
| + PAGE_LOAD_HISTOGRAM( |
| + internal::kHistogramExtensionsParseDuration, |
|
Devlin
2016/09/20 22:59:15
It would be useful to have this broken apart by MD
Charlie Harrison
2016/09/21 00:32:48
ACK. This is a good idea.
|
| + timing.parse_stop.value() - timing.parse_start.value()); |
| + break; |
| + case NONE: |
| + NOTREACHED(); |
| + break; |
| + } |
| +} |
| + |
| +void WebUIPageLoadMetricsObserver::OnFirstContentfulPaint( |
| + const page_load_metrics::PageLoadTiming& timing, |
| + const page_load_metrics::PageLoadExtraInfo& info) { |
| + if (!WasStartedInForegroundOptionalEventInForeground( |
| + timing.first_contentful_paint, info)) { |
| + return; |
| + } |
| + |
| + switch (tracked_page_) { |
| + case EXTENSIONS: |
| + PAGE_LOAD_HISTOGRAM( |
| + "PageLoad.Clients.WebUI.Extensions.PaintTiming." |
| + "NavigationToFirstContentfulPaint", |
| + timing.first_contentful_paint.value()); |
| + break; |
| + case NONE: |
| + NOTREACHED(); |
| + break; |
| + } |
| +} |