| # Copyright (c) 2010 The Chromium OS 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 time |
| from autotest_lib.client.bin import test, utils |
| from autotest_lib.client.common_lib import error |
| from autotest_lib.client.cros import power_status, power_utils |
| from autotest_lib.client.cros import service_stopper |
| from autotest_lib.client.cros.graphics import graphics_utils |
| |
| |
| class power_Backlight(test.test): |
| version = 1 |
| |
| |
| def initialize(self): |
| """Perform necessary initialization prior to test run. |
| |
| Private Attributes: |
| _backlight: power_utils.Backlight object |
| _services: service_stopper.ServiceStopper object |
| """ |
| super(power_Backlight, self).initialize() |
| self._backlight = None |
| self._services = service_stopper.ServiceStopper( |
| service_stopper.ServiceStopper.POWER_DRAW_SERVICES) |
| self._services.stop_services() |
| |
| |
| def run_once(self, delay=60, seconds=10, tries=20): |
| self._backlight = power_utils.Backlight() |
| |
| |
| # disable screen blanking. Stopping screen-locker isn't |
| # synchronous :(. Add a sleep for now, till powerd comes around |
| # and fixes all this for us. |
| # TODO(davidjames): Power manager should support this feature directly |
| time.sleep(5) |
| graphics_utils.screen_disable_blanking() |
| |
| status = power_status.get_status() |
| status.assert_battery_state(5) |
| |
| max_brightness = self._backlight.get_max_level() |
| if max_brightness < 4: |
| raise error.TestFail('Must have at least 5 backlight levels') |
| sysfs_max = self._get_highest_sysfs_max_brightness() |
| if max_brightness != sysfs_max: |
| raise error.TestFail(('Max brightness %d is not the highest ' + |
| 'possible |max_brightness|, which is %d') % |
| (max_brightness, sysfs_max)) |
| keyvals = {} |
| rates = [] |
| |
| levels = [0, 50, 100] |
| for i in levels: |
| self._backlight.set_percent(i) |
| time.sleep(delay) |
| this_rate = [] |
| for _ in range(tries): |
| time.sleep(seconds) |
| status.refresh() |
| this_rate.append(status.battery[0].energy_rate) |
| rate = min(this_rate) |
| keyvals['w_bl_%d_rate' % i] = rate |
| rates.append(rate) |
| self.write_perf_keyval(keyvals) |
| for i in range(1, len(levels)): |
| if rates[i] <= rates[i-1]: |
| raise error.TestFail('Turning up the backlight ' \ |
| 'should increase energy consumption') |
| |
| |
| def cleanup(self): |
| if self._backlight: |
| self._backlight.restore() |
| self._services.restore_services() |
| super(power_Backlight, self).cleanup() |
| |
| |
| def _get_highest_sysfs_max_brightness(self): |
| # Print |max_brightness| for all backlight sysfs directories, and return |
| # the highest of these max_brightness values. |
| cmd = 'cat /sys/class/backlight/*/max_brightness' |
| output = utils.system_output(cmd) |
| return max(map(int, output.split())) |