Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 1 | <!DOCTYPE html> |
| 2 | <!-- |
| 3 | Copyright (c) 2014 The Chromium Authors. All rights reserved. |
| 4 | Use of this source code is governed by a BSD-style license that can be |
| 5 | found in the LICENSE file. |
| 6 | --> |
Chris Craik | f516a62 | 2015-04-01 17:52:39 -0700 | [diff] [blame] | 7 | <link rel="import" href="/extras/audits/chrome_process_helper.html"> |
Chris Craik | 44c2820 | 2015-05-12 17:25:16 -0700 | [diff] [blame^] | 8 | <link rel="import" href="/extras/cc/input_latency_async_slice.html"> |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 9 | |
| 10 | <script> |
| 11 | 'use strict'; |
| 12 | |
| 13 | /** |
| 14 | * @fileoverview Utilities for accessing trace data about the Chrome browser. |
| 15 | */ |
| 16 | tv.exportTo('tv.e.audits', function() { |
Chris Craik | f516a62 | 2015-04-01 17:52:39 -0700 | [diff] [blame] | 17 | function ChromeBrowserHelper(modelHelper, process) { |
| 18 | tv.e.audits.ChromeProcessHelper.call(this, modelHelper, process); |
Chris Craik | 44c2820 | 2015-05-12 17:25:16 -0700 | [diff] [blame^] | 19 | this.mainThread_ = process.findAtMostOneThreadNamed('CrBrowserMain'); |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 20 | } |
| 21 | |
Chris Craik | 44c2820 | 2015-05-12 17:25:16 -0700 | [diff] [blame^] | 22 | ChromeBrowserHelper.isBrowserProcess = function(process) { |
| 23 | if (!process.findAtMostOneThreadNamed('CrBrowserMain')) |
| 24 | return false; |
| 25 | return true; |
| 26 | }; |
| 27 | |
Chris Craik | f516a62 | 2015-04-01 17:52:39 -0700 | [diff] [blame] | 28 | ChromeBrowserHelper.prototype = { |
| 29 | __proto__: tv.e.audits.ChromeProcessHelper.prototype, |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 30 | |
Chris Craik | 44c2820 | 2015-05-12 17:25:16 -0700 | [diff] [blame^] | 31 | get rendererProcesses() { |
| 32 | return this.modelHelper.rendererProcesses; |
| 33 | }, |
| 34 | |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 35 | getLoadingEventsInRange: function(rangeOfInterest) { |
| 36 | var loadingEvents = []; |
| 37 | tv.b.iterItems(this.process.threads, function(tid, thread) { |
| 38 | thread.iterateAllEvents(function(event) { |
| 39 | if (event.title.indexOf('WebContentsImpl Loading') !== 0) |
| 40 | return; |
| 41 | if (rangeOfInterest.intersectsExplicitRange(event.start, event.end)) |
| 42 | loadingEvents.push(event); |
| 43 | }); |
| 44 | }); |
| 45 | return loadingEvents; |
| 46 | }, |
| 47 | |
| 48 | get hasLatencyEvents() { |
| 49 | var hasLatency = false; |
Chris Craik | f516a62 | 2015-04-01 17:52:39 -0700 | [diff] [blame] | 50 | this.modelHelper.model.getAllThreads().forEach(function(thread) { |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 51 | thread.iterateAllEvents(function(event) { |
Chris Craik | 44c2820 | 2015-05-12 17:25:16 -0700 | [diff] [blame^] | 52 | if (!event.isTopLevel) |
| 53 | return; |
| 54 | if (!(event instanceof tv.e.cc.InputLatencyAsyncSlice)) |
| 55 | return; |
| 56 | hasLatency = true; |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 57 | }); |
| 58 | }); |
| 59 | return hasLatency; |
| 60 | }, |
| 61 | |
| 62 | getLatencyEventsInRange: function(rangeOfInterest) { |
| 63 | var latencyEvents = []; |
Chris Craik | f516a62 | 2015-04-01 17:52:39 -0700 | [diff] [blame] | 64 | this.modelHelper.model.getAllThreads().forEach(function(thread) { |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 65 | thread.iterateAllEvents(function(event) { |
Chris Craik | 44c2820 | 2015-05-12 17:25:16 -0700 | [diff] [blame^] | 66 | if (!event.isTopLevel) |
| 67 | return; |
| 68 | if (!(event instanceof tv.e.cc.InputLatencyAsyncSlice)) |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 69 | return; |
| 70 | if (rangeOfInterest.intersectsExplicitRange(event.start, event.end)) |
| 71 | latencyEvents.push(event); |
| 72 | }); |
| 73 | }); |
| 74 | return latencyEvents; |
| 75 | }, |
| 76 | |
Chris Craik | 44c2820 | 2015-05-12 17:25:16 -0700 | [diff] [blame^] | 77 | getAllAsyncSlicesMatching: function(pred, opt_this) { |
| 78 | var events = []; |
| 79 | this.iterAllThreads(function(thread) { |
| 80 | thread.asyncSliceGroup.slices.forEach(function(slice) { |
| 81 | if (pred.call(opt_this, slice)) |
| 82 | events.push(slice); |
| 83 | }); |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 84 | }); |
Chris Craik | 44c2820 | 2015-05-12 17:25:16 -0700 | [diff] [blame^] | 85 | return events; |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 86 | }, |
| 87 | |
| 88 | getAllNetworkEventsInRange: function(rangeOfInterest) { |
| 89 | var networkEvents = []; |
Chris Craik | f516a62 | 2015-04-01 17:52:39 -0700 | [diff] [blame] | 90 | this.modelHelper.model.getAllThreads().forEach(function(thread) { |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 91 | thread.asyncSliceGroup.slices.forEach(function(slice) { |
| 92 | var match = false; |
| 93 | if (slice.cat == 'net' || // old-style URLRequest/Resource slices. |
| 94 | slice.cat == 'disabled-by-default-netlog' || // early netlog. |
| 95 | slice.cat == 'netlog') { |
| 96 | match = true; |
| 97 | } |
| 98 | |
| 99 | if (!match) |
| 100 | return; |
| 101 | |
| 102 | if (rangeOfInterest.intersectsExplicitRange(slice.start, slice.end)) |
| 103 | networkEvents.push(slice); |
| 104 | }); |
| 105 | }); |
| 106 | return networkEvents; |
Chris Craik | 44c2820 | 2015-05-12 17:25:16 -0700 | [diff] [blame^] | 107 | }, |
| 108 | |
| 109 | iterAllThreads: function(func, opt_this) { |
| 110 | tv.b.iterItems(this.process.threads, function(tid, thread) { |
| 111 | func.call(opt_this, thread); |
| 112 | }); |
| 113 | this.rendererProcesses.forEach(function(rendererProcess) { |
| 114 | tv.b.iterItems(rendererProcess.threads, function(tid, thread) { |
| 115 | func.call(opt_this, thread); |
| 116 | }); |
| 117 | }); |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 118 | } |
| 119 | }; |
| 120 | |
| 121 | return { |
Chris Craik | f516a62 | 2015-04-01 17:52:39 -0700 | [diff] [blame] | 122 | ChromeBrowserHelper: ChromeBrowserHelper |
Chris Craik | 93216d0 | 2015-03-05 13:58:42 -0800 | [diff] [blame] | 123 | }; |
| 124 | }); |
| 125 | </script> |