# Copyright (c) 2017 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. """Host object for Jetstream devices. Host customization provided for fine-tuning autotest reset, verification, and provisioning on Jetstream devices. A more customized host wrapper is typicaly used in Jetstream autotests. """ import logging import common from autotest_lib.client.common_lib import error from autotest_lib.client.common_lib import lsbrelease_utils from autotest_lib.server.hosts import cros_host from autotest_lib.server.hosts import cros_repair # Presence of any of these processes indicates that the host is up: BOOT_DETECTION_PROCESSES = ('ap-controller',) # Maximum time for host to report is_up after rebooting BOOT_TIMEOUT_SECONDS = 180 # Maximum time for host to recover after resetting RESET_TIMEOUT_SECONDS = 60 class JetstreamHost(cros_host.CrosHost): """Jetstream-specific host class.""" @staticmethod def check_host(host, timeout=10): """ Check if the given host is jetstream host. @param host: An ssh host representing a device. @param timeout: The timeout for the run command. @return: True if the host is a Jetstream device, otherwise False. """ try: lsb_release_content = host.run( 'grep CHROMEOS_RELEASE_BOARD /etc/lsb-release').stdout return lsbrelease_utils.is_jetstream( lsb_release_content=lsb_release_content) except (error.AutoservRunError, error.AutoservSSHTimeout): return False def _initialize(self, *args, **dargs): logging.debug('Initializing Jetstream host') super(JetstreamHost, self)._initialize(*args, **dargs) # Overwrite base class initialization self._repair_strategy = cros_repair.create_jetstream_repair_strategy() def get_os_type(self): return 'jetstream' def get_wait_up_processes(self): return BOOT_DETECTION_PROCESSES def verify(self): # Whirlwind takes longer to start all system services, so check # that ap-controller is running before verifying, crbug/739583. self.wait_up(timeout=BOOT_TIMEOUT_SECONDS) logging.debug('Jetstream host is up, starting verification') super(JetstreamHost, self).verify() def cleanup_services(self): """Restores the host to default settings. @raises AutoservRunError: on failure. """ logging.debug('Jetstream: Resetting AP services') # This is a 'fake' factory reset which restores the DUT to # its default state and restarts AP services. self.run('sudo ap-configure --factory_reset', ignore_status=False) self.wait_up(timeout=RESET_TIMEOUT_SECONDS) # Stop service ap-update-manager to prevent rebooting during autoupdate. self.run('sudo stop ap-update-manager', ignore_status=False) def prepare_for_update(self): """Prepare the host for an update.""" logging.debug('Jetstream: Prepare for update') try: self.cleanup_services() except error.AutoservRunError: logging.exception('Failed to reset host')