1# Copyright (c) 2014 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
5from autotest_lib.server import utils
6
7AUTHOR = "Harpreet Grewal <harpreet@chromium.org>"
8NAME = "cellular_StaleModemReboot"
9PURPOSE = "Verify modem is available for testing."
10CRITERIA = """
11This test will fail if either there is no response to modem status command or
12modem is in a non testable state after two or more tries.
13"""
14TIME = "SHORT"
15TEST_CATEGORY = "Functional"
16TEST_CLASS = "network"
17TEST_TYPE = "server"
18ATTRIBUTES = "suite:cellular_modem_repair"
19DEPENDENCIES = "servo_state:WORKING"
20
21DOC = """
22  Tests that a cellular modem is available for testing.
23
24  The test attempts to detect the modem state by running the modem status
25  command on the DUT and strips the state from its output. The test saves the
26  original modem state and reboots the DUT regardless of what state the modem
27  is in. After the reboot, it tries to get the modem state again and if the
28  modem does not respond or the state is one of the following as listed below,
29  it tries to reboot the DUT for a maximum of two tries by default. User can
30  override the number of tries by passing a tries flag with a desired value.
31
32  REBOOT STATES (If modem is in any of these states, DUT is cold rebooted using
33  the servo.):
34  MODEM STATE FAILED = -1
35  MODEM STATE UNKNOWN = 0
36  MODEM STATE DISABLED = 3
37  MODEM STATE DISABLING = 4
38  MODEM STATE DISCONNECTING = 9
39  GOBI MODEM STATE UNKNOWN = 0
40  GOBI MODEM STATE DISABLED = 10
41  GOBI MODEM STATE DISABLING = 20
42  GOBI MODEM STATE DISCONNECTING = 70
43
44  WAIT DELAY STATES (Waits for a maximum of 120 seconds for the modem to get
45  into a testable state. If the modem is still not in a stable state after the
46  first try, DUT will be rebooted.):
47  MODEM STATE INITIALIZING = 1
48  MODEM STATE ENABLING = 5
49  MODEM STATE ENABLED = 6
50  MODEM STATE SEARCHING = 7
51  GOBI MODEM STATE ENABLING = 30
52  GOBI MODEM STATE ENABLED = 40
53  GOBI MODEM STATE SEARCHING = 50
54
55  STABLE STATES (Test does nothing.):
56  MODEM STATE REGISTERED = 8
57  MODEM STATE CONNECTING = 10
58  MODEM STATE CONNECTED = 11
59  GOBI MODEM STATE REGISTERED = 60
60  GOBI MODEM STATE CONNECTING = 80
61  GOBI MODEM STATE CONNECTED = 90
62
63  LOCKED STATE (Test fails, the device should never be in this state unless
64  the SIM is locked):
65  MODEM STATE LOCKED = 2
66
67"""
68
69args_dict = utils.args_to_dict(args)
70servo_args = hosts.CrosHost.get_servo_arguments(args_dict)
71
72def run_StaleModemReboot(machine):
73    host = hosts.create_host(machine, servo_args=servo_args)
74    tries = int(args_dict.get('tries', 2))
75    job.run_test('cellular_StaleModemReboot', host=host, tries=tries)
76
77parallel_simple(run_StaleModemReboot, machines)
78