Chromium Code Reviews| Index: tools/perf/measurements/page_cycler.py |
| diff --git a/tools/perf/measurements/page_cycler.py b/tools/perf/measurements/page_cycler.py |
| index e373eeab72694b39f1f202a54aedcf6e2842739e..5d28a2a44977be939d08e6af57ac2c89ad6a92bc 100644 |
| --- a/tools/perf/measurements/page_cycler.py |
| +++ b/tools/perf/measurements/page_cycler.py |
| @@ -20,6 +20,7 @@ import sys |
| from metrics import io |
| from metrics import memory |
| +from metrics import v8_object_stats |
| from telemetry.core import util |
| from telemetry.page import page_measurement |
| @@ -31,7 +32,11 @@ class PageCycler(page_measurement.PageMeasurement): |
| 'page_cycler.js'), 'r') as f: |
| self._page_cycler_js = f.read() |
| + self._record_v8_object_stats = False |
| + |
| self._memory_metric = None |
| + self._v8_object_stats_metric = None |
| + |
| def AddCommandLineOptions(self, parser): |
| # The page cyclers should default to 10 iterations. In order to change the |
| @@ -42,9 +47,15 @@ class PageCycler(page_measurement.PageMeasurement): |
| parser.remove_option('--pageset-repeat') |
| parser.add_option(pageset_repeat_option) |
| + parser.add_option('--v8-object-stats', |
| + action='store_true', |
| + help='Enable detailed V8 object statistics.') |
| + |
| def DidStartBrowser(self, browser): |
| """Initialize metrics once right after the browser has been launched.""" |
| self._memory_metric = memory.MemoryMetric(browser) |
| + if self._record_v8_object_stats: |
| + self._v8_object_stats_metric = v8_object_stats.V8ObjectStatsMetric() |
| def DidStartHTTPServer(self, tab): |
| # Avoid paying for a cross-renderer navigation on the first page on legacy |
| @@ -56,11 +67,21 @@ class PageCycler(page_measurement.PageMeasurement): |
| def DidNavigateToPage(self, page, tab): |
| self._memory_metric.Start(page, tab) |
| + if self._record_v8_object_stats: |
| + self._v8_object_stats_metric.Start(page, tab) |
| def CustomizeBrowserOptions(self, options): |
| - memory.MemoryMetric.CustomizeBrowserOptions(options) |
| - io.IOMetric.CustomizeBrowserOptions(options) |
| + options.AppendExtraBrowserArg('--enable-stats-collection-bindings') |
|
tonyg
2013/08/27 15:40:02
Was there a merge error here? Ideally there should
rmcilroy
2013/08/27 18:24:07
Opps, this seems to have been a merge error. Done
|
| options.AppendExtraBrowserArg('--js-flags=--expose_gc') |
| + options.AppendExtraBrowserArg('--no-sandbox') |
| + |
| + # Old commandline flags used for reference builds. |
| + options.AppendExtraBrowserArg('--dom-automation') |
| + |
| + # Add custom options required by metrics |
| + if options.v8_object_stats: |
| + self._record_v8_object_stats = True |
| + v8_object_stats.V8ObjectStatsMetric.CustomizeBrowserOptions(options) |
| # Temporarily disable typical_25 page set on mac. |
| if sys.platform == 'darwin' and sys.argv[-1].endswith('/typical_25.json'): |
| @@ -77,6 +98,9 @@ class PageCycler(page_measurement.PageMeasurement): |
| self._memory_metric.Stop(page, tab) |
| self._memory_metric.AddResults(tab, results) |
| + if self._record_v8_object_stats: |
| + self._v8_object_stats_metric.Stop(page, tab) |
| + self._v8_object_stats_metric.AddResults(tab, results) |
| def DidRunTest(self, tab, results): |
| self._memory_metric.AddSummaryResults(results) |