Home | History | Annotate | Download | only in firmware_CorruptBothFwSigAB
      1 # Copyright (c) 2011 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_CorruptBothFwSigAB"
      9 PURPOSE = "Servo based both firmware signature A and B corruption test"
     10 CRITERIA = "This test will fail if firmware does not enter recovery mode"
     11 ATTRIBUTES = "suite:faft, suite:faft_bios, suite:faft_bios_au_1, suite:faft_bios_au_2, suite:faft_bios_au_3, suite:faft_lv3, suite:faft_normal, suite:faft_bios_ec3po, suite:faft_bios_tot"
     12 TIME = "SHORT"
     13 TEST_CATEGORY = "Functional"
     14 TEST_CLASS = "firmware"
     15 TEST_TYPE = "server"
     16 JOB_RETRIES = 4
     17 
     18 DOC = """
     19 This test requires a USB disk plugged-in, which contains a Chrome OS test
     20 image (built by "build_image --test"). On runtime, this test corrupts
     21 both firmware signature A and B. On next reboot, the firmware verification
     22 fails and enters recovery mode. This test then checks the success of the
     23 recovery boot.
     24 """
     25 
     26 args_dict = utils.args_to_dict(args)
     27 servo_args = hosts.CrosHost.get_servo_arguments(args_dict)
     28 
     29 def run_corruptbothfwsigab(machine):
     30     host = hosts.create_host(machine, servo_args=servo_args)
     31     job.run_test("firmware_CorruptBothFwSigAB", host=host, cmdline_args=args,
     32                  disable_sysinfo=True, dev_mode=False, tag="normal")
     33 
     34 parallel_simple(run_corruptbothfwsigab, machines)
     35