1# Copyright (c) 2010 The Chromium OS Authors. All rights reserved. 2# Use of this source code is governed by a BSD-style license that can be 3# found in the LICENSE file. 4 5import logging, time 6from autotest_lib.client.bin import test 7from autotest_lib.client.bin import utils 8from autotest_lib.client.cros.power import power_status 9 10 11class power_Draw(test.test): 12 version = 1 13 14 15 def run_once(self, seconds=200, sleep=10): 16 status = power_status.get_status() 17 if status.on_ac(): 18 logging.warning('AC power is online -- ' 19 'unable to monitor energy consumption') 20 return 21 22 # If powerd is running, stop it, so that it cannot interfere with the 23 # backlight adjustments in this test. 24 if utils.system_output('status powerd').find('start/running') != -1: 25 powerd_running = True 26 utils.system_output('stop powerd') 27 else: 28 powerd_running = False 29 30 start_energy = status.battery[0].energy 31 self._tlog = power_status.TempLogger([], seconds_period=sleep) 32 self._tlog.start() 33 34 # Let the test run 35 for i in range(0, seconds, sleep): 36 time.sleep(sleep) 37 status.refresh() 38 39 status.refresh() 40 end_energy = status.battery[0].energy 41 42 consumed_energy = start_energy - end_energy 43 energy_rate = consumed_energy * 60 * 60 / seconds 44 45 keyvals = self._tlog.calc() 46 keyvals['wh_energy_full'] = status.battery[0].energy_full 47 keyvals['wh_start_energy'] = start_energy 48 keyvals['wh_end_energy'] = end_energy 49 keyvals['wh_consumed_energy'] = consumed_energy 50 keyvals['w_average_energy_rate'] = energy_rate 51 keyvals['w_end_energy_rate'] = status.battery[0].energy_rate 52 53 self.write_perf_keyval(keyvals) 54 55 # Restore powerd if it was originally running. 56 if powerd_running: 57 utils.system_output('start powerd'); 58