| 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 from measurements import media | 5 from measurements import media |
| 6 import page_sets | 6 import page_sets |
| 7 from telemetry import test | 7 from telemetry import benchmark |
| 8 from telemetry.page import page_measurement | 8 from telemetry.page import page_measurement |
| 9 from telemetry.value import list_of_scalar_values | 9 from telemetry.value import list_of_scalar_values |
| 10 from telemetry.value import scalar | 10 from telemetry.value import scalar |
| 11 | 11 |
| 12 | 12 |
| 13 class _MSEMeasurement(page_measurement.PageMeasurement): | 13 class _MSEMeasurement(page_measurement.PageMeasurement): |
| 14 def MeasurePage(self, page, tab, results): | 14 def MeasurePage(self, page, tab, results): |
| 15 media_metric = tab.EvaluateJavaScript('window.__testMetrics') | 15 media_metric = tab.EvaluateJavaScript('window.__testMetrics') |
| 16 trace = media_metric['id'] if 'id' in media_metric else None | 16 trace = media_metric['id'] if 'id' in media_metric else None |
| 17 metrics = media_metric['metrics'] if 'metrics' in media_metric else [] | 17 metrics = media_metric['metrics'] if 'metrics' in media_metric else [] |
| 18 for m in metrics: | 18 for m in metrics: |
| 19 trace_name = '%s.%s' % (m, trace) | 19 trace_name = '%s.%s' % (m, trace) |
| 20 if isinstance(metrics[m], list): | 20 if isinstance(metrics[m], list): |
| 21 results.AddValue(list_of_scalar_values.ListOfScalarValues( | 21 results.AddValue(list_of_scalar_values.ListOfScalarValues( |
| 22 results.current_page, trace_name, units='ms', | 22 results.current_page, trace_name, units='ms', |
| 23 values=[float(v) for v in metrics[m]], | 23 values=[float(v) for v in metrics[m]], |
| 24 important=True)) | 24 important=True)) |
| 25 | 25 |
| 26 else: | 26 else: |
| 27 results.AddValue(scalar.ScalarValue( | 27 results.AddValue(scalar.ScalarValue( |
| 28 results.current_page, trace_name, units='ms', | 28 results.current_page, trace_name, units='ms', |
| 29 value=float(metrics[m]), important=True)) | 29 value=float(metrics[m]), important=True)) |
| 30 | 30 |
| 31 | 31 |
| 32 class Media(test.Test): | 32 class Media(benchmark.Benchmark): |
| 33 """Obtains media metrics for key user scenarios.""" | 33 """Obtains media metrics for key user scenarios.""" |
| 34 test = media.Media | 34 test = media.Media |
| 35 page_set = page_sets.ToughVideoCasesPageSet | 35 page_set = page_sets.ToughVideoCasesPageSet |
| 36 | 36 |
| 37 | 37 |
| 38 class MediaNetworkSimulation(test.Test): | 38 class MediaNetworkSimulation(benchmark.Benchmark): |
| 39 """Obtains media metrics under different network simulations.""" | 39 """Obtains media metrics under different network simulations.""" |
| 40 test = media.Media | 40 test = media.Media |
| 41 page_set = page_sets.MediaCnsCasesPageSet | 41 page_set = page_sets.MediaCnsCasesPageSet |
| 42 | 42 |
| 43 | 43 |
| 44 class MediaAndroid(test.Test): | 44 class MediaAndroid(benchmark.Benchmark): |
| 45 """Obtains media metrics for key user scenarios on Android.""" | 45 """Obtains media metrics for key user scenarios on Android.""" |
| 46 test = media.Media | 46 test = media.Media |
| 47 tag = 'android' | 47 tag = 'android' |
| 48 page_set = page_sets.ToughVideoCasesPageSet | 48 page_set = page_sets.ToughVideoCasesPageSet |
| 49 # Exclude is_4k and 50 fps media files (garden* & crowd*). | 49 # Exclude is_4k and 50 fps media files (garden* & crowd*). |
| 50 options = {'page_label_filter_exclude': 'is_4k,is_50fps'} | 50 options = {'page_label_filter_exclude': 'is_4k,is_50fps'} |
| 51 | 51 |
| 52 | 52 |
| 53 class MediaChromeOS4kOnly(test.Test): | 53 class MediaChromeOS4kOnly(benchmark.Benchmark): |
| 54 """Benchmark for media performance on ChromeOS using only is_4k test content. | 54 """Benchmark for media performance on ChromeOS using only is_4k test content. |
| 55 """ | 55 """ |
| 56 test = media.Media | 56 test = media.Media |
| 57 tag = 'chromeOS4kOnly' | 57 tag = 'chromeOS4kOnly' |
| 58 page_set = page_sets.ToughVideoCasesPageSet | 58 page_set = page_sets.ToughVideoCasesPageSet |
| 59 options = { | 59 options = { |
| 60 'page_label_filter': 'is_4k', | 60 'page_label_filter': 'is_4k', |
| 61 # Exclude is_50fps test files: crbug/331816 | 61 # Exclude is_50fps test files: crbug/331816 |
| 62 'page_label_filter_exclude': 'is_50fps' | 62 'page_label_filter_exclude': 'is_50fps' |
| 63 } | 63 } |
| 64 | 64 |
| 65 | 65 |
| 66 class MediaChromeOS(test.Test): | 66 class MediaChromeOS(benchmark.Benchmark): |
| 67 """Benchmark for media performance on all ChromeOS platforms. | 67 """Benchmark for media performance on all ChromeOS platforms. |
| 68 | 68 |
| 69 This benchmark does not run is_4k content, there's a separate benchmark for | 69 This benchmark does not run is_4k content, there's a separate benchmark for |
| 70 that. | 70 that. |
| 71 """ | 71 """ |
| 72 test = media.Media | 72 test = media.Media |
| 73 tag = 'chromeOS' | 73 tag = 'chromeOS' |
| 74 page_set = page_sets.ToughVideoCasesPageSet | 74 page_set = page_sets.ToughVideoCasesPageSet |
| 75 # Exclude is_50fps test files: crbug/331816 | 75 # Exclude is_50fps test files: crbug/331816 |
| 76 options = {'page_label_filter_exclude': 'is_4k,is_50fps'} | 76 options = {'page_label_filter_exclude': 'is_4k,is_50fps'} |
| 77 | 77 |
| 78 | 78 |
| 79 class MediaSourceExtensions(test.Test): | 79 class MediaSourceExtensions(benchmark.Benchmark): |
| 80 """Obtains media metrics for key media source extensions functions.""" | 80 """Obtains media metrics for key media source extensions functions.""" |
| 81 test = _MSEMeasurement | 81 test = _MSEMeasurement |
| 82 page_set = page_sets.MseCasesPageSet | 82 page_set = page_sets.MseCasesPageSet |
| 83 | 83 |
| 84 def CustomizeBrowserOptions(self, options): | 84 def CustomizeBrowserOptions(self, options): |
| 85 # Needed to allow XHR requests to return stream objects. | 85 # Needed to allow XHR requests to return stream objects. |
| 86 options.AppendExtraBrowserArgs( | 86 options.AppendExtraBrowserArgs( |
| 87 ['--enable-experimental-web-platform-features', | 87 ['--enable-experimental-web-platform-features', |
| 88 '--disable-gesture-requirement-for-media-playback']) | 88 '--disable-gesture-requirement-for-media-playback']) |
| OLD | NEW |