OLD | NEW |
1 # Copyright 2013 The Chromium Authors. All rights reserved. | 1 # Copyright 2013 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 import sys | 5 import sys |
6 | 6 |
7 from metrics import histogram_util | 7 from metrics import histogram_util |
8 from metrics import Metric | 8 from metrics import Metric |
| 9 from telemetry.value import histogram |
| 10 from telemetry.value import scalar |
| 11 |
9 | 12 |
10 _HISTOGRAMS = [ | 13 _HISTOGRAMS = [ |
11 {'name': 'V8.MemoryExternalFragmentationTotal', 'units': 'percent', | 14 {'name': 'V8.MemoryExternalFragmentationTotal', 'units': 'percent', |
12 'display_name': 'V8_MemoryExternalFragmentationTotal', | 15 'display_name': 'V8_MemoryExternalFragmentationTotal', |
13 'type': histogram_util.RENDERER_HISTOGRAM}, | 16 'type': histogram_util.RENDERER_HISTOGRAM}, |
14 {'name': 'V8.MemoryHeapSampleTotalCommitted', 'units': 'kb', | 17 {'name': 'V8.MemoryHeapSampleTotalCommitted', 'units': 'kb', |
15 'display_name': 'V8_MemoryHeapSampleTotalCommitted', | 18 'display_name': 'V8_MemoryHeapSampleTotalCommitted', |
16 'type': histogram_util.RENDERER_HISTOGRAM}, | 19 'type': histogram_util.RENDERER_HISTOGRAM}, |
17 {'name': 'V8.MemoryHeapSampleTotalUsed', 'units': 'kb', | 20 {'name': 'V8.MemoryHeapSampleTotalUsed', 'units': 'kb', |
18 'display_name': 'V8_MemoryHeapSampleTotalUsed', | 21 'display_name': 'V8_MemoryHeapSampleTotalUsed', |
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
86 | 89 |
87 # Optional argument trace_name is not in base class Metric. | 90 # Optional argument trace_name is not in base class Metric. |
88 # pylint: disable=W0221 | 91 # pylint: disable=W0221 |
89 def AddResults(self, tab, results, trace_name=None): | 92 def AddResults(self, tab, results, trace_name=None): |
90 """Add results for this page to the results object.""" | 93 """Add results for this page to the results object.""" |
91 assert self._histogram_delta, 'Must call Stop() first' | 94 assert self._histogram_delta, 'Must call Stop() first' |
92 for h in _HISTOGRAMS: | 95 for h in _HISTOGRAMS: |
93 # Histogram data may not be available | 96 # Histogram data may not be available |
94 if h['name'] not in self._histogram_start: | 97 if h['name'] not in self._histogram_start: |
95 continue | 98 continue |
96 results.Add(h['display_name'], h['units'], | 99 results.AddValue(histogram.HistogramValue( |
97 self._histogram_delta[h['name']], | 100 results.current_page, h['display_name'], h['units'], |
98 data_type='unimportant-histogram') | 101 raw_value_json=self._histogram_delta[h['name']], important=False)) |
99 self._memory_stats = self._browser.memory_stats | 102 self._memory_stats = self._browser.memory_stats |
100 if not self._memory_stats['Browser']: | 103 if not self._memory_stats['Browser']: |
101 return | 104 return |
102 AddResultsForProcesses(results, self._memory_stats, | 105 AddResultsForProcesses(results, self._memory_stats, |
103 metric_trace_name=trace_name) | 106 metric_trace_name=trace_name) |
104 | 107 |
105 end_commit_charge = self._memory_stats['SystemCommitCharge'] | 108 end_commit_charge = self._memory_stats['SystemCommitCharge'] |
106 commit_charge_difference = end_commit_charge - self._start_commit_charge | 109 commit_charge_difference = end_commit_charge - self._start_commit_charge |
107 results.Add(trace_name or 'commit_charge', 'kb', | 110 results.AddValue(scalar.ScalarValue( |
108 commit_charge_difference, | 111 results.current_page, |
109 chart_name='commit_charge', | 112 'commit_charge.' + (trace_name or 'commit_charge'), |
110 data_type='unimportant') | 113 'kb', |
111 results.Add(trace_name or 'processes', 'count', | 114 commit_charge_difference, important=False)) |
112 self._memory_stats['ProcessCount'], | 115 results.AddValue(scalar.ScalarValue( |
113 chart_name='processes', | 116 results.current_page, |
114 data_type='unimportant') | 117 'processes.' + (trace_name or 'processes'), |
| 118 'count', |
| 119 self._memory_stats['ProcessCount'], |
| 120 important=False)) |
115 | 121 |
116 | 122 |
117 def AddResultsForProcesses(results, memory_stats, chart_trace_name='final', | 123 def AddResultsForProcesses(results, memory_stats, chart_trace_name='final', |
118 metric_trace_name=None, | 124 metric_trace_name=None, |
119 exclude_metrics=None): | 125 exclude_metrics=None): |
120 """Adds memory stats for browser, renderer and gpu processes. | 126 """Adds memory stats for browser, renderer and gpu processes. |
121 | 127 |
122 Args: | 128 Args: |
123 results: A PageMeasurement results object. | 129 results: A PageMeasurement results object. |
124 memory_stats: System memory stats collected. | 130 memory_stats: System memory stats collected. |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
156 stats = memory_stats[process_type_memory] | 162 stats = memory_stats[process_type_memory] |
157 if value_name_memory in stats: | 163 if value_name_memory in stats: |
158 values.append(stats[value_name_memory]) | 164 values.append(stats[value_name_memory]) |
159 if values: | 165 if values: |
160 if metric_trace_name: | 166 if metric_trace_name: |
161 current_trace = '%s_%s' % (metric_trace_name, process_type_trace) | 167 current_trace = '%s_%s' % (metric_trace_name, process_type_trace) |
162 chart_name = value_name_trace | 168 chart_name = value_name_trace |
163 else: | 169 else: |
164 current_trace = '%s_%s' % (value_name_trace, process_type_trace) | 170 current_trace = '%s_%s' % (value_name_trace, process_type_trace) |
165 chart_name = current_trace | 171 chart_name = current_trace |
166 results.Add(current_trace, 'kb', sum(values) / 1024, | 172 results.AddValue(scalar.ScalarValue( |
167 chart_name=chart_name, data_type='unimportant') | 173 results.current_page, '%s.%s' % (chart_name, current_trace), 'kb', |
| 174 sum(values) / 1024, important=False)) |
168 | 175 |
169 AddResult('VM', 'vm_%s_size' % chart_trace_name) | 176 AddResult('VM', 'vm_%s_size' % chart_trace_name) |
170 AddResult('WorkingSetSize', 'vm_%s_%s_size' % (metric, chart_trace_name)) | 177 AddResult('WorkingSetSize', 'vm_%s_%s_size' % (metric, chart_trace_name)) |
171 AddResult('PrivateDirty', 'vm_private_dirty_%s' % chart_trace_name) | 178 AddResult('PrivateDirty', 'vm_private_dirty_%s' % chart_trace_name) |
172 AddResult('ProportionalSetSize', | 179 AddResult('ProportionalSetSize', |
173 'vm_proportional_set_size_%s' % chart_trace_name) | 180 'vm_proportional_set_size_%s' % chart_trace_name) |
174 AddResult('SharedDirty', 'vm_shared_dirty_%s' % chart_trace_name) | 181 AddResult('SharedDirty', 'vm_shared_dirty_%s' % chart_trace_name) |
175 AddResult('VMPeak', 'vm_peak_size') | 182 AddResult('VMPeak', 'vm_peak_size') |
176 AddResult('WorkingSetSizePeak', '%s_peak_size' % metric) | 183 AddResult('WorkingSetSizePeak', '%s_peak_size' % metric) |
177 | 184 |
178 AddResultsForProcessTypes(['Browser'], 'browser') | 185 AddResultsForProcessTypes(['Browser'], 'browser') |
179 AddResultsForProcessTypes(['Renderer'], 'renderer') | 186 AddResultsForProcessTypes(['Renderer'], 'renderer') |
180 AddResultsForProcessTypes(['Gpu'], 'gpu') | 187 AddResultsForProcessTypes(['Gpu'], 'gpu') |
181 AddResultsForProcessTypes(['Browser', 'Renderer', 'Gpu'], 'total') | 188 AddResultsForProcessTypes(['Browser', 'Renderer', 'Gpu'], 'total') |
OLD | NEW |