Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5928)

Unified Diff: chrome/test/functional/chromeos_battery.py

Issue 6990069: Adding PyAuto Battery test for ChromeOS (Closed) Base URL: http://src.chromium.org/svn/trunk/src/
Patch Set: '' Created 9 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/test/functional/chromeos_battery.py
===================================================================
--- chrome/test/functional/chromeos_battery.py (revision 0)
+++ chrome/test/functional/chromeos_battery.py (revision 0)
@@ -0,0 +1,122 @@
+#!/usr/bin/python
+# Copyright (c) 2011 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that
+# can be found in the LICENSE file.
+
+import os
+
+import pyauto_functional # Must be imported before pyauto
+import pyauto
+
+from chromeos.power_strip import PowerStrip
+
+class ChromeosBattery(pyauto.PyUITest):
+ """Tests ChromeOS Battery Status.
+
+ Preconditions:
+ 1) Device under test (DUT) is connected to the LAN via an
+ Ethernet-to-USB adapter plugged into one of its USB ports.
+ 2) AC power cable is connected to the DUT, and plugged into
+ the IP controlled Power Switch, outlet #4, located in the lab.
+ 3) Battery is installed in the DUT, and battery is not fully
+ discharged.
+ 4) Tester should have physical access to the power switch.
+
+ Note about time calculation:
+ When AC power is turned off or on, the battery will take from 2
+ to 60 seconds to calculate the time remaining to empty or full.
+ While calculating, the keys 'battery_time_to_full' and
+ 'battery_time_to_empty' are absent.
+ """
+
+ _BATTERY_CONFIG_FILE = os.path.join(pyauto.PyUITest.DataDir(),
+ 'pyauto_private', 'chromeos', 'power',
+ 'battery_testbed_config')
+
+ def setUp(self):
+ pyauto.PyUITest.setUp(self)
+ self.InitPowerStrip()
+
+ def tearDown(self):
+ # Leave AC power ON so battery does not discharge between tests
+ self._power_strip.PowerOn(self._outlet_battery_full)
+ pyauto.PyUITest.tearDown(self)
+
+ def InitPowerStrip(self):
+ assert os.path.exists(ChromeosBattery._BATTERY_CONFIG_FILE),\
Nirnimesh 2011/06/06 18:09:01 nit: put a space before \ Repeat elsewhere in this
xot 2011/06/10 01:36:33 Done.
+ 'Power Strip configuration file does not exist.'
+ power_config = pyauto.PyUITest.EvalDataFrom(
+ ChromeosBattery._BATTERY_CONFIG_FILE)
+ self._power_strip = PowerStrip(power_config['strip_ip'])
+ self._outlet_battery_full = (power_config['configs']
+ ['battery_full']
+ ['outlet_id'])
+
+ def BatteryPowerAndChargeStateAgree(self, ac_power_on, time_key):
+ battery_status = self.GetBatteryInfo()
+ return ((battery_status.get('line_power_on') == ac_power_on) and
Nirnimesh 2011/06/06 18:09:01 nit: remove extra parens. You don't need any paren
xot 2011/06/10 01:36:33 Done.
+ (battery_status.get(time_key) != None))
Nirnimesh 2011/06/06 18:09:01 '!= None' is redundant
dtu 2011/06/06 21:06:58 No, it should be "time_key in battery_status". 0 i
xot 2011/06/10 01:36:33 replaced with "time_key in battery_status"
xot 2011/06/10 01:36:33 replaced with "time_key in battery_status"
+
+ def testBatteryChargesWhenACisOn(self):
+ """AC power ON to CrOS device with battery."""
+ self._power_strip.PowerOn(self._outlet_battery_full)
+
+ # Get info about charging battery
+ assert self.WaitUntil(lambda: self.BatteryPowerAndChargeStateAgree(
+ True, 'battery_time_to_full'), timeout=60, retry_sleep=1),\
Nirnimesh 2011/06/06 18:09:01 Isn't the default timeout (~25 secs) not enough?
dtu 2011/06/06 21:06:58 You can pull this entire WaitUntil thing out to a
dtu 2011/06/06 21:06:58 scunningham said he's seen it take up to 40s, so 6
xot 2011/06/10 01:36:33 Okay, but only if you don't complain about me crea
xot 2011/06/10 01:36:33 Done.
xot 2011/06/10 01:36:33 Nope.
+ 'Battery charge time was not calculated.'
+ battery_status = self.GetBatteryInfo()
+ self.assertTrue(battery_status.get('battery_is_present'),
+ msg='Battery is not present.')
+ self.assertTrue(battery_status.get('line_power_on'),
+ msg='Line power is off.')
+ self.assertTrue(battery_status.get('battery_time_to_full') >= 0,
+ msg='Battery charge time is negative.')
+
+ def testBatteryDischargesWhenACisOff(self):
+ """AC power OFF to CrOS device with battery."""
+ self._power_strip.PowerOff(self._outlet_battery_full)
+
+ # Get info about discharging battery
+ assert self.WaitUntil(lambda: self.BatteryPowerAndChargeStateAgree(
+ False, 'battery_time_to_empty'), timeout=60, retry_sleep=1),\
+ 'Battery discharge time was not calculated.'
+ battery_status = self.GetBatteryInfo()
+ self.assertTrue(battery_status.get('battery_is_present'),
+ msg='Battery is not present.')
+ self.assertFalse(battery_status.get('line_power_on'),
+ msg='Line power is off.')
stanleyw 2011/06/06 20:54:50 Do you mean line power is on?
xot 2011/06/10 01:36:33 Good catch!
+ self.assertTrue(battery_status.get('battery_time_to_empty') >= 0,
+ msg='Battery discharge time is negative.')
+
+ def testBatteryTimesAreDifferent(self):
+ """Time to full is different than Time to empty"""
+ # Turn AC Power ON
+ self._power_strip.PowerOn(self._outlet_battery_full)
+
+ # Get charging battery time to full
+ assert self.WaitUntil(lambda: self.BatteryPowerAndChargeStateAgree(
+ True, 'battery_time_to_full'), timeout=60, retry_sleep=1),\
+ 'Battery charge time was not calculated.'
+ battery_status = self.GetBatteryInfo()
+ time_to_full = battery_status.get('battery_time_to_full')
+
+ # Turn AC Power OFF
+ self._power_strip.PowerOff(self._outlet_battery_full)
+
+ # Get discharging battery time to empty
+ assert self.WaitUntil(lambda: self.BatteryPowerAndChargeStateAgree(
+ False, 'battery_time_to_empty'), timeout=60, retry_sleep=1),\
+ 'Battery discharge time was not calculated.'
+ battery_status = self.GetBatteryInfo()
+ time_to_empty = battery_status.get('battery_time_to_empty')
+
+ # Compare times
stanleyw 2011/06/06 20:54:50 Maybe explain why you are comparing the times.
+ self.assertNotEqual(time_to_full, time_to_empty,
+ msg='Battery time to full equals time to empty. '
+ 'Though very unlikely, this is not impossible. '
+ 'If test failed falsely, Kris owes Scott a beer. ')
stanleyw 2011/06/06 20:54:50 Nice!
dtu 2011/06/06 21:06:58 Extra space after the last period.
xot 2011/06/10 01:36:33 Done.
xot 2011/06/10 01:36:33 Done.
+
+
+if __name__ == '__main__':
+ pyauto_functional.Main()
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698