blob: c3ec34578ea04ef243421a0c5942220f435b944d [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_Cr50RMAOpen.faft_cr50_tot"
PURPOSE = "Verify RMA Open"
ATTRIBUTES = "suite:faft_cr50_tot"
TEST_TYPE = "server"
DOC = """
Verify Cr50 RMA behavoior
Verify a couple of things:
- basic open from AP and command line
- Rate limiting
- Authcodes can't be reused once another challenge is generated.
- if the image is prod signed with mp flags, it isn't using test keys
Generate the challenge and calculate the response using rma_reset -c. Verify
open works and enables all of the ccd features.
If the generated challenge has the wrong version, make sure the challenge
generated with the test key fails.
This test is applicable when using ToT cr50 module.
TODO( Drop this control file once suites can inject test args.
if 'args_dict' not in locals():
args_dict = {}
servo_args = hosts.CrosHost.get_servo_arguments(args_dict)
# Inject test args.
args_dict['tot_test_run'] = 'true'
def run(machine):
host = hosts.create_host(machine, servo_args=servo_args)
iterations = int(args_dict.get("iterations", 1))
job.run_test("firmware_Cr50RMAOpen", host=host, cmdline_args=args,
full_args=args_dict, iterations=iterations)
parallel_simple(run, machines)