blob: ebe37ff430698f1c3b4cc5b6a4d0998c4e4312cf [file] [log] [blame]
# Copyright 2019 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.
from autotest_lib.server import utils
AUTHOR = "mruthven"
NAME = "firmware_Cr50TpmManufactured"
PURPOSE = "Check if the TPM is manufactured."
ATTRIBUTES = "suite:faft_cr50_prepvt, suite:faft_cr50_pvt"
TIME = "SHORT"
TEST_TYPE = "server"
DEPENDENCIES = "servo_state:WORKING"
DOC = """Check if the TPM is manufactured.
Cr50 will manufacture the TPM if the manufacturing space is ok. If we reset the
TPM and it isn't manufactured, then it's likely the manufacturing space is
corrupted. Corrupted manufacturing space can cause all sorts of weird issues.
This test can be used to find bad boards and possibly find issues with Cr50
images. Most of the time this issue is caused by bad DBG images, so it can
highlight those issues, but the test is mainly to make sure there aren't broken
boards in the lab.
"""
if 'args_dict' not in locals():
args_dict = {}
args_dict.update(utils.args_to_dict(args))
servo_args = hosts.CrosHost.get_servo_arguments(args_dict)
def run(machine):
host = hosts.create_host(machine, servo_args=servo_args)
iterations = int(args_dict.get("iterations", 1))
job.run_test("firmware_Cr50TpmManufactured", host=host, cmdline_args=args,
full_args=args_dict, iterations=iterations)
parallel_simple(run, machines)