# Copyright (c) 2012 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. """ The autotest performing FW update, both EC and AP.""" import logging import sys from autotest_lib.client.common_lib import error from autotest_lib.server import test class provision_FirmwareUpdate(test.test): """A test that can provision a machine to the correct firmware version.""" version = 1 def stage_image_to_usb(self, host): """Stage the current ChromeOS image on the USB stick connected to the servo. @param host: a CrosHost object of the machine to update. """ info = host.host_info_store.get() if not info.build: logging.warning('Failed to get build label from the DUT, skip ' 'staging ChromeOS image on the servo USB stick.') else: host.servo.image_to_servo_usb( host.stage_image_for_servo(info.build)) logging.debug('ChromeOS image %s is staged on the USB stick.', info.build) def get_ro_firmware_ver(self, host): """Get the RO firmware version from the host.""" result = host.run('crossystem ro_fwid', ignore_status=True) if result.exit_status == 0: # The firmware ID is something like "Google_Board.1234.56.0". # Remove the prefix "Google_Board". return result.stdout.split('.', 1)[1] else: return None def get_rw_firmware_ver(self, host): """Get the RW firmware version from the host.""" result = host.run('crossystem fwid', ignore_status=True) if result.exit_status == 0: # The firmware ID is something like "Google_Board.1234.56.0". # Remove the prefix "Google_Board". return result.stdout.split('.', 1)[1] else: return None def run_once(self, host, value, rw_only=False, stage_image_to_usb=False): """The method called by the control file to start the test. @param host: a CrosHost object of the machine to update. @param value: the provisioning value, which is the build version to which we want to provision the machine, e.g. 'link-firmware/R22-2695.1.144'. @param rw_only: True to only update the RW firmware. @param stage_image_to_usb: True to stage the current ChromeOS image on the USB stick connected to the servo. Default is False. """ try: host.repair_servo() # Stage the current CrOS image to servo USB stick. if stage_image_to_usb: self.stage_image_to_usb(host) host.firmware_install(build=value, rw_only=rw_only) except Exception as e: logging.error(e) raise error.TestFail, str(e), sys.exc_info()[2] # DUT reboots after the above firmware_install(). Wait it to boot. host.test_wait_for_boot() # Only care about the version number. firmware_ver = value.rsplit('-', 1)[1] if not rw_only: current_ro_ver = self.get_ro_firmware_ver(host) if current_ro_ver != firmware_ver: raise error.TestFail('Failed to update RO, still version %s' % current_ro_ver) current_rw_ver = self.get_rw_firmware_ver(host) if current_rw_ver != firmware_ver: raise error.TestFail('Failed to update RW, still version %s' % current_rw_ver)