Home | History | Annotate | Download | only in display_EdidStress
      1 # Copyright (c) 2014 The Chromium OS Authors. All rights reserved.
      2 # Use of this source code is governed by a BSD-style license that can be
      3 # found in the LICENSE file.
      4 
      5 """This is a server side stressing DUT by switching Chameleon EDID."""
      6 
      7 import glob
      8 import logging
      9 import os
     10 import xmlrpclib
     11 
     12 from autotest_lib.client.bin import utils
     13 from autotest_lib.client.common_lib import error
     14 from autotest_lib.client.cros.chameleon import chameleon_port_finder
     15 from autotest_lib.client.cros.chameleon import chameleon_screen_test
     16 from autotest_lib.client.cros.chameleon import edid
     17 from autotest_lib.server import test
     18 from autotest_lib.server.cros.multimedia import remote_facade_factory
     19 
     20 
     21 class display_EdidStress(test.test):
     22     """Server side external display test.
     23 
     24     This test switches Chameleon EDID from among a large pool of EDIDs, tests
     25     DUT recognizes the emulated monitor and emits the correct video signal to
     26     Chameleon.
     27     """
     28     version = 1
     29 
     30     _EDID_TYPES = {'HDMI': {'HDMI', 'MHL', 'DVI'},
     31                    'DP': {'DP'},
     32                    'VGA': {'VGA'}}
     33 
     34     def run_once(self, host, edid_set):
     35 
     36         def _get_edid_type(s):
     37             i = s.rfind('_') + 1
     38             j = len(s) - len('.txt')
     39             return s[i:j].upper()
     40 
     41         edid_path = os.path.join(self.bindir, 'test_data', 'edids',
     42                                  edid_set, '*')
     43 
     44         factory = remote_facade_factory.RemoteFacadeFactory(host)
     45         display_facade = factory.create_display_facade()
     46         chameleon_board = host.chameleon
     47 
     48         chameleon_board.setup_and_reset(self.outputdir)
     49         finder = chameleon_port_finder.ChameleonVideoInputFinder(
     50                 chameleon_board, display_facade)
     51         for chameleon_port in finder.iterate_all_ports():
     52             screen_test = chameleon_screen_test.ChameleonScreenTest(
     53                 host, chameleon_port, display_facade, self.outputdir)
     54 
     55             logging.info('See the display on Chameleon: port %d (%s)',
     56                          chameleon_port.get_connector_id(),
     57                          chameleon_port.get_connector_type())
     58 
     59             connector = chameleon_port.get_connector_type()
     60             supported_types = self._EDID_TYPES[connector]
     61 
     62             failed_edids = []
     63             for filepath in glob.glob(edid_path):
     64                 filename = os.path.basename(filepath)
     65                 edid_type = _get_edid_type(filename)
     66                 if edid_type not in supported_types:
     67                     logging.info('Skip EDID: %s...', filename)
     68                     continue
     69 
     70                 logging.info('Use EDID: %s...', filename)
     71                 try:
     72                     with chameleon_port.use_edid(
     73                             edid.Edid.from_file(filepath, skip_verify=True)):
     74                         resolution = utils.wait_for_value_changed(
     75                                 display_facade.get_external_resolution,
     76                                 old_value=None)
     77                         if resolution is None:
     78                             raise error.TestFail('No external display detected on DUT')
     79                         if screen_test.test_resolution(resolution):
     80                             raise error.TestFail('Resolution test failed')
     81                 except (error.TestFail, xmlrpclib.Fault) as e:
     82                     logging.warning(e)
     83                     logging.error('EDID not supported: %s', filename)
     84                     failed_edids.append(filename)
     85 
     86             if failed_edids:
     87                 message = ('Total %d EDIDs not supported: ' % len(failed_edids)
     88                            + ', '.join(failed_edids))
     89                 logging.error(message)
     90                 raise error.TestFail(message)
     91