1 # Copyright (c) 2012 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 from autotest_lib.server import utils 6 7 AUTHOR = "Chrome OS Team" 8 NAME = "firmware_UpdateFirmwareDataKeyVersion" 9 PURPOSE = """ 10 Servo based firmware update test which check firmware datakey version. 11 """ 12 CRITERIA = """ 13 Prerequirement is as follow: 14 1.The fwid should matches shellball's (/usr/sbin/chromeos-firmwareupdate) fwid, 15 unless this test use a given shellball. 16 2. A USB disk should be plugged-in, which contains a Chrome OS test image. 17 18 This test will fail if following requrements are met: 19 1. fwid does not match shellball's (/usr/sbin/chromeos-firmwareupdate) fwid 20 2. Firmware datakey version does not match original datakey version. 21 """ 22 # TODO(waihong): Add back to the regular FAFT suite when the TPM recovery 23 # is added to the lab infrastructure. 24 ATTRIBUTES = "suite:faft_lv5" 25 SUITE = "faft_lv5" 26 TIME = "SHORT" 27 TEST_CATEGORY = "Functional" 28 TEST_CLASS = "firmware" 29 TEST_TYPE = "server" 30 31 DOC = """ 32 This test requires a USB test image plugged in. The firmware id 33 should matches fwid of shellball chromeos-firmwareupdate, or user can 34 provide a shellball to do this test. In this way, the client will be update 35 with the given shellball first. On runtime, this test modifies shellball 36 and runs autoupdate. Check firmware datakey version after boot with 37 firmware B, and then recover firmware A and B to original shellball. 38 """ 39 40 args_dict = utils.args_to_dict(args) 41 servo_args = hosts.CrosHost.get_servo_arguments(args_dict) 42 43 def run_updatefirmwaredatakeyversion(machine): 44 host = hosts.create_host(machine, servo_args=servo_args) 45 job.run_test("firmware_UpdateFirmwareDataKeyVersion", 46 host=host, cmdline_args=args, 47 disable_sysinfo=True) 48 49 parallel_simple(run_updatefirmwaredatakeyversion, machines) 50