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 telemetry.page.actions.all_page_actions import WaitAction | |
6 from telemetry.page import page | 5 from telemetry.page import page |
7 from telemetry.page import page_measurement | 6 from telemetry.page import page_measurement |
8 | 7 |
9 | 8 |
10 class PageForPolymerLoad(page.Page): | 9 class PageForPolymerLoad(page.Page): |
11 | 10 |
12 def __init__(self, url, page_set): | 11 def __init__(self, url, page_set): |
13 super(PageForPolymerLoad, self).__init__( | 12 super(PageForPolymerLoad, self).__init__( |
14 url=url, | 13 url=url, |
15 page_set=page_set) | 14 page_set=page_set) |
16 self.script_to_evaluate_on_commit = ''' | 15 self.script_to_evaluate_on_commit = ''' |
17 document.addEventListener("polymer-ready", function() { | 16 document.addEventListener("polymer-ready", function() { |
18 var unused = document.body.offsetHeight; | 17 var unused = document.body.offsetHeight; |
19 window.__polymer_ready_time = performance.now(); | 18 window.__polymer_ready_time = performance.now(); |
20 setTimeout(function() { | 19 setTimeout(function() { |
21 window.__polymer_ready = true; | 20 window.__polymer_ready = true; |
22 }, 1000); | 21 }, 1000); |
23 }) | 22 }) |
24 ''' | 23 ''' |
25 | 24 |
26 def RunNavigateSteps(self, action_runner): | 25 def RunNavigateSteps(self, action_runner): |
27 action_runner.NavigateToPage(self) | 26 action_runner.NavigateToPage(self) |
28 action_runner.RunAction(WaitAction( | 27 action_runner.WaitForJavaScriptCondition('window.__polymer_ready') |
29 { | |
30 'javascript': "window.__polymer_ready" | |
31 })) | |
32 | 28 |
33 | 29 |
34 class PolymerLoadMeasurement(page_measurement.PageMeasurement): | 30 class PolymerLoadMeasurement(page_measurement.PageMeasurement): |
35 def MeasurePage(self, _, tab, results): | 31 def MeasurePage(self, _, tab, results): |
36 result = int(tab.EvaluateJavaScript('__polymer_ready_time')) | 32 result = int(tab.EvaluateJavaScript('__polymer_ready_time')) |
37 results.Add('Total', 'ms', result) | 33 results.Add('Total', 'ms', result) |
OLD | NEW |