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

Unified Diff: tools/perf/measurements/v8_detached_context_age_in_gc_unittest.py

Issue 930333002: [telemetry] Add new measurement that counts number of GCs needed to free V8 context. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address comments from Ross Created 5 years, 10 months 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 | « tools/perf/measurements/v8_detached_context_age_in_gc.py ('k') | tools/perf/page_sets/page_reload_cases.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/perf/measurements/v8_detached_context_age_in_gc_unittest.py
diff --git a/tools/perf/measurements/v8_detached_context_age_in_gc_unittest.py b/tools/perf/measurements/v8_detached_context_age_in_gc_unittest.py
new file mode 100644
index 0000000000000000000000000000000000000000..1364d61f3511ea16ba1ed455b40cdfcfe2e987fd
--- /dev/null
+++ b/tools/perf/measurements/v8_detached_context_age_in_gc_unittest.py
@@ -0,0 +1,77 @@
+# Copyright 2015 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.
+
+from measurements import v8_detached_context_age_in_gc
+from telemetry.core import wpr_modes
+from telemetry.page import page_test
+from telemetry.results import page_test_results
+from telemetry.unittest_util import options_for_unittests
+from telemetry.unittest_util import page_test_test_case
+from telemetry.value import skip
+
+
+class FakePage(object):
+ def __init__(self, url):
+ self.url = url
+ self.is_file = url.startswith('file://')
+
+
+class FakeTab(object):
+ def __init__(self, histograms):
+ self.histograms = histograms
+ self.current_histogram_index = 0
+
+ def EvaluateJavaScript(self, script):
+ if 'V8.DetachedContextAgeInGC' in script:
+ self.current_histogram_index += 1
+ return self.histograms[self.current_histogram_index - 1]
+ return "{}"
Sami 2015/02/18 15:30:26 nit: single quotes
ulan 2015/02/18 15:58:41 Done.
+
+ def CollectGarbage(self):
+ pass
+
+
+def _MeasureFakePage(histograms):
+ results = page_test_results.PageTestResults()
+ page = FakePage("file://blank.html")
Sami 2015/02/18 15:30:26 ditto
ulan 2015/02/18 15:58:41 Done.
+ tab = FakeTab(histograms)
+ metric = v8_detached_context_age_in_gc.V8DetachedContextAgeInGC()
+ results.WillRunPage(page)
+ metric.DidNavigateToPage(page, tab)
+ metric.ValidateAndMeasurePage(page, tab, results)
+ results.DidRunPage(page)
+ return results
+
+
+def _ActualValues(results):
+ return dict(list((v.name, v)) for v in results.all_page_specific_values)
Sami 2015/02/18 15:30:27 nit: "list()" is redundant
ulan 2015/02/18 15:58:41 Done.
+
+
+class V8DetachedContextAgeInGCTests(page_test_test_case.PageTestTestCase):
+
+ def setUp(self):
+ self._options = options_for_unittests.GetCopy()
+ self._options.browser_options.wpr_mode = wpr_modes.WPR_OFF
+
+ def testWithNoData(self):
+ histograms = [
+ """{"count": 0, "buckets": []}""",
+ """{"count": 0, "buckets": []}"""
+ ]
+ results = _MeasureFakePage(histograms)
+ actual = _ActualValues(results)
+ self.assertTrue('skip' in actual)
+ self.assertFalse('V8_DetachedContextAgeInGC' in actual)
+
+ def testWithData(self):
Sami 2015/02/18 15:30:26 Could we write this test in a way that uses the re
ulan 2015/02/18 15:58:41 Do you mean: create a real html page, let the brow
Sami 2015/02/18 16:20:56 Breaking a unit test instead triggering a perf reg
+ histograms = [
+ """{"count": 3, "buckets": [{"low": 1, "high": 2, "count": 1},
+ {"low": 2, "high": 3, "count": 2}]}""",
+ """{"count": 4, "buckets": [{"low": 1, "high": 2, "count": 2},
+ {"low": 2, "high": 3, "count": 2}]}""",
+ ]
+ results = _MeasureFakePage(histograms)
+ actual = _ActualValues(results)['V8_DetachedContextAgeInGC']
+ self.assertEqual(2, actual.value)
+ self.assertEqual('garbage_collections', actual.units)
« no previous file with comments | « tools/perf/measurements/v8_detached_context_age_in_gc.py ('k') | tools/perf/page_sets/page_reload_cases.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698