| # Copyright 2013 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. |
| |
| |
| class SystemProperties(dict): |
| |
| """A dict interface to interact with device system properties. |
| |
| System properties are key/value pairs as exposed by adb shell getprop/setprop. |
| |
| This implementation minimizes interaction with the physical device. It is |
| valid for the lifetime of a boot. |
| """ |
| |
| def __init__(self, android_commands): |
| super(SystemProperties, self).__init__() |
| self._adb = android_commands |
| self._cached_static_properties = {} |
| |
| def __getitem__(self, key): |
| if self._IsStatic(key): |
| if key not in self._cached_static_properties: |
| self._cached_static_properties[key] = self._GetProperty(key) |
| return self._cached_static_properties[key] |
| return self._GetProperty(key) |
| |
| def __setitem__(self, key, value): |
| # TODO(tonyg): This can fail with no root. Verify that it succeeds. |
| self._adb.SendShellCommand('setprop %s "%s"' % (key, value), retry_count=3) |
| |
| @staticmethod |
| def _IsStatic(key): |
| # TODO(tonyg): This list is conservative and could be expanded as needed. |
| return (key.startswith('ro.boot.') or |
| key.startswith('ro.build.') or |
| key.startswith('ro.product.')) |
| |
| def _GetProperty(self, key): |
| return self._adb.SendShellCommand('getprop %s' % key, retry_count=3).strip() |