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 |