OLD | NEW |
1 # Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 # Copyright (c) 2012 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 logging | 5 import logging |
6 import time | |
7 | 6 |
8 from telemetry.core import util | 7 from telemetry.core import util |
9 from telemetry.core import exceptions | 8 from telemetry.core import exceptions |
10 from telemetry.unittest import tab_test_case | 9 from telemetry.unittest import tab_test_case |
11 from telemetry.unittest import DisabledTest | |
12 | 10 |
13 | 11 |
14 def _IsDocumentVisible(tab): | 12 def _IsDocumentVisible(tab): |
15 state = tab.EvaluateJavaScript('document.webkitVisibilityState') | 13 state = tab.EvaluateJavaScript('document.webkitVisibilityState') |
16 # TODO(dtu): Remove when crbug.com/166243 is fixed. | 14 # TODO(dtu): Remove when crbug.com/166243 is fixed. |
17 tab.Disconnect() | 15 tab.Disconnect() |
18 return state == 'visible' | 16 return state == 'visible' |
19 | 17 |
20 | 18 |
21 class TabTest(tab_test_case.TabTestCase): | 19 class TabTest(tab_test_case.TabTestCase): |
(...skipping 28 matching lines...) Expand all Loading... |
50 self._tab.Activate() | 48 self._tab.Activate() |
51 util.WaitFor(lambda: _IsDocumentVisible(self._tab), timeout=5) | 49 util.WaitFor(lambda: _IsDocumentVisible(self._tab), timeout=5) |
52 self.assertFalse(_IsDocumentVisible(new_tab)) | 50 self.assertFalse(_IsDocumentVisible(new_tab)) |
53 | 51 |
54 | 52 |
55 class GpuTabTest(tab_test_case.TabTestCase): | 53 class GpuTabTest(tab_test_case.TabTestCase): |
56 def setUp(self): | 54 def setUp(self): |
57 self._extra_browser_args = ['--enable-gpu-benchmarking'] | 55 self._extra_browser_args = ['--enable-gpu-benchmarking'] |
58 super(GpuTabTest, self).setUp() | 56 super(GpuTabTest, self).setUp() |
59 | 57 |
60 @DisabledTest | |
61 def testScreenshot(self): | 58 def testScreenshot(self): |
62 if not self._tab.screenshot_supported: | 59 if not self._tab.screenshot_supported: |
63 logging.warning('Browser does not support screenshots, skipping test.') | 60 logging.warning('Browser does not support screenshots, skipping test.') |
64 return | 61 return |
65 | 62 |
66 self._browser.SetHTTPServerDirectories(util.GetUnittestDataDir()) | 63 self._browser.SetHTTPServerDirectories(util.GetUnittestDataDir()) |
67 self._tab.Navigate( | 64 self._tab.Navigate( |
68 self._browser.http_server.UrlOf('green_rect.html')) | 65 self._browser.http_server.UrlOf('green_rect.html')) |
69 self._tab.WaitForDocumentReadyStateToBeComplete() | 66 self._tab.WaitForDocumentReadyStateToBeComplete() |
70 pixel_ratio = self._tab.EvaluateJavaScript('window.devicePixelRatio || 1') | 67 pixel_ratio = self._tab.EvaluateJavaScript('window.devicePixelRatio || 1') |
71 | 68 |
72 # TODO(bajones): Sleep for a bit to counter BUG 260878. | |
73 time.sleep(0.5) | |
74 screenshot = self._tab.Screenshot(5) | 69 screenshot = self._tab.Screenshot(5) |
75 assert screenshot | 70 assert screenshot |
76 screenshot.GetPixelColor(0 * pixel_ratio, 0 * pixel_ratio).AssertIsRGB( | 71 screenshot.GetPixelColor(0 * pixel_ratio, 0 * pixel_ratio).AssertIsRGB( |
77 0, 255, 0, tolerance=2) | 72 0, 255, 0, tolerance=2) |
78 screenshot.GetPixelColor(31 * pixel_ratio, 31 * pixel_ratio).AssertIsRGB( | 73 screenshot.GetPixelColor(31 * pixel_ratio, 31 * pixel_ratio).AssertIsRGB( |
79 0, 255, 0, tolerance=2) | 74 0, 255, 0, tolerance=2) |
80 screenshot.GetPixelColor(32 * pixel_ratio, 32 * pixel_ratio).AssertIsRGB( | 75 screenshot.GetPixelColor(32 * pixel_ratio, 32 * pixel_ratio).AssertIsRGB( |
81 255, 255, 255, tolerance=2) | 76 255, 255, 255, tolerance=2) |
| 77 |
| 78 def testScreenshotSync(self): |
| 79 if not self._tab.screenshot_supported: |
| 80 logging.warning('Browser does not support screenshots, skipping test.') |
| 81 return |
| 82 |
| 83 self._browser.SetHTTPServerDirectories(util.GetUnittestDataDir()) |
| 84 self._tab.Navigate( |
| 85 self._browser.http_server.UrlOf('screenshot_sync.html')) |
| 86 self._tab.WaitForDocumentReadyStateToBeComplete() |
| 87 |
| 88 def IsTestComplete(): |
| 89 return self._tab.EvaluateJavaScript('window.__testComplete') |
| 90 util.WaitFor(IsTestComplete, 120) |
| 91 |
| 92 message = self._tab.EvaluateJavaScript('window.__testMessage') |
| 93 if message: |
| 94 logging.error(message) |
| 95 assert self._tab.EvaluateJavaScript('window.__testSuccess') |
OLD | NEW |