Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 # Copyright 2016 The Chromium Authors. All rights reserved. | 1 # Copyright 2016 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 | 5 import re |
| 6 | 6 |
| 7 from benchmarks import v8_helper | 7 from benchmarks import v8_helper |
| 8 from core import perf_benchmark | 8 from core import perf_benchmark |
| 9 from telemetry import benchmark | 9 from telemetry import benchmark |
| 10 from telemetry.timeline import chrome_trace_config | 10 from telemetry.timeline import chrome_trace_config |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 79 return ('renderer_processes' in value.name and | 79 return ('renderer_processes' in value.name and |
| 80 not _IGNORED_MEMORY_STATS_RE.search(value.name)) | 80 not _IGNORED_MEMORY_STATS_RE.search(value.name)) |
| 81 return (_V8_GC_HIGH_LEVEL_STATS_RE.search(value.name) and | 81 return (_V8_GC_HIGH_LEVEL_STATS_RE.search(value.name) and |
| 82 not _IGNORED_V8_STATS_RE.search(value.name)) | 82 not _IGNORED_V8_STATS_RE.search(value.name)) |
| 83 | 83 |
| 84 @classmethod | 84 @classmethod |
| 85 def ShouldTearDownStateAfterEachStoryRun(cls): | 85 def ShouldTearDownStateAfterEachStoryRun(cls): |
| 86 return True | 86 return True |
| 87 | 87 |
| 88 | 88 |
| 89 class _V8RuntimeStatsBrowsingBenchmark(_V8BrowsingBenchmark): | |
| 90 """Base class for V8 browsing benchmarks that measure RuntimeStats. | |
| 91 RuntimeStats measure the time spent by v8 in different phases like | |
| 92 compile, JS execute, runtime etc., | |
| 93 See browsing_stories._BrowsingStory for workload description. | |
| 94 """ | |
| 95 | |
| 96 def CreateTimelineBasedMeasurementOptions(self): | |
| 97 # Adds options for GC and v8 execution metrics. | |
| 98 options = super(_V8RuntimeStatsBrowsingBenchmark, | |
| 99 self).CreateTimelineBasedMeasurementOptions() | |
| 100 | |
| 101 # Add options for runtime stats metric. | |
| 102 options.category_filter.AddIncludedCategory('v8') | |
| 103 options.category_filter.AddDisabledByDefault( | |
| 104 'disabled-by-default-v8.runtime_stats') | |
| 105 | |
| 106 # Enable rail to bucket runtime stats based on UE. | |
| 107 options.category_filter.AddIncludedCategory('rail') | |
| 108 | |
| 109 options.AddTimelineBasedMetric('runtimeStatsTotalMetric') | |
|
nednguyen
2017/02/13 20:28:22
Also wouldn't you also enable GC metrics?
mythria
2017/02/14 14:48:30
I made this a subclass of V8 browsing benchmark, s
nednguyen
2017/02/14 15:05:25
The problem with this approach is besides GC, it w
mythria
2017/02/14 16:05:34
Thanks, Done.
| |
| 110 return options | |
| 111 | |
| 112 @classmethod | |
| 113 def Name(cls): | |
| 114 return 'v8.runtimestats.browsing_%s%s' % (cls.PLATFORM, cls.TEST_SUFFIX) | |
| 115 | |
| 116 @classmethod | |
| 117 def ShouldTearDownStateAfterEachStoryRun(cls): | |
| 118 return True | |
| 119 | |
| 120 | |
| 89 class _V8DesktopBrowsingBenchmark(_V8BrowsingBenchmark): | 121 class _V8DesktopBrowsingBenchmark(_V8BrowsingBenchmark): |
| 90 | 122 |
| 91 @classmethod | 123 @classmethod |
| 92 def ShouldDisable(cls, possible_browser): | 124 def ShouldDisable(cls, possible_browser): |
| 93 # http://crbug.com/628736 | 125 # http://crbug.com/628736 |
| 94 if (possible_browser.platform.GetOSName() == 'mac' and | 126 if (possible_browser.platform.GetOSName() == 'mac' and |
| 95 possible_browser.browser_type == 'reference'): | 127 possible_browser.browser_type == 'reference'): |
| 96 return True | 128 return True |
| 97 | 129 |
| 98 return possible_browser.platform.GetDeviceTypeName() != 'Desktop' | 130 return possible_browser.platform.GetDeviceTypeName() != 'Desktop' |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 148 | 180 |
| 149 | 181 |
| 150 @benchmark.Disabled('reference') # http://crbug.com/628631 | 182 @benchmark.Disabled('reference') # http://crbug.com/628631 |
| 151 class V8MobileTurboBrowsingBenchmark(_V8MobileBrowsingBenchmark): | 183 class V8MobileTurboBrowsingBenchmark(_V8MobileBrowsingBenchmark): |
| 152 PLATFORM = 'mobile' | 184 PLATFORM = 'mobile' |
| 153 TEST_SUFFIX = '_turbo' | 185 TEST_SUFFIX = '_turbo' |
| 154 | 186 |
| 155 def SetExtraBrowserOptions(self, options): | 187 def SetExtraBrowserOptions(self, options): |
| 156 super(V8MobileTurboBrowsingBenchmark, self).SetExtraBrowserOptions( | 188 super(V8MobileTurboBrowsingBenchmark, self).SetExtraBrowserOptions( |
| 157 options) | 189 options) |
| 190 | |
| 191 | |
| 192 class V8RuntimeStatsDesktopBrowsingBenchmark( | |
| 193 _V8RuntimeStatsBrowsingBenchmark): | |
| 194 PLATFORM = 'desktop' | |
| 195 TEST_SUFFIX = '' | |
| 196 | |
| 197 @classmethod | |
| 198 def ShouldDisable(cls, possible_browser): | |
| 199 return possible_browser.platform.GetDeviceTypeName() != 'Desktop' | |
| 200 | |
| 201 | |
| 202 class V8RuntimeStatsDesktopTurboBrowsingBenchmark( | |
| 203 _V8RuntimeStatsBrowsingBenchmark): | |
| 204 PLATFORM = 'desktop' | |
| 205 TEST_SUFFIX = '_turbo' | |
| 206 | |
| 207 def SetExtraBrowserOptions(self, options): | |
| 208 super(V8RuntimeStatsDesktopTurboBrowsingBenchmark, | |
| 209 self).SetExtraBrowserOptions(options) | |
| 158 v8_helper.EnableTurbo(options) | 210 v8_helper.EnableTurbo(options) |
| 211 | |
| 212 @classmethod | |
| 213 def ShouldDisable(cls, possible_browser): | |
| 214 return possible_browser.platform.GetDeviceTypeName() != 'Desktop' | |
| 215 | |
| 216 | |
| 217 class V8RuntimeStatsMobileBrowsingBenchmark( | |
| 218 _V8RuntimeStatsBrowsingBenchmark): | |
| 219 PLATFORM = 'mobile' | |
| 220 TEST_SUFFIX = '' | |
| 221 | |
| 222 def SetExtraBrowserOptions(self, options): | |
| 223 super(V8RuntimeStatsMobileBrowsingBenchmark, | |
| 224 self).SetExtraBrowserOptions(options) | |
| 225 v8_helper.EnableTurbo(options) | |
| 226 | |
| 227 @classmethod | |
| 228 def ShouldDisable(cls, possible_browser): | |
| 229 return possible_browser.platform.GetDeviceTypeName() == 'Desktop' | |
| 230 | |
| 231 | |
| 232 class V8RuntimeStatsMobileTurboBrowsingBenchmark( | |
| 233 _V8RuntimeStatsBrowsingBenchmark): | |
| 234 PLATFORM = 'mobile' | |
| 235 TEST_SUFFIX = '_turbo' | |
| 236 | |
| 237 def SetExtraBrowserOptions(self, options): | |
| 238 super(V8RuntimeStatsMobileTurboBrowsingBenchmark, | |
| 239 self).SetExtraBrowserOptions(options) | |
| 240 v8_helper.EnableTurbo(options) | |
| 241 | |
| 242 @classmethod | |
| 243 def ShouldDisable(cls, possible_browser): | |
| 244 return possible_browser.platform.GetDeviceTypeName() == 'Desktop' | |
| 245 | |
| OLD | NEW |