1# Copyright 2017 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 5import logging 6import time 7 8from autotest_lib.client.common_lib import error 9from autotest_lib.server import autotest, test 10from autotest_lib.server.cros.faft.firmware_test import FirmwareTest 11 12 13class firmware_Cr50USB(FirmwareTest): 14 """ 15 Stress the Cr50 usb connection to the DUT. 16 17 This test is intended to be run with many iterations to ensure that the 18 USB connection is not flaky. 19 20 The iteration should be specified by the parameter -a "num_iterations=10". 21 22 To exit on the first USB failure use "exit_condition='immediately'". 23 """ 24 version = 1 25 26 SLEEP_DELAY = 20 27 28 def cleanup(self): 29 """Reenable CCD before cleanup""" 30 if hasattr(self, "cr50"): 31 self.cr50.ccd_enable() 32 super(firmware_Cr50USB, self).cleanup() 33 34 35 def run_once(self, host, cmdline_args, num_iterations=100, 36 exit_condition=None): 37 self.host = host 38 # Disable CCD so it doesn't interfere with the Cr50 AP usb connection. 39 if hasattr(self, "cr50"): 40 self.cr50.ccd_disable() 41 42 # Make sure the device is logged in so TPM activity doesn't keep it 43 # awake 44 self.client_at = autotest.Autotest(self.host) 45 self.client_at.run_test('login_LoginSuccess') 46 47 failed_runs = [] 48 fail_count = 0 49 logging.info("Running Cr50 USB stress test for %d iterations", 50 num_iterations) 51 52 for iteration in xrange(num_iterations): 53 if iteration: 54 time.sleep(self.SLEEP_DELAY) 55 56 i = iteration + 1 57 logging.info("Run %d of %d%s", i, num_iterations, 58 " %d failures" % fail_count if fail_count else "") 59 try: 60 # Run usb_updater command. 61 result = self.host.run("usb_updater -f") 62 except Exception, e: 63 failed_runs.append(str(i)) 64 fail_count += 1 65 logging.debug(e) 66 67 if exit_condition == "immediately": 68 raise error.TestFail("USB failure on run %d of %d" % 69 (i, num_iterations)) 70 71 logging.info("USB failure on %d out of %d runs: %s", fail_count, 72 i, ', '.join(failed_runs)) 73 74 if fail_count: 75 raise error.TestFail('USB failure on %d runs out of %d: %s' % 76 (fail_count, num_iterations, ', '.join(failed_runs))) 77