xref: /aosp_15_r20/external/autotest/server/site_tests/sequences/control.power (revision 9c5db1993ded3edbeafc8092d69fe5de2ee02df7)
1*9c5db199SXin Li# Copyright (c) 2010 The Chromium OS Authors. All rights reserved.
2*9c5db199SXin Li# Use of this source code is governed by a BSD-style license that can be
3*9c5db199SXin Li# found in the LICENSE file.
4*9c5db199SXin Li
5*9c5db199SXin LiAUTHOR = "ChromeOS Team"
6*9c5db199SXin LiNAME = "Power"
7*9c5db199SXin LiTIME = "LONG"
8*9c5db199SXin LiTEST_CATEGORY = "Functional"
9*9c5db199SXin LiTEST_CLASS = "suite"
10*9c5db199SXin LiTEST_TYPE = "server"
11*9c5db199SXin LiDEPENDENCIES = "rpm"
12*9c5db199SXin LiPY_VERSION = 3
13*9c5db199SXin Li
14*9c5db199SXin LiDOC = """
15*9c5db199SXin LiThis test suite runs automated power tests that should all pass and that
16*9c5db199SXin Lirequire the power to be connected with a remote power manager.
17*9c5db199SXin Li"""
18*9c5db199SXin Li
19*9c5db199SXin Lifrom autotest_lib.server import site_host_attributes
20*9c5db199SXin Lifrom autotest_lib.client.common_lib import error
21*9c5db199SXin Li
22*9c5db199SXin Li# Run power tests that don't take a long time
23*9c5db199SXin LiTESTS = [
24*9c5db199SXin Li  'power_Display',
25*9c5db199SXin Li  'power_CPUFreq',
26*9c5db199SXin Li  'power_CPUIdle',
27*9c5db199SXin Li  'power_Draw',
28*9c5db199SXin Li  'power_Idle',
29*9c5db199SXin Li  'power_StatsCPUFreq',
30*9c5db199SXin Li  'power_StatsUSB',
31*9c5db199SXin Li]
32*9c5db199SXin Li
33*9c5db199SXin Li
34*9c5db199SXin Lidef run_client_test(machine):
35*9c5db199SXin Li  client = hosts.create_host(machine)
36*9c5db199SXin Li  client_attributes = site_host_attributes.HostAttributes(client.hostname)
37*9c5db199SXin Li  client_at = autotest.Autotest(client)
38*9c5db199SXin Li
39*9c5db199SXin Li  if client.has_power():
40*9c5db199SXin Li    client.power_on()
41*9c5db199SXin Li  else:
42*9c5db199SXin Li    raise error.TestNAError("No power switch configured")
43*9c5db199SXin Li
44*9c5db199SXin Li  # Charge battery to at least 50% first
45*9c5db199SXin Li  client_at.run_test('power_BatteryCharge', percent_target_charge=50,
46*9c5db199SXin Li                     max_run_time=60*60*4, tag='CHARGE_50')
47*9c5db199SXin Li
48*9c5db199SXin Li  try:
49*9c5db199SXin Li    client.power_off()
50*9c5db199SXin Li    for test in TESTS:
51*9c5db199SXin Li        client_at.run_test(test)
52*9c5db199SXin Li
53*9c5db199SXin Li    if not client_attributes.has_resume_bug:
54*9c5db199SXin Li        client_at.run_test('power_Resume')
55*9c5db199SXin Li        client_at.run_test('power_UiResume')
56*9c5db199SXin Li
57*9c5db199SXin Li  finally:
58*9c5db199SXin Li    client.power_on()
59*9c5db199SXin Li
60*9c5db199SXin Li  # Run the 60/20/10/10 load test
61*9c5db199SXin Li  # Charge the battery to at least 99% in preparation for the load
62*9c5db199SXin Li  # test. Charging the battery from empty to full can take up to 4 hours.
63*9c5db199SXin Li  client_at.run_test('power_BatteryCharge', percent_target_charge=99,
64*9c5db199SXin Li                     max_run_time=60*60*5, tag='CHARGE_99')
65*9c5db199SXin Li
66*9c5db199SXin Li  # Turn off power and run power_LoadTest. The power_LoadTest can take
67*9c5db199SXin Li  # up to 9 hours to run to completion
68*9c5db199SXin Li  # TODO (snanda):
69*9c5db199SXin Li  # 1. Make the test run over wifi instead of ethernet
70*9c5db199SXin Li  # 2. Make the test login automatically to facebook and gmail
71*9c5db199SXin Li  # 3. Add audiovideo_V4L2 webcam test
72*9c5db199SXin Li  client.power_off()
73*9c5db199SXin Li
74*9c5db199SXin Li  try:
75*9c5db199SXin Li    if hasattr(client_attributes, 'wifi'):
76*9c5db199SXin Li      wifi_ap, wifi_sec, wifi_pw = client_attributes.wifi.split(',')
77*9c5db199SXin Li
78*9c5db199SXin Li      client_at.run_test('power_LoadTest', loop_count=9, loop_time=3600,
79*9c5db199SXin Li                         force_wifi=True, wifi_ap=wifi_ap, wifi_sec=wifi_sec,
80*9c5db199SXin Li                         wifi_pw=wifi_pw, tag='WIFI')
81*9c5db199SXin Li    else:
82*9c5db199SXin Li      client_at.run_test('power_LoadTest', loop_count=9, loop_time=3600,
83*9c5db199SXin Li                         check_network=False, tag='WIRED')
84*9c5db199SXin Li  finally:
85*9c5db199SXin Li    client.power_on()
86*9c5db199SXin Li
87*9c5db199SXin Li
88*9c5db199SXin Lijob.parallel_on_machines(run_client_test, machines)
89