ozone: evdev: Sync caps lock LED state to evdev
[chromium-blink-merge.git] / tools / perf / page_sets / tough_scheduling_cases.py
blob00fcb6eef492d92c42fd8f4ce2afb8502e7a42e0
1 # Copyright 2014 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 from telemetry.page import page as page_module
5 from telemetry.page import page_set as page_set_module
8 class ToughSchedulingCasesPage(page_module.Page):
10 def __init__(self, url, page_set):
11 super(ToughSchedulingCasesPage, self).__init__(
12 url=url, page_set=page_set, credentials_path='data/credentials.json')
13 self.user_agent_type = 'mobile'
14 self.archive_data_file = 'data/tough_scheduling_cases.json'
16 def RunPageInteractions(self, action_runner):
17 interaction = action_runner.BeginGestureInteraction(
18 'ScrollAction', is_smooth=True)
19 action_runner.ScrollPage()
20 interaction.End()
23 class Page1(ToughSchedulingCasesPage):
25 """Why: Simulate oversubscribed main thread."""
27 def __init__(self, page_set):
28 super(Page1, self).__init__(
29 url='file://tough_scheduling_cases/simple_text_page.html?main_busy',
30 page_set=page_set)
32 self.synthetic_delays = {'cc.BeginMainFrame': {'target_duration': 0.008}}
35 class Page2(ToughSchedulingCasesPage):
37 """Why: Simulate oversubscribed main thread."""
39 def __init__(self, page_set):
40 super(Page2, self).__init__(
41 # pylint: disable=C0301
42 url='file://tough_scheduling_cases/simple_text_page.html?main_very_busy',
43 page_set=page_set)
45 self.synthetic_delays = {'cc.BeginMainFrame': {'target_duration': 0.024}}
48 class Page3(ToughSchedulingCasesPage):
50 """Why: Simulate a page with a a few graphics layers."""
52 def __init__(self, page_set):
53 super(Page3, self).__init__(
54 # pylint: disable=C0301
55 url='file://tough_scheduling_cases/simple_text_page.html?medium_layers',
56 page_set=page_set)
58 self.synthetic_delays = {
59 'cc.DrawAndSwap': {'target_duration': 0.004},
60 'gpu.PresentingFrame': {'target_duration': 0.004},
61 'cc.BeginMainFrame': {'target_duration': 0.004}
65 class Page4(ToughSchedulingCasesPage):
67 """Why: Simulate a page with many graphics layers."""
69 def __init__(self, page_set):
70 super(Page4, self).__init__(
71 # pylint: disable=C0301
72 url='file://tough_scheduling_cases/simple_text_page.html?many_layers',
73 page_set=page_set)
75 self.synthetic_delays = {
76 'cc.DrawAndSwap': {'target_duration': 0.012},
77 'gpu.PresentingFrame': {'target_duration': 0.012},
78 'cc.BeginMainFrame': {'target_duration': 0.012}
82 class Page5(ToughSchedulingCasesPage):
84 """Why: Simulate a page with expensive recording and rasterization."""
86 def __init__(self, page_set):
87 super(Page5, self).__init__(
88 # pylint: disable=C0301
89 url='file://tough_scheduling_cases/simple_text_page.html?medium_raster',
90 page_set=page_set)
92 self.synthetic_delays = {
93 'cc.RasterRequiredForActivation': {'target_duration': 0.004},
94 'cc.BeginMainFrame': {'target_duration': 0.004},
95 'gpu.AsyncTexImage': {'target_duration': 0.004}
99 class Page6(ToughSchedulingCasesPage):
101 """Why: Simulate a page with expensive recording and rasterization."""
103 def __init__(self, page_set):
104 super(Page6, self).__init__(
105 # pylint: disable=C0301
106 url='file://tough_scheduling_cases/simple_text_page.html?heavy_raster',
107 page_set=page_set)
109 self.synthetic_delays = {
110 'cc.RasterRequiredForActivation': {'target_duration': 0.024},
111 'cc.BeginMainFrame': {'target_duration': 0.024},
112 'gpu.AsyncTexImage': {'target_duration': 0.024}
116 class Page7(ToughSchedulingCasesPage):
118 """Why: Medium cost touch handler."""
120 def __init__(self, page_set):
121 super(Page7, self).__init__(
122 # pylint: disable=C0301
123 url='file://tough_scheduling_cases/touch_handler_scrolling.html?medium_handler',
124 page_set=page_set)
126 self.synthetic_delays = {'blink.HandleInputEvent':
127 {'target_duration': 0.008}}
130 class Page8(ToughSchedulingCasesPage):
132 """Why: Slow touch handler."""
134 def __init__(self, page_set):
135 super(Page8, self).__init__(
136 # pylint: disable=C0301
137 url='file://tough_scheduling_cases/touch_handler_scrolling.html?slow_handler',
138 page_set=page_set)
140 self.synthetic_delays = {'blink.HandleInputEvent':
141 {'target_duration': 0.024}}
144 class Page9(ToughSchedulingCasesPage):
146 """Why: Touch handler that often takes a long time."""
148 def __init__(self, page_set):
149 super(Page9, self).__init__(
150 # pylint: disable=C0301
151 url='file://tough_scheduling_cases/touch_handler_scrolling.html?janky_handler',
152 page_set=page_set)
154 self.synthetic_delays = {'blink.HandleInputEvent':
155 {'target_duration': 0.024, 'mode': 'alternating'}
159 class Page10(ToughSchedulingCasesPage):
161 """Why: Touch handler that occasionally takes a long time."""
163 def __init__(self, page_set):
164 super(Page10, self).__init__(
165 # pylint: disable=C0301
166 url='file://tough_scheduling_cases/touch_handler_scrolling.html?occasionally_janky_handler',
167 page_set=page_set)
169 self.synthetic_delays = {'blink.HandleInputEvent':
170 {'target_duration': 0.024, 'mode': 'oneshot'}}
173 class Page11(ToughSchedulingCasesPage):
175 """Why: Super expensive touch handler causes browser to scroll after a
176 timeout."""
178 def __init__(self, page_set):
179 super(Page11, self).__init__(
180 # pylint: disable=C0301
181 url='file://tough_scheduling_cases/touch_handler_scrolling.html?super_slow_handler',
182 page_set=page_set)
184 self.synthetic_delays = {'blink.HandleInputEvent':
185 {'target_duration': 0.2}}
188 class Page12(ToughSchedulingCasesPage):
190 """Why: Super expensive touch handler that only occupies a part of the page.
193 def __init__(self, page_set):
194 super(Page12, self).__init__(
195 url='file://tough_scheduling_cases/div_touch_handler.html',
196 page_set=page_set)
198 self.synthetic_delays = {'blink.HandleInputEvent': {'target_duration': 0.2}}
201 class Page13(ToughSchedulingCasesPage):
203 """Why: Test a moderately heavy requestAnimationFrame handler."""
205 def __init__(self, page_set):
206 super(Page13, self).__init__(
207 url='file://tough_scheduling_cases/raf.html?medium_handler',
208 page_set=page_set)
210 self.synthetic_delays = {
211 'cc.RasterRequiredForActivation': {'target_duration': 0.004},
212 'cc.BeginMainFrame': {'target_duration': 0.004},
213 'gpu.AsyncTexImage': {'target_duration': 0.004}
217 class Page14(ToughSchedulingCasesPage):
219 """Why: Test a moderately heavy requestAnimationFrame handler."""
221 def __init__(self, page_set):
222 super(Page14, self).__init__(
223 url='file://tough_scheduling_cases/raf.html?heavy_handler',
224 page_set=page_set)
226 self.synthetic_delays = {
227 'cc.RasterRequiredForActivation': {'target_duration': 0.024},
228 'cc.BeginMainFrame': {'target_duration': 0.024},
229 'gpu.AsyncTexImage': {'target_duration': 0.024}
233 class Page15(ToughSchedulingCasesPage):
235 """Why: Simulate a heavily GPU bound page."""
237 def __init__(self, page_set):
238 super(Page15, self).__init__(
239 url='file://tough_scheduling_cases/raf.html?gpu_bound',
240 page_set=page_set)
242 self.synthetic_delays = {'gpu.PresentingFrame': {'target_duration': 0.1}}
245 class Page16(ToughSchedulingCasesPage):
247 """Why: Test a requestAnimationFrame handler with a heavy first frame."""
249 def __init__(self, page_set):
250 super(Page16, self).__init__(
251 url='file://tough_scheduling_cases/raf.html?heavy_first_frame',
252 page_set=page_set)
254 self.synthetic_delays = {'cc.BeginMainFrame': {'target_duration': 0.15,
255 'mode': 'oneshot'}}
258 class Page17(ToughSchedulingCasesPage):
260 """Why: Medium stress test for the scheduler."""
262 def __init__(self, page_set):
263 super(Page17, self).__init__(
264 url='file://tough_scheduling_cases/raf_touch_animation.html?medium',
265 page_set=page_set)
267 self.synthetic_delays = {
268 'cc.DrawAndSwap': {'target_duration': 0.004},
269 'cc.BeginMainFrame': {'target_duration': 0.004}
273 class Page18(ToughSchedulingCasesPage):
275 """Why: Heavy stress test for the scheduler."""
277 def __init__(self, page_set):
278 super(Page18, self).__init__(
279 url='file://tough_scheduling_cases/raf_touch_animation.html?heavy',
280 page_set=page_set)
282 self.synthetic_delays = {
283 'cc.DrawAndSwap': {'target_duration': 0.012},
284 'cc.BeginMainFrame': {'target_duration': 0.012}
288 class Page19(ToughSchedulingCasesPage):
290 """Why: Both main and impl thread animating concurrently."""
292 def __init__(self, page_set):
293 super(Page19, self).__init__(
294 url='file://tough_scheduling_cases/split_animation.html',
295 page_set=page_set)
297 def RunPageInteractions(self, action_runner):
298 action_runner.Wait(3)
301 class Page20(ToughSchedulingCasesPage):
303 """Why: Simple JS touch dragging."""
305 def __init__(self, page_set):
306 super(Page20, self).__init__(
307 url='file://tough_scheduling_cases/simple_touch_drag.html',
308 page_set=page_set)
310 def RunPageInteractions(self, action_runner):
311 interaction = action_runner.BeginGestureInteraction(
312 'ScrollAction', is_smooth=True)
313 action_runner.ScrollElement(
314 selector='#card',
315 use_touch=True,
316 direction='up',
317 speed_in_pixels_per_second=150,
318 distance=400)
319 interaction.End()
322 class EmptyTouchHandlerPage(ToughSchedulingCasesPage):
324 """Why: Scrolling on a page with a touch handler that consumes no events but
325 may be slow."""
327 def __init__(self, name, desktop, slow_handler, bounce, page_set):
328 super(EmptyTouchHandlerPage, self).__init__(
329 url='file://tough_scheduling_cases/empty_touch_handler' +
330 ('_desktop' if desktop else '') + '.html?' + name,
331 page_set=page_set)
333 if slow_handler:
334 self.synthetic_delays = {
335 'blink.HandleInputEvent': {'target_duration': 0.2}
338 self.bounce = bounce
340 def RunPageInteractions(self, action_runner):
341 if self.bounce:
342 interaction = action_runner.BeginGestureInteraction(
343 'ScrollBounceAction', is_smooth=True)
344 action_runner.ScrollBouncePage()
345 interaction.End()
346 else:
347 interaction = action_runner.BeginGestureInteraction(
348 'ScrollAction', is_smooth=True)
349 # Speed and distance are tuned to run exactly as long as a scroll
350 # bounce.
351 action_runner.ScrollPage(use_touch=True, speed_in_pixels_per_second=400,
352 distance=2100)
353 interaction.End()
356 class SynchronizedScrollOffsetPage(ToughSchedulingCasesPage):
358 """Why: For measuring the latency of scroll-synchronized effects."""
360 def __init__(self, page_set):
361 super(SynchronizedScrollOffsetPage, self).__init__(
362 url='file://tough_scheduling_cases/sync_scroll_offset.html',
363 page_set=page_set)
365 def RunPageInteractions(self, action_runner):
366 interaction = action_runner.BeginGestureInteraction(
367 'ScrollBounceAction', is_smooth=True)
368 action_runner.ScrollBouncePage()
369 interaction.End()
372 class ToughSchedulingCasesPageSet(page_set_module.PageSet):
374 """Tough scheduler latency test cases."""
376 def __init__(self):
377 super(ToughSchedulingCasesPageSet, self).__init__(
378 user_agent_type='mobile',
379 archive_data_file='data/tough_scheduling_cases.json',
380 bucket=page_set_module.INTERNAL_BUCKET)
382 # Why: Simple scrolling baseline
383 self.AddUserStory(ToughSchedulingCasesPage(
384 'file://tough_scheduling_cases/simple_text_page.html',
385 self))
386 self.AddUserStory(Page1(self))
387 self.AddUserStory(Page2(self))
388 self.AddUserStory(Page3(self))
389 self.AddUserStory(Page4(self))
390 # Disabled until crbug.com/413829 is fixed.
391 # self.AddUserStory(Page5(self))
392 # Disabled because of crbug.com/413829 and flakiness crbug.com/368532
393 # self.AddUserStory(Page6(self))
394 # Why: Touch handler scrolling baseline
395 self.AddUserStory(ToughSchedulingCasesPage(
396 'file://tough_scheduling_cases/touch_handler_scrolling.html',
397 self))
398 self.AddUserStory(Page7(self))
399 self.AddUserStory(Page8(self))
400 self.AddUserStory(Page9(self))
401 self.AddUserStory(Page10(self))
402 self.AddUserStory(Page11(self))
403 self.AddUserStory(Page12(self))
404 # Why: requestAnimationFrame scrolling baseline
405 self.AddUserStory(ToughSchedulingCasesPage(
406 'file://tough_scheduling_cases/raf.html',
407 self))
408 # Why: Test canvas blocking behavior
409 self.AddUserStory(ToughSchedulingCasesPage(
410 'file://tough_scheduling_cases/raf_canvas.html',
411 self))
412 # Disabled until crbug.com/413829 is fixed.
413 # self.AddUserStory(Page13(self))
414 # Disabled because of crbug.com/413829 and flakiness crbug.com/368532
415 # self.AddUserStory(Page14(self))
416 self.AddUserStory(Page15(self))
417 self.AddUserStory(Page16(self))
418 # Why: Test a requestAnimationFrame handler with concurrent CSS animation
419 self.AddUserStory(ToughSchedulingCasesPage(
420 'file://tough_scheduling_cases/raf_animation.html',
421 self))
422 # Why: Stress test for the scheduler
423 self.AddUserStory(ToughSchedulingCasesPage(
424 'file://tough_scheduling_cases/raf_touch_animation.html',
425 self))
426 self.AddUserStory(Page17(self))
427 self.AddUserStory(Page18(self))
428 self.AddUserStory(Page19(self))
429 self.AddUserStory(Page20(self))
430 # Why: Baseline for scrolling in the presence of a no-op touch handler
431 self.AddUserStory(EmptyTouchHandlerPage(
432 name='baseline',
433 desktop=False,
434 slow_handler=False,
435 bounce=False,
436 page_set=self))
437 # Why: Slow handler blocks scroll start
438 self.AddUserStory(EmptyTouchHandlerPage(
439 name='slow_handler',
440 desktop=False,
441 slow_handler=True,
442 bounce=False,
443 page_set=self))
444 # Why: Slow handler blocks scroll start until touch ACK timeout
445 self.AddUserStory(EmptyTouchHandlerPage(
446 name='desktop_slow_handler',
447 desktop=True,
448 slow_handler=True,
449 bounce=False,
450 page_set=self))
451 # Why: Scroll bounce showing repeated transitions between scrolling and
452 # sending synchronous touchmove events. Should be nearly as fast as
453 # scroll baseline.
454 self.AddUserStory(EmptyTouchHandlerPage(
455 name='bounce',
456 desktop=False,
457 slow_handler=False,
458 bounce=True,
459 page_set=self))
460 # Why: Scroll bounce with slow handler, repeated blocking.
461 self.AddUserStory(EmptyTouchHandlerPage(
462 name='bounce_slow_handler',
463 desktop=False,
464 slow_handler=True,
465 bounce=True,
466 page_set=self))
467 # Why: Scroll bounce with slow handler on desktop, blocks only once until
468 # ACK timeout.
469 self.AddUserStory(EmptyTouchHandlerPage(
470 name='bounce_desktop_slow_handler',
471 desktop=True,
472 slow_handler=True,
473 bounce=True,
474 page_set=self))
475 # Why: For measuring the latency of scroll-synchronized effects.
476 self.AddUserStory(SynchronizedScrollOffsetPage(page_set=self))