# Copyright 2016 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.
import logging
import time
from contextlib import contextmanager
from autotest_lib.client.common_lib import error
from autotest_lib.client.cros.chameleon import chameleon_port_finder
class _BaseChameleonMeasurer(object):
"""Base class of performing measurement using Chameleon."""
_TIME_WAIT_FADE_OUT = 10
_WAIT_TIME_LID_TRANSITION = 5
def __init__(self, cros_host, outputdir=None):
"""Initializes the object."""
raise NotImplementedError('_BaseChameleonMeasurer.__init__')
@contextmanager
def start_mirrored_mode_measurement(self):
"""Starts the mirrored mode to measure.
It iterates the connection ports between DUT and Chameleon and uses
the first port. Sets DUT into the mirrored mode. Then yields the
connected ports.
It is used via a with statement, like the following:
measurer = LocalChameleonMeasurer(cros_host, args, chrome)
with measurer.start_mirrored_mode_measurement() as chameleon_port:
# chameleon_port is automatically plugged before this line.
do_some_test_on(chameleon_port)
# chameleon_port is automatically unplugged after this line.
@yields the first connected ChameleonVideoInput which is ensured plugged
before yielding.
@raises TestFail if no connected video port.
"""
finder = chameleon_port_finder.ChameleonVideoInputFinder(
self.chameleon, self.display_facade)
with finder.use_first_port() as chameleon_port:
logging.info('Used Chameleon port: %s',
chameleon_port.get_connector_type())
logging.info('Setting to mirrored mode')
self.display_facade.set_mirrored(True)
# Hide the typing cursor.
self.display_facade.hide_typing_cursor()
# Sleep a while to wait the pop-up window faded-out.
time.sleep(self._TIME_WAIT_FADE_OUT)
# Get the resolution to make sure Chameleon in a good state.
resolution = chameleon_port.get_resolution()
logging.info('Detected the resolution: %dx%d', *resolution)
yield chameleon_port
@contextmanager
def start_dock_mode_measurement(self):
"""Starts the dock mode to measure.
It iterates the connection ports between DUT and Chameleon and uses
the first port. Sets DUT into the dock mode. Then yields the
connected ports.
It is used via a with statement, like the following:
measurer = LocalChameleonMeasurer(cros_host, args, chrome)
with measurer.start_dock_mode_measurement() as chameleon_port:
# chameleon_port is automatically plugged before this line
# and lid is close to enter doc mode.
do_some_test_on(chameleon_port)
# chameleon_port is automatically unplugged after this line
# and lid is open again.
@yields the first connected ChameleonVideoInput which is ensured plugged
before yielding.
@raises TestFail if no connected video port or fail to enter dock mode.
"""
finder = chameleon_port_finder.ChameleonVideoInputFinder(
self.chameleon, self.display_facade)
try:
with finder.use_first_port() as chameleon_port:
logging.info('Used Chameleon port: %s',
chameleon_port.get_connector_type())
logging.info('Close lid to switch into dock mode...')
self.host.servo.lid_close()
time.sleep(self._WAIT_TIME_LID_TRANSITION)
# Hide the typing cursor.
self.display_facade.hide_typing_cursor()
# Sleep a while to wait the pop-up window faded-out.
time.sleep(self._TIME_WAIT_FADE_OUT)
# Get the resolution to make sure Chameleon in a good state.
resolution = chameleon_port.get_resolution()
logging.info('Detected the resolution: %dx%d', *resolution)
# Check if it is dock mode, no internal screen.
if self.display_facade.get_internal_resolution() is not None:
raise error.TestError('Failed to enter dock mode: '
'internal display still valid')
yield chameleon_port
finally:
logging.info('Open lid again...')
self.host.servo.lid_open()