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

Unified Diff: tools/perf/benchmarks/blink_perf_unittest.py

Issue 2819343002: Support tracing metrics for measureTime & measureFrameTime method in blink_perf (Closed)
Patch Set: Disable testBlinkPerfTracingMetricsForMeasureTime on Android Created 3 years, 8 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/benchmarks/blink_perf.py ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/perf/benchmarks/blink_perf_unittest.py
diff --git a/tools/perf/benchmarks/blink_perf_unittest.py b/tools/perf/benchmarks/blink_perf_unittest.py
new file mode 100644
index 0000000000000000000000000000000000000000..cff0eeb110c57c3cbfcfb211f01fd003a4960043
--- /dev/null
+++ b/tools/perf/benchmarks/blink_perf_unittest.py
@@ -0,0 +1,156 @@
+# Copyright 2017 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 os
+import unittest
+
+from telemetry import decorators
+from telemetry import story
+from telemetry.page import page as page_module
+from telemetry.testing import options_for_unittests
+from telemetry.testing import page_test_test_case
+from telemetry.timeline import async_slice
+from telemetry.timeline import model as model_module
+
+
+from benchmarks import blink_perf
+
+
+class BlinkPerfTest(page_test_test_case.PageTestTestCase):
+ _BLINK_PERF_TEST_DATA_DIR = os.path.join(os.path.dirname(__file__),
+ '..', '..', '..', 'third_party', 'WebKit', 'PerformanceTests',
+ 'TestData')
+
+ _BLINK_PERF_RESOURCES_DIR = os.path.join(os.path.dirname(__file__),
+ '..', '..', '..', 'third_party', 'WebKit', 'PerformanceTests',
+ 'resources')
+ def setUp(self):
+ self._options = options_for_unittests.GetCopy()
+ # pylint: disable=protected-access
+ self._measurement = blink_perf._BlinkPerfMeasurement()
+ # pylint: enable=protected-access
+
+ def _CreateStorySetForTestFile(self, test_file_name):
+ story_set = story.StorySet(base_dir=self._BLINK_PERF_TEST_DATA_DIR,
+ serving_dirs={self._BLINK_PERF_TEST_DATA_DIR,
+ self._BLINK_PERF_RESOURCES_DIR})
+ page = page_module.Page('file://' + test_file_name, story_set,
+ base_dir=story_set.base_dir)
+ story_set.AddStory(page)
+ return story_set
+
+ def testBlinkPerfTracingMetricsForMeasureTime(self):
+ results = self.RunMeasurement(measurement=self._measurement,
+ ps=self._CreateStorySetForTestFile('append-child-measure-time.html'),
+ options=self._options)
+ self.assertFalse(results.failures)
+ self.assertEquals(len(results.FindAllTraceValues()), 1)
+
+ frame_view_layouts = results.FindAllPageSpecificValuesNamed(
+ 'FrameView::layout')
+ self.assertEquals(len(frame_view_layouts), 1)
+ self.assertGreater(frame_view_layouts[0].GetRepresentativeNumber, 0.1)
+
+ update_layout_trees = results.FindAllPageSpecificValuesNamed(
+ 'UpdateLayoutTree')
+ self.assertEquals(len(update_layout_trees), 1)
+ self.assertGreater(update_layout_trees[0].GetRepresentativeNumber, 0.1)
+
+ @decorators.Disabled('android') # crbug.com/715685
+ def testBlinkPerfTracingMetricsForMeasureFrameTime(self):
+ results = self.RunMeasurement(measurement=self._measurement,
+ ps=self._CreateStorySetForTestFile(
+ 'color-changes-measure-frame-time.html'),
+ options=self._options)
+ self.assertFalse(results.failures)
+ self.assertEquals(len(results.FindAllTraceValues()), 1)
+
+ frame_view_prepaints = results.FindAllPageSpecificValuesNamed(
+ 'FrameView::prePaint')
+ self.assertEquals(len(frame_view_prepaints), 1)
+ self.assertGreater(frame_view_prepaints[0].GetRepresentativeNumber, 0.1)
+
+ frame_view_painttrees = results.FindAllPageSpecificValuesNamed(
+ 'FrameView::paintTree')
+ self.assertEquals(len(frame_view_painttrees), 1)
+ self.assertGreater(frame_view_painttrees[0].GetRepresentativeNumber, 0.1)
+
+
+# pylint: disable=protected-access
+# This is needed for testing _ComputeTraceEventsThreadTimeForBlinkPerf method.
+class ComputeTraceEventsMetricsForBlinkPerfTest(unittest.TestCase):
+
+ def _AddBlinkTestSlice(self, renderer_thread, start, end):
+ s = async_slice.AsyncSlice(
+ 'blink', 'blink_perf.runTest',
+ timestamp=start, duration=end - start, start_thread=renderer_thread,
+ end_thread=renderer_thread)
+ renderer_thread.AddAsyncSlice(s)
+
+ def testTraceEventMetricsSingleBlinkTest(self):
+ model = model_module.TimelineModel()
+ renderer_main = model.GetOrCreateProcess(1).GetOrCreateThread(2)
+ renderer_main.name = 'CrRendererMain'
+
+ # Set up a main thread model that looks like:
+ # [ blink_perf.run_test ]
+ # | [ foo ] [ bar ] [ baz ]
+ # | | | | | | | |
+ # 100 120 140 400 420 500 550 600
+ # | | |
+ # CPU dur: 15 18 70
+ #
+ self._AddBlinkTestSlice(renderer_main, 100, 550)
+
+ renderer_main.BeginSlice('blink', 'foo', 120, 122)
+ renderer_main.EndSlice(140, 137)
+
+ renderer_main.BeginSlice('blink', 'bar', 400, 402)
+ renderer_main.EndSlice(420, 420)
+
+ # Since this "baz" slice has CPU duration = 70ms, wall-time duration = 100ms
+ # & its overalapped wall-time with "blink_perf.run_test" is 50 ms, its
+ # overlapped CPU time with "blink_perf.run_test" is
+ # 50 * 70 / 100 = 35ms.
+ renderer_main.BeginSlice('blink', 'baz', 500, 520)
+ renderer_main.EndSlice(600, 590)
+
+ self.assertEquals(
+ blink_perf._ComputeTraceEventsThreadTimeForBlinkPerf(
+ renderer_main, ['foo', 'bar', 'baz']),
+ {'foo': [15], 'bar': [18], 'baz': [35]})
+
+
+ def testTraceEventMetricsMultiBlinkTest(self):
+ model = model_module.TimelineModel()
+ renderer_main = model.GetOrCreateProcess(1).GetOrCreateThread(2)
+ renderer_main.name = 'CrRendererMain'
+
+ # Set up a main thread model that looks like:
+ # [ blink_perf.run_test ] [ blink_perf.run_test ]
+ # | [ foo ] [ bar ] | [ | foo ] |
+ # | | | | | | | | | | |
+ # 100 120 140 400 420 440 500 520 600 640
+ # | | |
+ # CPU dur: 15 18 40
+ #
+ self._AddBlinkTestSlice(renderer_main, 100, 440)
+ self._AddBlinkTestSlice(renderer_main, 520, 640)
+
+ renderer_main.BeginSlice('blink', 'foo', 120, 122)
+ renderer_main.EndSlice(140, 137)
+
+ renderer_main.BeginSlice('blink', 'bar', 400, 402)
+ renderer_main.EndSlice(420, 420)
+
+ # Since this "foo" slice has CPU duration = 40ms, wall-time duration = 100ms
+ # & its overalapped wall-time with "blink_perf.run_test" is 80 ms, its
+ # overlapped CPU time with "blink_perf.run_test" is
+ # 80 * 40 / 100 = 32ms.
+ renderer_main.BeginSlice('blink', 'foo', 500, 520)
+ renderer_main.EndSlice(600, 560)
+
+ self.assertEquals(
+ blink_perf._ComputeTraceEventsThreadTimeForBlinkPerf(
+ renderer_main, ['foo', 'bar', 'baz']),
+ {'foo': [15, 32], 'bar': [18, 0], 'baz': [0, 0]})
« no previous file with comments | « tools/perf/benchmarks/blink_perf.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698