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