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

Side by Side Diff: chrome/browser/ui/webui/extensions/extensions_ui.cc

Issue 2341553002: [MD Extensions] Add some performance metrics (Closed)
Patch Set: Created 4 years, 3 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 unified diff | Download patch
« no previous file with comments | « no previous file | tools/metrics/histograms/histograms.xml » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/webui/extensions/extensions_ui.h" 5 #include "chrome/browser/ui/webui/extensions/extensions_ui.h"
6 6
Dan Beam 2016/09/13 23:40:13 nit: #include <memory> for std::unique_ptr
Devlin 2016/09/14 00:33:48 Done.
7 #include "base/metrics/histogram_macros.h"
7 #include "base/strings/utf_string_conversions.h" 8 #include "base/strings/utf_string_conversions.h"
9 #include "base/timer/elapsed_timer.h"
8 #include "build/build_config.h" 10 #include "build/build_config.h"
9 #include "chrome/browser/browser_process.h" 11 #include "chrome/browser/browser_process.h"
10 #include "chrome/browser/profiles/profile.h" 12 #include "chrome/browser/profiles/profile.h"
11 #include "chrome/browser/ui/webui/extensions/extension_loader_handler.h" 13 #include "chrome/browser/ui/webui/extensions/extension_loader_handler.h"
12 #include "chrome/browser/ui/webui/extensions/extension_settings_handler.h" 14 #include "chrome/browser/ui/webui/extensions/extension_settings_handler.h"
13 #include "chrome/browser/ui/webui/extensions/install_extension_handler.h" 15 #include "chrome/browser/ui/webui/extensions/install_extension_handler.h"
14 #include "chrome/browser/ui/webui/metrics_handler.h" 16 #include "chrome/browser/ui/webui/metrics_handler.h"
15 #include "chrome/common/chrome_features.h" 17 #include "chrome/common/chrome_features.h"
16 #include "chrome/common/url_constants.h" 18 #include "chrome/common/url_constants.h"
17 #include "chrome/grit/browser_resources.h" 19 #include "chrome/grit/browser_resources.h"
18 #include "chrome/grit/chromium_strings.h" 20 #include "chrome/grit/chromium_strings.h"
19 #include "chrome/grit/generated_resources.h" 21 #include "chrome/grit/generated_resources.h"
20 #include "chrome/grit/theme_resources.h" 22 #include "chrome/grit/theme_resources.h"
21 #include "components/google/core/browser/google_util.h" 23 #include "components/google/core/browser/google_util.h"
24 #include "content/public/browser/web_contents.h"
25 #include "content/public/browser/web_contents_observer.h"
22 #include "content/public/browser/web_ui.h" 26 #include "content/public/browser/web_ui.h"
23 #include "content/public/browser/web_ui_data_source.h" 27 #include "content/public/browser/web_ui_data_source.h"
24 #include "extensions/common/extension_urls.h" 28 #include "extensions/common/extension_urls.h"
25 #include "ui/base/l10n/l10n_util.h" 29 #include "ui/base/l10n/l10n_util.h"
26 #include "ui/base/resource/resource_bundle.h" 30 #include "ui/base/resource/resource_bundle.h"
27 31
28 #if defined(OS_CHROMEOS) 32 #if defined(OS_CHROMEOS)
29 #include "chrome/browser/chromeos/ownership/owner_settings_service_chromeos_fact ory.h" 33 #include "chrome/browser/chromeos/ownership/owner_settings_service_chromeos_fact ory.h"
30 #include "chrome/browser/ui/webui/extensions/chromeos/kiosk_apps_handler.h" 34 #include "chrome/browser/ui/webui/extensions/chromeos/kiosk_apps_handler.h"
31 #endif 35 #endif
32 36
33 namespace extensions { 37 namespace extensions {
34 38
35 namespace { 39 namespace {
36 40
41 class ExtensionWebUiTimer : public content::WebContentsObserver {
42 public:
43 explicit ExtensionWebUiTimer(content::WebContents* web_contents, bool is_md)
44 : content::WebContentsObserver(web_contents), is_md_(is_md) {}
45 ~ExtensionWebUiTimer() override {}
46
47 void DidStartProvisionalLoadForFrame(
48 content::RenderFrameHost* render_frame_host,
49 const GURL& validated_url,
50 bool is_error_page,
51 bool is_iframe_srcdoc) override {
52 timer_.reset(new base::ElapsedTimer());
Dan Beam 2016/09/13 23:40:13 i assume this captures reloads correctly?
Devlin 2016/09/14 00:33:48 Yep, it seems to. FWIW, this is also what setting
53 }
54
55 void DocumentLoadedInFrame(
56 content::RenderFrameHost* render_frame_host) override {
57 if (render_frame_host != web_contents()->GetMainFrame())
58 return;
59 if (is_md_) {
60 UMA_HISTOGRAM_TIMES("Extensions.WebUi.DocumentLoadedInMainFrameTime.MD",
61 timer_->Elapsed());
62 } else {
63 UMA_HISTOGRAM_TIMES("Extensions.WebUi.DocumentLoadedInMainFrameTime.Uber",
64 timer_->Elapsed());
65 }
66 }
67
68 void DocumentOnLoadCompletedInMainFrame() override {
69 if (is_md_) {
70 UMA_HISTOGRAM_TIMES("Extensions.WebUi.LoadCompletedInMainFrame.MD",
71 timer_->Elapsed());
72 } else {
73 UMA_HISTOGRAM_TIMES("Extensions.WebUi.LoadCompletedInMainFrame.Uber",
74 timer_->Elapsed());
75 }
76 }
77
78 void WebContentsDestroyed() override { delete this; }
79
80 private:
81 // Whether this is the MD version of the chrome://extensions page.
82 bool is_md_;
83
84 std::unique_ptr<base::ElapsedTimer> timer_;
85
86 DISALLOW_COPY_AND_ASSIGN(ExtensionWebUiTimer);
87 };
88
37 content::WebUIDataSource* CreateMdExtensionsSource() { 89 content::WebUIDataSource* CreateMdExtensionsSource() {
38 content::WebUIDataSource* source = 90 content::WebUIDataSource* source =
39 content::WebUIDataSource::Create(chrome::kChromeUIExtensionsHost); 91 content::WebUIDataSource::Create(chrome::kChromeUIExtensionsHost);
40 92
41 source->SetJsonPath("strings.js"); 93 source->SetJsonPath("strings.js");
42 94
43 source->AddLocalizedString("title", 95 source->AddLocalizedString("title",
44 IDS_MANAGE_EXTENSIONS_SETTING_WINDOWS_TITLE); 96 IDS_MANAGE_EXTENSIONS_SETTING_WINDOWS_TITLE);
45 source->AddLocalizedString("toolbarTitle", IDS_MD_EXTENSIONS_TOOLBAR_TITLE); 97 source->AddLocalizedString("toolbarTitle", IDS_MD_EXTENSIONS_TOOLBAR_TITLE);
46 source->AddLocalizedString("search", IDS_MD_EXTENSIONS_SEARCH); 98 source->AddLocalizedString("search", IDS_MD_EXTENSIONS_SEARCH);
(...skipping 162 matching lines...) Expand 10 before | Expand all | Expand 10 after
209 source->DisableDenyXFrameOptions(); 261 source->DisableDenyXFrameOptions();
210 return source; 262 return source;
211 } 263 }
212 264
213 } // namespace 265 } // namespace
214 266
215 ExtensionsUI::ExtensionsUI(content::WebUI* web_ui) : WebUIController(web_ui) { 267 ExtensionsUI::ExtensionsUI(content::WebUI* web_ui) : WebUIController(web_ui) {
216 Profile* profile = Profile::FromWebUI(web_ui); 268 Profile* profile = Profile::FromWebUI(web_ui);
217 content::WebUIDataSource* source = nullptr; 269 content::WebUIDataSource* source = nullptr;
218 270
219 if (base::FeatureList::IsEnabled(features::kMaterialDesignExtensions)) { 271 bool is_md =
272 base::FeatureList::IsEnabled(features::kMaterialDesignExtensions);
273
274 if (is_md) {
220 source = CreateMdExtensionsSource(); 275 source = CreateMdExtensionsSource();
221 InstallExtensionHandler* install_extension_handler = 276 InstallExtensionHandler* install_extension_handler =
222 new InstallExtensionHandler(); 277 new InstallExtensionHandler();
223 install_extension_handler->GetLocalizedValues(source); 278 install_extension_handler->GetLocalizedValues(source);
224 web_ui->AddMessageHandler(install_extension_handler); 279 web_ui->AddMessageHandler(install_extension_handler);
225 } else { 280 } else {
226 source = CreateExtensionsHTMLSource(); 281 source = CreateExtensionsHTMLSource();
227 282
228 ExtensionSettingsHandler* handler = new ExtensionSettingsHandler(); 283 ExtensionSettingsHandler* handler = new ExtensionSettingsHandler();
229 web_ui->AddMessageHandler(handler); 284 web_ui->AddMessageHandler(handler);
(...skipping 19 matching lines...) Expand all
249 #endif 304 #endif
250 305
251 web_ui->AddMessageHandler(new MetricsHandler()); 306 web_ui->AddMessageHandler(new MetricsHandler());
252 307
253 // Need to allow <object> elements so that the <extensionoptions> browser 308 // Need to allow <object> elements so that the <extensionoptions> browser
254 // plugin can be loaded within chrome://extensions. 309 // plugin can be loaded within chrome://extensions.
255 source->OverrideContentSecurityPolicyObjectSrc("object-src 'self';"); 310 source->OverrideContentSecurityPolicyObjectSrc("object-src 'self';");
256 } 311 }
257 312
258 content::WebUIDataSource::Add(profile, source); 313 content::WebUIDataSource::Add(profile, source);
314 // Handles its own lifetime.
315 new ExtensionWebUiTimer(web_ui->GetWebContents(), is_md);
259 } 316 }
260 317
261 ExtensionsUI::~ExtensionsUI() {} 318 ExtensionsUI::~ExtensionsUI() {}
262 319
263 // static 320 // static
264 base::RefCountedMemory* ExtensionsUI::GetFaviconResourceBytes( 321 base::RefCountedMemory* ExtensionsUI::GetFaviconResourceBytes(
265 ui::ScaleFactor scale_factor) { 322 ui::ScaleFactor scale_factor) {
266 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); 323 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance();
267 return rb.LoadDataResourceBytesForScale(IDR_EXTENSIONS_FAVICON, scale_factor); 324 return rb.LoadDataResourceBytesForScale(IDR_EXTENSIONS_FAVICON, scale_factor);
268 } 325 }
269 326
270 } // namespace extensions 327 } // namespace extensions
OLDNEW
« no previous file with comments | « no previous file | tools/metrics/histograms/histograms.xml » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698