Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 #!/usr/bin/python | |
| 2 # Copyright (c) 2011 The Chromium Authors. All rights reserved. | |
| 3 # Use of this source code is governed by a BSD-style license that | |
| 4 # can be found in the LICENSE file. | |
| 5 | |
| 6 import os | |
| 7 import time | |
|
dtu
2011/06/01 01:09:23
Remove extra import.
xot
2011/06/06 02:27:19
Done.
| |
| 8 | |
| 9 import pyauto_functional # Must be imported before pyauto | |
| 10 import pyauto | |
| 11 | |
| 12 from chromeos.power_strip import PowerStrip | |
| 13 | |
| 14 class ChromeosBattery(pyauto.PyUITest): | |
| 15 """Tests ChromeOS Battery Status API. | |
|
Nirnimesh
2011/06/01 00:33:00
nit: leave a blank line after this line
Remove 'A
xot
2011/06/06 02:27:19
Done.
| |
| 16 Preconditions: | |
| 17 1) Device under test (DUT) is connected to the corporate LAN | |
|
Nirnimesh
2011/06/01 00:33:00
remove reference to 'corporate'. Just mention that
xot
2011/06/06 02:27:19
Done.
| |
| 18 LAN via Ethernet-to-USB adapter plugged into one of its | |
| 19 USB ports. | |
| 20 2) AC power cable is connected to the DUT, and plugged into | |
| 21 the IP controlled Power Switch, outlet #4, located in the | |
|
Nirnimesh
2011/06/01 00:33:00
remove name of the lab
xot
2011/06/06 02:27:19
Done.
| |
| 22 Oyster Bay lab. | |
| 23 3) Battery is installed in the DUT, and battery is not fully | |
| 24 discharged. | |
| 25 | |
| 26 Note about calculation time: | |
| 27 When AC power is turned off or on, the battery will take from 2 | |
| 28 to 60 seconds to calculate the time left. While calculating, the | |
| 29 keys 'battery_time_to_full' and 'battery_time_to_empty' are | |
| 30 absent. | |
| 31 """ | |
| 32 | |
| 33 _OUTLET_WITH_BATTERY = '.a4' | |
|
dtu
2011/06/01 01:09:23
Put this in the configuration file and read it fro
xot
2011/06/06 02:27:19
Done.
| |
| 34 _BATTERY_CONFIG_FILE = os.path.join(pyauto.PyUITest.DataDir(), | |
| 35 'pyauto_private', 'chromeos', 'power', | |
|
dtu
2011/06/01 01:09:23
nit: Indent these lines by one space.
xot
2011/06/06 02:27:19
Done.
| |
| 36 'battery_testbed_config') | |
|
dtu
2011/06/01 01:09:23
Does this configuration file exist yet? Please sta
xot
2011/06/06 02:27:19
Yes file exists. It was sent out as issue https://
| |
| 37 | |
| 38 def setUp(self): | |
| 39 pyauto.PyUITest.setUp(self) | |
| 40 self.InitPowerStrip() | |
| 41 | |
| 42 def tearDown(self): | |
| 43 # Leave power outlet On so battery does not discharge | |
| 44 self._power_strip.PowerOn(ChromeosBattery._OUTLET_WITH_BATTERY) | |
| 45 pyauto.PyUITest.tearDown(self) | |
| 46 | |
| 47 def InitPowerStrip(self): | |
| 48 self.assertTrue( | |
|
Nirnimesh
2011/06/01 00:33:00
replace self.assertTrue with 'assert'
Use self.as
xot
2011/06/06 02:27:19
Done.
| |
| 49 lambda: os.path.exists(ChromeosBattery._BATTERY_CONFIG_FILE), | |
| 50 msg = 'Power Strip configuration file does not exist.') | |
| 51 power_config = pyauto.PyUITest.EvalDataFrom( | |
| 52 ChromeosBattery._BATTERY_CONFIG_FILE) | |
| 53 self._power_strip = PowerStrip(power_config['strip_ip']) | |
| 54 | |
| 55 def WaitUntilBatteryTimeIsCalculated(self): | |
| 56 battery_status = self.GetBatteryInfo() | |
| 57 if battery_status.get('line_power_on'): | |
| 58 time_key = 'battery_time_to_full' | |
| 59 else: | |
| 60 time_key = 'battery_time_to_empty' | |
| 61 return self.WaitUntil(lambda: self.GetBatteryInfo().get(time_key) != None, | |
| 62 timeout=60, | |
| 63 retry_sleep=2) | |
| 64 | |
| 65 def testBatteryChargesWhenACisOn(self): | |
| 66 """AC power ON to CrOS device with battery.""" | |
| 67 self._power_strip.PowerOn(ChromeosBattery._OUTLET_WITH_BATTERY) | |
| 68 | |
| 69 # Get info about charging battery | |
| 70 self.assertTrue(self.WaitUntilBatteryTimeIsCalculated(), | |
| 71 msg='Battery charge time was not calculated') | |
| 72 battery_status = self.GetBatteryInfo() | |
| 73 self.assertTrue(battery_status.get('battery_is_present'), | |
| 74 msg='Battery is not present.') | |
| 75 self.assertTrue(battery_status.get('line_power_on'), | |
| 76 msg='Line power is off.') | |
| 77 self.assertTrue(battery_status.get('battery_time_to_full') >= 0, | |
| 78 msg='Battery charge time is negative.') | |
| 79 | |
| 80 def testBatteryDischargesWhenACisOff(self): | |
| 81 """AC power OFF to CrOS device with battery.""" | |
| 82 self._power_strip.PowerOff(ChromeosBattery._OUTLET_WITH_BATTERY) | |
| 83 | |
| 84 # Get info about discharging battery | |
| 85 self.assertTrue(self.WaitUntilBatteryTimeIsCalculated(), | |
| 86 msg='Battery discharge time was not calculated.') | |
| 87 battery_status = self.GetBatteryInfo() | |
| 88 self.assertTrue(battery_status.get('battery_is_present'), | |
| 89 msg='Battery is not present.') | |
| 90 self.assertFalse(battery_status.get('line_power_on'), | |
| 91 msg='Line power is off.') | |
| 92 self.assertTrue(battery_status.get('battery_time_to_empty') >= 0, | |
| 93 msg='Battery discharge time is negative.') | |
| 94 | |
| 95 def testBatteryTimesAreDifferent(self): | |
| 96 """Time until full is different than Time until empty""" | |
| 97 # Turn AC Power ON | |
| 98 self._power_strip.PowerOn(ChromeosBattery._OUTLET_WITH_BATTERY) | |
| 99 | |
| 100 # Get charging battery time to full | |
| 101 self.WaitUntilBatteryTimeIsCalculated() | |
| 102 battery_status = self.GetBatteryInfo() | |
| 103 time_to_full = battery_status.get('battery_time_to_full') | |
| 104 | |
| 105 # Turn AC Power OFF | |
| 106 self._power_strip.PowerOff(ChromeosBattery._OUTLET_WITH_BATTERY) | |
| 107 | |
| 108 # Get discharging battery time to empty | |
| 109 self.WaitUntilBatteryTimeIsCalculated() | |
| 110 battery_status = self.GetBatteryInfo() | |
| 111 time_to_empty = battery_status.get('battery_time_to_empty') | |
| 112 | |
| 113 # Compare times | |
| 114 self.assertNotEqual(time_to_full, time_to_empty, | |
| 115 msg='Battery time to full equals time to empty. ' | |
| 116 'Though very unlikely, this is not impossible. ' | |
| 117 'If test failed falsely, Kris owes Scott a beer. ') | |
| 118 | |
|
Nirnimesh
2011/06/01 00:33:00
nit: need another blank line here
xot
2011/06/06 02:27:19
Done.
| |
| 119 if __name__ == '__main__': | |
| 120 pyauto_functional.Main() | |
| OLD | NEW |