# Copyright 2014 The Chromium OS Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
from autotest_lib.client.cros.chameleon import mirror_comparison
from autotest_lib.client.cros.chameleon import resolution_comparison
from autotest_lib.client.cros.chameleon import screen_capture
from autotest_lib.client.cros.chameleon import screen_comparison
class ScreenUtilityFactory(object):
"""A factory to generate utilities for screen comparison test.
This factory creates the utilities, according to the properties of
the CrOS. For example, a CrOS connected to VGA can use a VGA specific
algorithm for screen comparison.
"""
_PIXEL_DIFF_MARGIN_FOR_ANALOG = 30
_PIXEL_DIFF_MARGIN_FOR_DIGITAL = 2
_WRONG_PIXELS_MARGIN_FOR_ANALOG = 0.04 # 4%
_WRONG_PIXELS_MARGIN_FOR_DIGITAL = 0
def __init__(self, chameleon_port, display_facade):
"""Initializes the ScreenUtilityFactory objects."""
self._chameleon_port = chameleon_port
self._display_facade = display_facade
self._is_vga = chameleon_port.get_connector_type() == 'VGA'
def create_resolution_comparer(self):
"""Creates a resolution comparer object."""
if self._is_vga:
return resolution_comparison.VgaResolutionComparer(
self._chameleon_port, self._display_facade)
else:
return resolution_comparison.ExactMatchResolutionComparer(
self._chameleon_port, self._display_facade)
def create_chameleon_screen_capturer(self):
"""Creates a Chameleon screen capturer."""
if self._is_vga:
return screen_capture.VgaChameleonScreenCapturer(
self._chameleon_port)
else:
return screen_capture.CommonChameleonScreenCapturer(
self._chameleon_port)
def create_cros_screen_capturer(self, internal_screen=False):
"""Creates an Chrome OS screen capturer.
@param internal_screen: True to compare the internal screen on CrOS.
"""
if internal_screen:
return screen_capture.CrosInternalScreenCapturer(
self._display_facade)
else:
return screen_capture.CrosExternalScreenCapturer(
self._display_facade)
def create_screen_comparer(self, output_dir):
"""Creates a screen comparer.
@param output_dir: The directory the image files output to.
"""
if self._is_vga:
pixel_diff_margin = self._PIXEL_DIFF_MARGIN_FOR_ANALOG
wrong_pixels_margin = self._WRONG_PIXELS_MARGIN_FOR_ANALOG
else:
pixel_diff_margin = self._PIXEL_DIFF_MARGIN_FOR_DIGITAL
wrong_pixels_margin = self._WRONG_PIXELS_MARGIN_FOR_DIGITAL
capturer1 = self.create_chameleon_screen_capturer()
capturer2 = self.create_cros_screen_capturer()
return screen_comparison.ScreenComparer(
capturer1, capturer2, output_dir,
pixel_diff_margin, wrong_pixels_margin)
def create_mirror_comparer(self, output_dir):
"""Creates a comparer for mirrored mode.
@param output_dir: The directory the image files output to.
"""
return mirror_comparison.MirrorComparer(self._display_facade, output_dir)