Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1374)

Unified Diff: tools/perf/perf_tools/memory_benchmark.py

Issue 11273081: Adding a test for measuring memory usage. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Split out interactions. Created 8 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | tools/perf/perf_tools/multipage_benchmark_runner.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/perf/perf_tools/memory_benchmark.py
diff --git a/tools/perf/perf_tools/memory_benchmark.py b/tools/perf/perf_tools/memory_benchmark.py
new file mode 100644
index 0000000000000000000000000000000000000000..93f04a14346c3cd5f649645732adf87fe6c67f2b
--- /dev/null
+++ b/tools/perf/perf_tools/memory_benchmark.py
@@ -0,0 +1,49 @@
+# Copyright (c) 2012 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+import copy
+
+from chrome_remote_control import interaction
+from chrome_remote_control import multi_page_benchmark
+from chrome_remote_control import test_helper_interaction #pylint: disable=W0611
+
+MEMORY_HISTOGRAMS = [
+ {'name': 'V8.MemoryExternalFragmentationTotal', 'units': 'percent'},
+ {'name': 'V8.MemoryHeapSampleTotalCommitted', 'units': 'kb'},
+ {'name': 'V8.MemoryHeapSampleTotalUsed', 'units': 'kb'}]
+
+class MemoryBenchmark(multi_page_benchmark.MultiPageBenchmark):
+ def __init__(self):
+ super(MemoryBenchmark, self).__init__()
+ self._interactions = []
+ self._results = {}
+
+ @staticmethod
+ def GetMemoryHistograms(tab, results):
+ for histogram in MEMORY_HISTOGRAMS:
+ name = histogram['name']
+ data = tab.runtime.Evaluate(
+ 'window.domAutomationController.getHistogram("%s")' % name)
+ results.Add(name, histogram['units'], data, data_type='histogram')
+
+ def CustomizeBrowserOptions(self, options):
+ options.extra_browser_args.append('--dom-automation')
nduca 2012/11/08 22:05:45 is this flag considered to be long-term supported?
marja 2012/11/09 14:17:35 The --dom-automation command line switch is ultima
+
+ def DoNextInteraction(self, page, tab):
nduca 2012/11/06 05:10:02 I'd like to see interactions be part of the multi_
marja 2012/11/09 14:17:35 Now that we have compound interactions, running th
+ if not self._interactions:
+ return False
+ data = self._interactions[0]
+ self._interactions = self._interactions[1:]
+ i = interaction.FindClassWithName('TestHelper')(data)
+ i.PerformInteraction(page, tab, self)
+ return True
+
+ def DidPerformInteraction(self, _, page, tab):
+ if not self.DoNextInteraction(page, tab):
+ self.GetMemoryHistograms(tab, self._results)
+
+ def MeasurePage(self, page, tab, results):
+ self._interactions = copy.copy(page.interactions)
+ self._results = results
+ tab.WaitForDocumentReadyStateToBeComplete()
+ self.DoNextInteraction(page, tab)
« no previous file with comments | « no previous file | tools/perf/perf_tools/multipage_benchmark_runner.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698