OLD | NEW |
1 # Copyright 2013 The Chromium Authors. All rights reserved. | 1 # Copyright 2013 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 import collections | 4 import collections |
5 import json | 5 import json |
6 import logging | 6 import logging |
7 | 7 |
8 from metrics import Metric | 8 from metrics import Metric |
9 | 9 |
10 from telemetry.core import exceptions | 10 from telemetry.core import exceptions |
(...skipping 29 matching lines...) Expand all Loading... |
40 tab) | 40 tab) |
41 if high_bytes == 0 and low_bytes == 0: | 41 if high_bytes == 0 and low_bytes == 0: |
42 return None | 42 return None |
43 return (int(high_bytes) << 32) | (int(low_bytes) << 1) | 43 return (int(high_bytes) << 32) | (int(low_bytes) << 1) |
44 | 44 |
45 def _RecordTabLoadTimes(self, tab, browser_main_entry_time_ms, results): | 45 def _RecordTabLoadTimes(self, tab, browser_main_entry_time_ms, results): |
46 """Records the tab load times for the browser. """ | 46 """Records the tab load times for the browser. """ |
47 tab_load_times = [] | 47 tab_load_times = [] |
48 TabLoadTime = collections.namedtuple( | 48 TabLoadTime = collections.namedtuple( |
49 'TabLoadTime', | 49 'TabLoadTime', |
50 ['request_start_ms', 'load_end_ms']) | 50 ['load_start_ms', 'load_duration_ms', 'request_start_ms']) |
51 | 51 |
52 def RecordTabLoadTime(t): | 52 def RecordTabLoadTime(t): |
53 try: | 53 try: |
54 t.WaitForJavaScriptExpression( | 54 t.WaitForDocumentReadyStateToBeComplete() |
55 'window.performance.timing["loadEventEnd"] > 0', 10) | 55 |
| 56 result = t.EvaluateJavaScript( |
| 57 'statsCollectionController.tabLoadTiming()') |
| 58 result = json.loads(result) |
| 59 |
| 60 if 'load_start_ms' not in result or 'load_duration_ms' not in result: |
| 61 raise Exception("Outdated Chrome version, " |
| 62 "statsCollectionController.tabLoadTiming() not present") |
| 63 if result['load_duration_ms'] is None: |
| 64 tab_title = t.EvaluateJavaScript('document.title') |
| 65 print "Page: ", tab_title, " didn't finish loading." |
| 66 return |
56 | 67 |
57 perf_timing = t.EvaluateJavaScript('window.performance.timing') | 68 perf_timing = t.EvaluateJavaScript('window.performance.timing') |
58 if 'requestStart' not in perf_timing: | 69 if 'requestStart' not in perf_timing: |
59 perf_timing['requestStart'] = 0 # Exclude from benchmark results | 70 perf_timing['requestStart'] = 0 # Exclude from benchmark results |
60 print 'requestStart is not supported by this browser' | 71 print 'requestStart is not supported by this browser' |
61 | 72 |
62 tab_load_times.append(TabLoadTime( | 73 tab_load_times.append(TabLoadTime( |
63 int(perf_timing['requestStart']), | 74 int(result['load_start_ms']), |
64 int(perf_timing['loadEventEnd']))) | 75 int(result['load_duration_ms']), |
| 76 int(perf_timing['requestStart']))) |
65 except exceptions.TimeoutException: | 77 except exceptions.TimeoutException: |
66 # Low memory Android devices may not be able to load more than | 78 # Low memory Android devices may not be able to load more than |
67 # one tab at a time, so may timeout when the test attempts to | 79 # one tab at a time, so may timeout when the test attempts to |
68 # access a background tab. Ignore these tabs. | 80 # access a background tab. Ignore these tabs. |
69 logging.error("Tab timed out on JavaScript access") | 81 logging.error("Tab timed out on JavaScript access") |
70 | 82 |
71 # Only measure the foreground tab. We can't measure all tabs on Android | 83 # Only measure the foreground tab. We can't measure all tabs on Android |
72 # because on Android the data of the background tabs is loaded on demand, | 84 # because on Android the data of the background tabs is loaded on demand, |
73 # when the user switches to them, rather than during startup. In view of | 85 # when the user switches to them, rather than during startup. In view of |
74 # this, to get the same measures on all platform, we only measure the | 86 # this, to get the same measures on all platform, we only measure the |
75 # foreground tab on all platforms. | 87 # foreground tab on all platforms. |
76 | 88 |
77 RecordTabLoadTime(tab.browser.foreground_tab) | 89 RecordTabLoadTime(tab.browser.foreground_tab) |
78 | 90 |
79 foreground_tab_stats = tab_load_times[0] | 91 foreground_tab_stats = tab_load_times[0] |
80 foreground_tab_load_complete = ( | 92 foreground_tab_load_complete = ((foreground_tab_stats.load_start_ms + |
81 foreground_tab_stats.load_end_ms - browser_main_entry_time_ms) | 93 foreground_tab_stats.load_duration_ms) - browser_main_entry_time_ms) |
82 results.AddValue(scalar.ScalarValue( | 94 results.AddValue(scalar.ScalarValue( |
83 results.current_page, 'foreground_tab_load_complete', 'ms', | 95 results.current_page, 'foreground_tab_load_complete', 'ms', |
84 foreground_tab_load_complete)) | 96 foreground_tab_load_complete)) |
85 if (foreground_tab_stats.request_start_ms > 0): | 97 if (foreground_tab_stats.request_start_ms > 0): |
86 results.AddValue(scalar.ScalarValue( | 98 results.AddValue(scalar.ScalarValue( |
87 results.current_page, 'foreground_tab_request_start', 'ms', | 99 results.current_page, 'foreground_tab_request_start', 'ms', |
88 foreground_tab_stats.request_start_ms - browser_main_entry_time_ms)) | 100 foreground_tab_stats.request_start_ms - browser_main_entry_time_ms)) |
89 | 101 |
90 def AddResults(self, tab, results): | 102 def AddResults(self, tab, results): |
91 get_histogram_js = 'statsCollectionController.getBrowserHistogram("%s")' | 103 get_histogram_js = 'statsCollectionController.getBrowserHistogram("%s")' |
(...skipping 13 matching lines...) Expand all Loading... |
105 | 117 |
106 results.AddValue(scalar.ScalarValue( | 118 results.AddValue(scalar.ScalarValue( |
107 results.current_page, display_name, 'ms', measured_time)) | 119 results.current_page, display_name, 'ms', measured_time)) |
108 | 120 |
109 # Get tab load times. | 121 # Get tab load times. |
110 browser_main_entry_time_ms = self._GetBrowserMainEntryTime(tab) | 122 browser_main_entry_time_ms = self._GetBrowserMainEntryTime(tab) |
111 if (browser_main_entry_time_ms is None): | 123 if (browser_main_entry_time_ms is None): |
112 print "Outdated Chrome version, browser main entry time not supported." | 124 print "Outdated Chrome version, browser main entry time not supported." |
113 return | 125 return |
114 self._RecordTabLoadTimes(tab, browser_main_entry_time_ms, results) | 126 self._RecordTabLoadTimes(tab, browser_main_entry_time_ms, results) |
OLD | NEW |