# Lint as: python2, python3 # Copyright 2020 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 from autotest_lib.client.common_lib import error from autotest_lib.client.common_lib.cros import dev_server from autotest_lib.client.common_lib.cros import kernel_utils from autotest_lib.client.cros import cryptohome from autotest_lib.server.cros import provisioner from autotest_lib.server.cros.update_engine import update_engine_test class autoupdate_Basic(update_engine_test.UpdateEngineTest): """Performs a simple AU using Nebraska.""" version = 1 def cleanup(self): super(autoupdate_Basic, self).cleanup() def run_once(self, full_payload, job_repo_url=None, build=None, m2n=False, running_at_desk=False, pin_login=False): """ Performs a N-to-N autoupdate with Nebraska. @param full_payload: True for full payload, False for delta @param job_repo_url: A url pointing to the devserver where the autotest package for this build should be staged. @param build: An optional parameter to specify the target build for the update when running locally. job_repo_url will override this value. @m2n: M -> N update. This means we install the current stable version of this board before updating to ToT. @param running_at_desk: Indicates test is run locally from workstation. Flag does not work with M2N tests. @param pin_login: True to use login via PIN. """ if pin_login: if not cryptohome.is_low_entropy_credentials_supported(self._host): raise error.TestNAError( 'Skip test: No hardware support for PIN login') # Get a payload to use for the test. payload_url = self.get_payload_for_nebraska( job_repo_url=job_repo_url, build=build, full_payload=full_payload, public_bucket=running_at_desk) self._m2n = m2n if self._m2n: if self._host.get_board().endswith("-kernelnext"): raise error.TestNAError("Skipping test on kernelnext board") # Provision latest stable build for the current build. build_name = self._get_latest_serving_stable_build() logging.debug('build name is %s', build_name) # Install the matching build with quick provision. if running_at_desk: self._copy_quick_provision_to_dut() update_url = self._get_provision_url_on_public_bucket( build_name) else: autotest_devserver = dev_server.ImageServer.resolve( build_name, self._host.hostname) update_url = autotest_devserver.get_update_url(build_name) logging.info('Installing source image with update url: %s', update_url) provisioner.ChromiumOSProvisioner( update_url, host=self._host, is_release_bucket=True, public_bucket=running_at_desk).run_provision() # Login to device before update if pin_login: self._run_client_test_and_check_result(self._LOGIN_TEST_PIN, tag='before') else: self._run_client_test_and_check_result( self._LOGIN_TEST, username=self._LOGIN_TEST_USERNAME, password=self._LOGIN_TEST_PASSWORD, tag='before') # Record DUT state before the update. active, inactive = kernel_utils.get_kernel_state(self._host) # Perform the update. self._run_client_test_and_check_result('autoupdate_CannedOmahaUpdate', payload_url=payload_url) # Verify the update completed successfully. self._host.reboot() kernel_utils.verify_boot_expectations(inactive, host=self._host) rootfs_hostlog, _ = self._create_hostlog_files() self.verify_update_events(self._FORCED_UPDATE, rootfs_hostlog) if self._m2n: # Bring stateful version to the same version as rootfs. logging.info('Restoring stateful partition to ToT version') self._update_stateful() # Check we can login with the same user after update. if pin_login: self._run_client_test_and_check_result(self._LOGIN_TEST_PIN, tag='after', setup_pin=False) else: self._run_client_test_and_check_result( self._LOGIN_TEST, tag='after', username=self._LOGIN_TEST_USERNAME, password=self._LOGIN_TEST_PASSWORD, dont_override_profile=True)