| OLD | NEW |
| 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 from telemetry.core import util | 4 |
| 5 from telemetry.page import multi_page_benchmark | 5 from telemetry import multi_page_benchmark |
| 6 from telemetry import util |
| 6 | 7 |
| 7 MEMORY_HISTOGRAMS = [ | 8 MEMORY_HISTOGRAMS = [ |
| 8 {'name': 'V8.MemoryExternalFragmentationTotal', 'units': 'percent'}, | 9 {'name': 'V8.MemoryExternalFragmentationTotal', 'units': 'percent'}, |
| 9 {'name': 'V8.MemoryHeapSampleTotalCommitted', 'units': 'kb'}, | 10 {'name': 'V8.MemoryHeapSampleTotalCommitted', 'units': 'kb'}, |
| 10 {'name': 'V8.MemoryHeapSampleTotalUsed', 'units': 'kb'}] | 11 {'name': 'V8.MemoryHeapSampleTotalUsed', 'units': 'kb'}] |
| 11 | 12 |
| 12 class PageCycler(multi_page_benchmark.MultiPageBenchmark): | 13 class PageCycler(multi_page_benchmark.MultiPageBenchmark): |
| 13 def CustomizeBrowserOptions(self, options): | 14 def CustomizeBrowserOptions(self, options): |
| 14 options.AppendExtraBrowserArg('--dom-automation') | 15 options.AppendExtraBrowserArg('--dom-automation') |
| 15 options.AppendExtraBrowserArg('--js-flags=--expose_gc') | 16 options.AppendExtraBrowserArg('--js-flags=--expose_gc') |
| (...skipping 12 matching lines...) Expand all Loading... |
| 28 'window.domAutomationController.getHistogram("%s")' % name) | 29 'window.domAutomationController.getHistogram("%s")' % name) |
| 29 results.Add(name, histogram['units'], data, data_type='histogram') | 30 results.Add(name, histogram['units'], data, data_type='histogram') |
| 30 | 31 |
| 31 def _IsNavigatedToReport(): | 32 def _IsNavigatedToReport(): |
| 32 return tab.GetCookieByName('__navigated_to_report') == '1' | 33 return tab.GetCookieByName('__navigated_to_report') == '1' |
| 33 util.WaitFor(_IsNavigatedToReport, 60, poll_interval=5) | 34 util.WaitFor(_IsNavigatedToReport, 60, poll_interval=5) |
| 34 timings = tab.EvaluateJavaScript('__get_timings()').split(',') | 35 timings = tab.EvaluateJavaScript('__get_timings()').split(',') |
| 35 results.Add('t', 'ms', [int(t) for t in timings], chart_name='times') | 36 results.Add('t', 'ms', [int(t) for t in timings], chart_name='times') |
| 36 | 37 |
| 37 # TODO(tonyg): Add version that runs with extension profile. | 38 # TODO(tonyg): Add version that runs with extension profile. |
| OLD | NEW |