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

Side by Side Diff: build/android/pylib/device/device_utils.py

Issue 1040473002: [android] Create Battery Utils to seperate power functionality (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 9 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 unified diff | Download patch
OLDNEW
1 # Copyright 2014 The Chromium Authors. All rights reserved. 1 # Copyright 2014 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 """Provides a variety of device interactions based on adb. 5 """Provides a variety of device interactions based on adb.
6 6
7 Eventually, this will be based on adb_wrapper. 7 Eventually, this will be based on adb_wrapper.
8 """ 8 """
9 # pylint: disable=unused-argument 9 # pylint: disable=unused-argument
10 10
(...skipping 1420 matching lines...) Expand 10 before | Expand all | Expand 10 after
1431 1431
1432 Parameters passed to this function are passed directly to 1432 Parameters passed to this function are passed directly to
1433 |logcat_monitor.LogcatMonitor| and are documented there. 1433 |logcat_monitor.LogcatMonitor| and are documented there.
1434 1434
1435 Args: 1435 Args:
1436 timeout: timeout in seconds 1436 timeout: timeout in seconds
1437 retries: number of retries 1437 retries: number of retries
1438 """ 1438 """
1439 return logcat_monitor.LogcatMonitor(self.adb, *args, **kwargs) 1439 return logcat_monitor.LogcatMonitor(self.adb, *args, **kwargs)
1440 1440
1441 # TODO(rnephew): Remove when battery_utils is switched to.
1441 @decorators.WithTimeoutAndRetriesFromInstance() 1442 @decorators.WithTimeoutAndRetriesFromInstance()
1442 def GetBatteryInfo(self, timeout=None, retries=None): 1443 def GetBatteryInfo(self, timeout=None, retries=None):
1443 """Gets battery info for the device. 1444 """Gets battery info for the device.
1444 1445
1445 Args: 1446 Args:
1446 timeout: timeout in seconds 1447 timeout: timeout in seconds
1447 retries: number of retries 1448 retries: number of retries
1448 Returns: 1449 Returns:
1449 A dict containing various battery information as reported by dumpsys 1450 A dict containing various battery information as reported by dumpsys
1450 battery. 1451 battery.
1451 """ 1452 """
1452 result = {} 1453 result = {}
1453 # Skip the first line, which is just a header. 1454 # Skip the first line, which is just a header.
1454 for line in self.RunShellCommand( 1455 for line in self.RunShellCommand(
1455 ['dumpsys', 'battery'], check_return=True)[1:]: 1456 ['dumpsys', 'battery'], check_return=True)[1:]:
1456 # If usb charging has been disabled, an extra line of header exists. 1457 # If usb charging has been disabled, an extra line of header exists.
1457 if 'UPDATES STOPPED' in line: 1458 if 'UPDATES STOPPED' in line:
1458 logging.warning('Dumpsys battery not receiving updates. ' 1459 logging.warning('Dumpsys battery not receiving updates. '
1459 'Run dumpsys battery reset if this is in error.') 1460 'Run dumpsys battery reset if this is in error.')
1460 elif ':' not in line: 1461 elif ':' not in line:
1461 logging.warning('Unknown line found in dumpsys battery.') 1462 logging.warning('Unknown line found in dumpsys battery.')
1462 logging.warning(line) 1463 logging.warning(line)
1463 else: 1464 else:
1464 k, v = line.split(': ', 1) 1465 k, v = line.split(': ', 1)
1465 result[k.strip()] = v.strip() 1466 result[k.strip()] = v.strip()
1466 return result 1467 return result
1467 1468
1469 # TODO(rnephew): Remove when battery_utils is switched to.
1468 @decorators.WithTimeoutAndRetriesFromInstance() 1470 @decorators.WithTimeoutAndRetriesFromInstance()
1469 def GetCharging(self, timeout=None, retries=None): 1471 def GetCharging(self, timeout=None, retries=None):
1470 """Gets the charging state of the device. 1472 """Gets the charging state of the device.
1471 1473
1472 Args: 1474 Args:
1473 timeout: timeout in seconds 1475 timeout: timeout in seconds
1474 retries: number of retries 1476 retries: number of retries
1475 Returns: 1477 Returns:
1476 True if the device is charging, false otherwise. 1478 True if the device is charging, false otherwise.
1477 """ 1479 """
1478 battery_info = self.GetBatteryInfo() 1480 battery_info = self.GetBatteryInfo()
1479 for k in ('AC powered', 'USB powered', 'Wireless powered'): 1481 for k in ('AC powered', 'USB powered', 'Wireless powered'):
1480 if (k in battery_info and 1482 if (k in battery_info and
1481 battery_info[k].lower() in ('true', '1', 'yes')): 1483 battery_info[k].lower() in ('true', '1', 'yes')):
1482 return True 1484 return True
1483 return False 1485 return False
1484 1486
1487 # TODO(rnephew): Remove when battery_utils is switched to.
1485 @decorators.WithTimeoutAndRetriesFromInstance() 1488 @decorators.WithTimeoutAndRetriesFromInstance()
1486 def SetCharging(self, enabled, timeout=None, retries=None): 1489 def SetCharging(self, enabled, timeout=None, retries=None):
1487 """Enables or disables charging on the device. 1490 """Enables or disables charging on the device.
1488 1491
1489 Args: 1492 Args:
1490 enabled: A boolean indicating whether charging should be enabled or 1493 enabled: A boolean indicating whether charging should be enabled or
1491 disabled. 1494 disabled.
1492 timeout: timeout in seconds 1495 timeout: timeout in seconds
1493 retries: number of retries 1496 retries: number of retries
1494 """ 1497 """
(...skipping 10 matching lines...) Expand all
1505 command = self._cache['charging_config']['enable_command'] 1508 command = self._cache['charging_config']['enable_command']
1506 else: 1509 else:
1507 command = self._cache['charging_config']['disable_command'] 1510 command = self._cache['charging_config']['disable_command']
1508 1511
1509 def set_and_verify_charging(): 1512 def set_and_verify_charging():
1510 self.RunShellCommand(command, check_return=True) 1513 self.RunShellCommand(command, check_return=True)
1511 return self.GetCharging() == enabled 1514 return self.GetCharging() == enabled
1512 1515
1513 timeout_retry.WaitFor(set_and_verify_charging, wait_period=1) 1516 timeout_retry.WaitFor(set_and_verify_charging, wait_period=1)
1514 1517
1515 # TODO(rnephew): Make private when all use cases can use the context manager. 1518 # TODO(rnephew): Remove when battery_utils is switched to.
1516 @decorators.WithTimeoutAndRetriesFromInstance() 1519 @decorators.WithTimeoutAndRetriesFromInstance()
1517 def DisableBatteryUpdates(self, timeout=None, retries=None): 1520 def DisableBatteryUpdates(self, timeout=None, retries=None):
1518 """ Resets battery data and makes device appear like it is not 1521 """ Resets battery data and makes device appear like it is not
1519 charging so that it will collect power data since last charge. 1522 charging so that it will collect power data since last charge.
1520 1523
1521 Args: 1524 Args:
1522 timeout: timeout in seconds 1525 timeout: timeout in seconds
1523 retries: number of retries 1526 retries: number of retries
1524 """ 1527 """
1525 def battery_updates_disabled(): 1528 def battery_updates_disabled():
1526 return self.GetCharging() is False 1529 return self.GetCharging() is False
1527 1530
1528 self.RunShellCommand( 1531 self.RunShellCommand(
1529 ['dumpsys', 'batterystats', '--reset'], check_return=True) 1532 ['dumpsys', 'batterystats', '--reset'], check_return=True)
1530 battery_data = self.RunShellCommand( 1533 battery_data = self.RunShellCommand(
1531 ['dumpsys', 'batterystats', '--charged', '--checkin'], 1534 ['dumpsys', 'batterystats', '--charged', '--checkin'],
1532 check_return=True) 1535 check_return=True)
1533 ROW_TYPE_INDEX = 3 1536 ROW_TYPE_INDEX = 3
1534 PWI_POWER_INDEX = 5 1537 PWI_POWER_INDEX = 5
1535 for line in battery_data: 1538 for line in battery_data:
1536 l = line.split(',') 1539 l = line.split(',')
1537 if (len(l) > PWI_POWER_INDEX and l[ROW_TYPE_INDEX] == 'pwi' 1540 if (len(l) > PWI_POWER_INDEX and l[ROW_TYPE_INDEX] == 'pwi'
1538 and l[PWI_POWER_INDEX] != 0): 1541 and l[PWI_POWER_INDEX] != 0):
1539 raise device_errors.CommandFailedError( 1542 raise device_errors.CommandFailedError(
1540 'Non-zero pmi value found after reset.') 1543 'Non-zero pmi value found after reset.')
1541 self.RunShellCommand(['dumpsys', 'battery', 'set', 'usb', '0'], 1544 self.RunShellCommand(['dumpsys', 'battery', 'set', 'usb', '0'],
1542 check_return=True) 1545 check_return=True)
1543 timeout_retry.WaitFor(battery_updates_disabled, wait_period=1) 1546 timeout_retry.WaitFor(battery_updates_disabled, wait_period=1)
1544 1547
1545 # TODO(rnephew): Make private when all use cases can use the context manager. 1548 # TODO(rnephew): Remove when battery_utils is switched to.
1546 @decorators.WithTimeoutAndRetriesFromInstance() 1549 @decorators.WithTimeoutAndRetriesFromInstance()
1547 def EnableBatteryUpdates(self, timeout=None, retries=None): 1550 def EnableBatteryUpdates(self, timeout=None, retries=None):
1548 """ Restarts device charging so that dumpsys no longer collects power data. 1551 """ Restarts device charging so that dumpsys no longer collects power data.
1549 1552
1550 Args: 1553 Args:
1551 timeout: timeout in seconds 1554 timeout: timeout in seconds
1552 retries: number of retries 1555 retries: number of retries
1553 """ 1556 """
1554 def battery_updates_enabled(): 1557 def battery_updates_enabled():
1555 return self.GetCharging() is True 1558 return self.GetCharging() is True
1556 1559
1557 self.RunShellCommand(['dumpsys', 'battery', 'set', 'usb', '1'], 1560 self.RunShellCommand(['dumpsys', 'battery', 'set', 'usb', '1'],
1558 check_return=True) 1561 check_return=True)
1559 self.RunShellCommand(['dumpsys', 'battery', 'reset'], check_return=True) 1562 self.RunShellCommand(['dumpsys', 'battery', 'reset'], check_return=True)
1560 timeout_retry.WaitFor(battery_updates_enabled, wait_period=1) 1563 timeout_retry.WaitFor(battery_updates_enabled, wait_period=1)
1561 1564
1565 # TODO(rnephew): Remove when battery_utils is switched to.
1562 @contextlib.contextmanager 1566 @contextlib.contextmanager
1563 def BatteryMeasurement(self, timeout=None, retries=None): 1567 def BatteryMeasurement(self, timeout=None, retries=None):
1564 """Context manager that enables battery data collection. It makes 1568 """Context manager that enables battery data collection. It makes
1565 the device appear to stop charging so that dumpsys will start collecting 1569 the device appear to stop charging so that dumpsys will start collecting
1566 power data since last charge. Once the with block is exited, charging is 1570 power data since last charge. Once the with block is exited, charging is
1567 resumed and power data since last charge is no longer collected. 1571 resumed and power data since last charge is no longer collected.
1568 1572
1569 Only for devices L and higher. 1573 Only for devices L and higher.
1570 1574
1571 Example usage: 1575 Example usage:
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after
1641 """ 1645 """
1642 if not devices: 1646 if not devices:
1643 devices = adb_wrapper.AdbWrapper.GetDevices() 1647 devices = adb_wrapper.AdbWrapper.GetDevices()
1644 if not devices: 1648 if not devices:
1645 raise device_errors.NoDevicesError() 1649 raise device_errors.NoDevicesError()
1646 devices = [d if isinstance(d, cls) else cls(d) for d in devices] 1650 devices = [d if isinstance(d, cls) else cls(d) for d in devices]
1647 if async: 1651 if async:
1648 return parallelizer.Parallelizer(devices) 1652 return parallelizer.Parallelizer(devices)
1649 else: 1653 else:
1650 return parallelizer.SyncParallelizer(devices) 1654 return parallelizer.SyncParallelizer(devices)
1655
1656 # TODO(rnephew): Implement cache class.
1657 def GetCacheEntry(self, key):
perezju 2015/03/30 11:05:23 I'm not sure I like this idea. Why would a class e
jbudorick 2015/03/30 13:35:03 BatteryUtils doesn't know how to control the lifet
rnephew (Wrong account) 2015/03/30 17:50:29 It will use this when it stops passing the calls t
1658 """Cache getter."""
1659 return self._cache.get(key)
1660
1661 def SetCacheEntry(self, key, value, override=False):
1662 """Cache setter."""
1663 if key not in self._cache:
1664 self._cache[key] = value
1665 elif override and value != self._cache[key]:
1666 logging.warning('%s already in cache. Overriding %s with %s.', key,
1667 self._cache[key], value)
1668 self._cache[key] = value
1669 else:
1670 logging.warning('%s already in cache. Not overriding %s with %s.', key,
1671 self._cache[key], value)
OLDNEW
« build/android/pylib/device/battery_utils.py ('K') | « build/android/pylib/device/device_errors.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698