Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 # Copyright 2014 The Chromium Authors. All rights reserved. | 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 | 2 # Use of this source code is governed by a BSD-style license that can be |
| 3 # found in the LICENSE file. | 3 # found in the LICENSE file. |
| 4 | 4 |
| 5 import re | |
| 6 | |
| 5 import page_sets | 7 import page_sets |
| 6 | 8 |
| 7 from core import perf_benchmark | 9 from core import perf_benchmark |
| 8 from telemetry import benchmark | 10 from telemetry import benchmark |
| 9 from telemetry.page import legacy_page_test | 11 from telemetry.page import legacy_page_test |
| 10 from telemetry.value import scalar | 12 from telemetry.value import scalar |
| 11 from telemetry.value import improvement_direction | 13 from telemetry.value import improvement_direction |
| 12 from telemetry.timeline import tracing_category_filter | 14 from telemetry.timeline import tracing_category_filter |
| 13 from telemetry.web_perf import timeline_based_measurement | 15 from telemetry.web_perf import timeline_based_measurement |
| 14 from telemetry.web_perf.metrics import v8_gc_latency | |
| 15 from telemetry.web_perf.metrics import smoothness | |
| 16 from telemetry.web_perf.metrics import memory_timeline | |
| 17 | 16 |
| 18 | 17 |
| 19 class _OortOnlineMeasurement(legacy_page_test.LegacyPageTest): | 18 class _OortOnlineMeasurement(legacy_page_test.LegacyPageTest): |
| 20 | 19 |
| 21 def __init__(self): | 20 def __init__(self): |
| 22 super(_OortOnlineMeasurement, self).__init__() | 21 super(_OortOnlineMeasurement, self).__init__() |
| 23 | 22 |
| 24 def ValidateAndMeasurePage(self, page, tab, results): | 23 def ValidateAndMeasurePage(self, page, tab, results): |
| 25 del page # unused | 24 del page # unused |
| 26 tab.WaitForJavaScriptExpression('window.benchmarkFinished', 1000) | 25 tab.WaitForJavaScriptExpression('window.benchmarkFinished', 1000) |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 46 return 'oortonline' | 45 return 'oortonline' |
| 47 | 46 |
| 48 def CreateStorySet(self, options): | 47 def CreateStorySet(self, options): |
| 49 return page_sets.OortOnlinePageSet() | 48 return page_sets.OortOnlinePageSet() |
| 50 | 49 |
| 51 | 50 |
| 52 # Disabled on reference builds because they don't support the new | 51 # Disabled on reference builds because they don't support the new |
| 53 # Tracing.requestMemoryDump DevTools API. See http://crbug.com/540022. | 52 # Tracing.requestMemoryDump DevTools API. See http://crbug.com/540022. |
| 54 @benchmark.Disabled('reference') | 53 @benchmark.Disabled('reference') |
| 55 @benchmark.Disabled('android') | 54 @benchmark.Disabled('android') |
| 56 class OortOnlineTBM(perf_benchmark.PerfBenchmark): | 55 class OortOnlineTBMv2(perf_benchmark.PerfBenchmark): |
| 57 """OortOnline benchmark that measures WebGL and V8 performance. | 56 """OortOnline benchmark that measures WebGL and V8 performance. |
| 58 URL: http://oortonline.gl/#run | 57 URL: http://oortonline.gl/#run |
| 59 Info: http://v8project.blogspot.de/2015/10/jank-busters-part-one.html | 58 Info: http://v8project.blogspot.de/2015/10/jank-busters-part-one.html |
| 60 """ | 59 """ |
| 61 | 60 |
| 61 # Report only V8-specific and overall renderer memory values. Note that | |
| 62 # detailed values reported by the OS (such as native heap) are excluded. | |
| 63 _V8_AND_OVERALL_MEMORY_RE = re.compile( | |
| 64 r'renderer_processes:' | |
| 65 r'(reported_by_chrome:v8|reported_by_os:system_memory:[^:]+$)') | |
| 66 | |
| 67 page_set = page_sets.OortOnlineTBMPageSet | |
| 68 | |
| 62 def SetExtraBrowserOptions(self, options): | 69 def SetExtraBrowserOptions(self, options): |
| 63 options.AppendExtraBrowserArgs([ | 70 options.AppendExtraBrowserArgs([ |
| 64 # TODO(perezju): Temporary workaround to disable periodic memory dumps. | 71 # TODO(perezju): Temporary workaround to disable periodic memory dumps. |
| 65 # See: http://crbug.com/513692 | 72 # See: http://crbug.com/513692 |
| 66 '--enable-memory-benchmarking', | 73 '--enable-memory-benchmarking', |
| 67 ]) | 74 ]) |
| 68 | 75 |
| 69 def CreateStorySet(self, options): | |
| 70 return page_sets.OortOnlineTBMPageSet() | |
| 71 | |
| 72 def CreateTimelineBasedMeasurementOptions(self): | 76 def CreateTimelineBasedMeasurementOptions(self): |
| 73 v8_gc_latency_categories = [ | 77 v8_categories = [ |
|
petrcermak
2016/06/29 14:48:18
does it still make sense to write the categories l
ulan
2016/06/29 15:38:21
Done.
| |
| 74 'blink.console', 'renderer.scheduler', 'v8', 'webkit.console'] | 78 'blink.console', 'disabled-by-default-v8.gc', |
| 79 'renderer.scheduler', 'v8', 'webkit.console'] | |
| 75 smoothness_categories = [ | 80 smoothness_categories = [ |
| 76 'webkit.console', 'blink.console', 'benchmark', 'trace_event_overhead'] | 81 'webkit.console', 'blink.console', 'benchmark', 'trace_event_overhead'] |
| 77 categories = list(set(v8_gc_latency_categories + smoothness_categories)) | 82 memory_categories = ['blink.console', 'disabled-by-default-memory-infra'] |
| 78 memory_categories = 'blink.console,disabled-by-default-memory-infra' | |
| 79 category_filter = tracing_category_filter.TracingCategoryFilter( | 83 category_filter = tracing_category_filter.TracingCategoryFilter( |
| 80 memory_categories) | 84 ','.join(['-*'] + v8_categories + |
| 81 for category in categories: | 85 smoothness_categories + memory_categories)) |
| 82 category_filter.AddIncludedCategory(category) | |
| 83 options = timeline_based_measurement.Options(category_filter) | 86 options = timeline_based_measurement.Options(category_filter) |
| 84 options.SetLegacyTimelineBasedMetrics([v8_gc_latency.V8GCLatency(), | 87 options.SetTimelineBasedMetric('v8AndMemoryAndResponsivenessMetrics') |
| 85 smoothness.SmoothnessMetric(), | |
| 86 memory_timeline.MemoryTimelineMetric()]) | |
| 87 return options | 88 return options |
| 88 | 89 |
| 89 @classmethod | 90 @classmethod |
| 90 def Name(cls): | 91 def Name(cls): |
| 91 return 'oortonline_tbm' | 92 return 'oortonline_tbmv2' |
| 92 | 93 |
| 93 @classmethod | 94 @classmethod |
| 94 def ValueCanBeAddedPredicate(cls, value, is_first_result): | 95 def ValueCanBeAddedPredicate(cls, value, _): |
| 95 if value.tir_label in ['Begin', 'End']: | 96 if 'memory:chrome' in value.name: |
| 96 return value.name.startswith('memory_') and 'v8_renderer' in value.name | 97 return bool(cls._V8_AND_OVERALL_MEMORY_RE.search(value.name)) |
| 97 else: | 98 return ('v8' in value.name or |
| 98 return value.tir_label == 'Running' | 99 value.name in ['animation throughput', |
| 100 'animation frameTimeDiscrepancy']) | |
| OLD | NEW |