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

Side by Side Diff: tools/perf/benchmarks/blink_perf_unittest.py

Issue 2844133002: Support tracing metrics for measureTime & measureFrameTime methods in blink_perf (Reland) (Closed)
Patch Set: Fix thread times & disable tests on Win Created 3 years, 7 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 unified diff | Download patch
« no previous file with comments | « tools/perf/benchmarks/blink_perf.py ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 # Copyright 2017 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
4 import os
5 import unittest
6
7 from telemetry import decorators
8 from telemetry import story
9 from telemetry.page import page as page_module
10 from telemetry.testing import options_for_unittests
11 from telemetry.testing import page_test_test_case
12 from telemetry.timeline import async_slice
13 from telemetry.timeline import model as model_module
14
15
16 from benchmarks import blink_perf
17
18
19 class BlinkPerfTest(page_test_test_case.PageTestTestCase):
20 _BLINK_PERF_TEST_DATA_DIR = os.path.join(os.path.dirname(__file__),
21 '..', '..', '..', 'third_party', 'WebKit', 'PerformanceTests',
22 'TestData')
23
24 _BLINK_PERF_RESOURCES_DIR = os.path.join(os.path.dirname(__file__),
25 '..', '..', '..', 'third_party', 'WebKit', 'PerformanceTests',
26 'resources')
27 def setUp(self):
28 self._options = options_for_unittests.GetCopy()
29 # pylint: disable=protected-access
30 self._measurement = blink_perf._BlinkPerfMeasurement()
31 # pylint: enable=protected-access
32
33 def _CreateStorySetForTestFile(self, test_file_name):
34 story_set = story.StorySet(base_dir=self._BLINK_PERF_TEST_DATA_DIR,
35 serving_dirs={self._BLINK_PERF_TEST_DATA_DIR,
36 self._BLINK_PERF_RESOURCES_DIR})
37 page = page_module.Page('file://' + test_file_name, story_set,
38 base_dir=story_set.base_dir)
39 story_set.AddStory(page)
40 return story_set
41
42 @decorators.Disabled('win') # crbug.com/715822
43 def testBlinkPerfTracingMetricsForMeasureTime(self):
44 results = self.RunMeasurement(measurement=self._measurement,
45 ps=self._CreateStorySetForTestFile('append-child-measure-time.html'),
46 options=self._options)
47 self.assertFalse(results.failures)
48 self.assertEquals(len(results.FindAllTraceValues()), 1)
49
50 frame_view_layouts = results.FindAllPageSpecificValuesNamed(
51 'FrameView::layout')
52 self.assertEquals(len(frame_view_layouts), 1)
53 self.assertGreater(frame_view_layouts[0].GetRepresentativeNumber, 0.1)
54
55 update_layout_trees = results.FindAllPageSpecificValuesNamed(
56 'UpdateLayoutTree')
57 self.assertEquals(len(update_layout_trees), 1)
58 self.assertGreater(update_layout_trees[0].GetRepresentativeNumber, 0.1)
59
60 @decorators.Disabled('android') # crbug.com/715685
61 def testBlinkPerfTracingMetricsForMeasureFrameTime(self):
62 results = self.RunMeasurement(measurement=self._measurement,
63 ps=self._CreateStorySetForTestFile(
64 'color-changes-measure-frame-time.html'),
65 options=self._options)
66 self.assertFalse(results.failures)
67 self.assertEquals(len(results.FindAllTraceValues()), 1)
68
69 frame_view_prepaints = results.FindAllPageSpecificValuesNamed(
70 'FrameView::prePaint')
71 self.assertEquals(len(frame_view_prepaints), 1)
72 self.assertGreater(frame_view_prepaints[0].GetRepresentativeNumber, 0.1)
73
74 frame_view_painttrees = results.FindAllPageSpecificValuesNamed(
75 'FrameView::paintTree')
76 self.assertEquals(len(frame_view_painttrees), 1)
77 self.assertGreater(frame_view_painttrees[0].GetRepresentativeNumber, 0.1)
78
79
80 # pylint: disable=protected-access
81 # This is needed for testing _ComputeTraceEventsThreadTimeForBlinkPerf method.
82 class ComputeTraceEventsMetricsForBlinkPerfTest(unittest.TestCase):
83
84 def _AddBlinkTestSlice(self, renderer_thread, start, end):
85 s = async_slice.AsyncSlice(
86 'blink', 'blink_perf.runTest',
87 timestamp=start, duration=end - start, start_thread=renderer_thread,
88 end_thread=renderer_thread)
89 renderer_thread.AddAsyncSlice(s)
90
91 def testTraceEventMetricsSingleBlinkTest(self):
92 model = model_module.TimelineModel()
93 renderer_main = model.GetOrCreateProcess(1).GetOrCreateThread(2)
94 renderer_main.name = 'CrRendererMain'
95
96 # Set up a main thread model that looks like:
97 # [ blink_perf.run_test ]
98 # | [ foo ] [ bar ] [ baz ]
99 # | | | | | | | |
100 # 100 120 140 400 420 500 550 600
101 # | | |
102 # CPU dur: 15 18 70
103 #
104 self._AddBlinkTestSlice(renderer_main, 100, 550)
105
106 renderer_main.BeginSlice('blink', 'foo', 120, 122)
107 renderer_main.EndSlice(140, 137)
108
109 renderer_main.BeginSlice('blink', 'bar', 400, 402)
110 renderer_main.EndSlice(420, 420)
111
112 # Since this "baz" slice has CPU duration = 70ms, wall-time duration = 100ms
113 # & its overalapped wall-time with "blink_perf.run_test" is 50 ms, its
114 # overlapped CPU time with "blink_perf.run_test" is
115 # 50 * 70 / 100 = 35ms.
116 renderer_main.BeginSlice('blink', 'baz', 500, 520)
117 renderer_main.EndSlice(600, 590)
118
119 self.assertEquals(
120 blink_perf._ComputeTraceEventsThreadTimeForBlinkPerf(
121 renderer_main, ['foo', 'bar', 'baz']),
122 {'foo': [15], 'bar': [18], 'baz': [35]})
123
124
125 def testTraceEventMetricsMultiBlinkTest(self):
126 model = model_module.TimelineModel()
127 renderer_main = model.GetOrCreateProcess(1).GetOrCreateThread(2)
128 renderer_main.name = 'CrRendererMain'
129
130 # Set up a main thread model that looks like:
131 # [ blink_perf.run_test ] [ blink_perf.run_test ]
132 # | [ foo ] [ bar ] | [ | foo ] |
133 # | | | | | | | | | | |
134 # 100 120 140 400 420 440 500 520 600 640
135 # | | |
136 # CPU dur: 15 18 40
137 #
138 self._AddBlinkTestSlice(renderer_main, 100, 440)
139 self._AddBlinkTestSlice(renderer_main, 520, 640)
140
141 renderer_main.BeginSlice('blink', 'foo', 120, 122)
142 renderer_main.EndSlice(140, 137)
143
144 renderer_main.BeginSlice('blink', 'bar', 400, 402)
145 renderer_main.EndSlice(420, 420)
146
147 # Since this "foo" slice has CPU duration = 40ms, wall-time duration = 100ms
148 # & its overalapped wall-time with "blink_perf.run_test" is 80 ms, its
149 # overlapped CPU time with "blink_perf.run_test" is
150 # 80 * 40 / 100 = 32ms.
151 renderer_main.BeginSlice('blink', 'foo', 500, 520)
152 renderer_main.EndSlice(600, 560)
153
154 self.assertEquals(
155 blink_perf._ComputeTraceEventsThreadTimeForBlinkPerf(
156 renderer_main, ['foo', 'bar', 'baz']),
157 {'foo': [15, 32], 'bar': [18, 0], 'baz': [0, 0]})
158
159 def testTraceEventMetricsNoThreadTimeAvailable(self):
160 model = model_module.TimelineModel()
161 renderer_main = model.GetOrCreateProcess(1).GetOrCreateThread(2)
162 renderer_main.name = 'CrRendererMain'
163
164 # Set up a main thread model that looks like:
165 # [ blink_perf.run_test ]
166 # | [ foo ] [ bar ] |
167 # | | | | | |
168 # 100 120 140 400 420 550
169 # | |
170 # CPU dur: None None
171 #
172 self._AddBlinkTestSlice(renderer_main, 100, 550)
173
174 renderer_main.BeginSlice('blink', 'foo', 120)
175 renderer_main.EndSlice(140)
176
177 renderer_main.BeginSlice('blink', 'bar', 400)
178 renderer_main.EndSlice(420)
179
180 self.assertEquals(
181 blink_perf._ComputeTraceEventsThreadTimeForBlinkPerf(
182 renderer_main, ['foo', 'bar']),
183 {'foo': [20], 'bar': [20]})
OLDNEW
« 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