| 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 |