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

Side by Side Diff: client/site_tests/power_Draw/power_Draw.py

Issue 6800002: power_Draw/Idle/LoadTest: Support temperature sensing for x86 (Closed) Base URL: ssh://git@gitrw.chromium.org:9222/autotest.git
Patch Set: Added temp logging during each query Created 9 years, 8 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 | Annotate | Revision Log
« no previous file with comments | « client/cros/power_status.py ('k') | client/site_tests/power_Idle/power_Idle.py » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 # Copyright (c) 2010 The Chromium OS Authors. All rights reserved. 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 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 import logging, time 5 import logging, time
6 from autotest_lib.client.bin import test 6 from autotest_lib.client.bin import test
7 from autotest_lib.client.cros import power_status 7 from autotest_lib.client.cros import power_status
8 8
9 9
10 class power_Draw(test.test): 10 class power_Draw(test.test):
11 version = 1 11 version = 1
12 12
13 13
14 def run_once(self, seconds=200): 14 def run_once(self, seconds=200, sleep=10):
15 status = power_status.get_status() 15 status = power_status.get_status()
16 if status.linepower[0].online: 16 if status.linepower[0].online:
17 logging.warn('AC power is online -- ' 17 logging.warn('AC power is online -- '
18 'unable to monitor energy consumption') 18 'unable to monitor energy consumption')
19 return 19 return
20 20
21 start_energy = status.battery[0].energy 21 start_energy = status.battery[0].energy
22 22
23 # Let the test run 23 # Let the test run
24 time.sleep(seconds) 24 for i in range(0, seconds, sleep):
25 time.sleep(sleep)
26 status.refresh()
25 27
26 status.refresh() 28 status.refresh()
27 end_energy = status.battery[0].energy 29 end_energy = status.battery[0].energy
28 30
29 consumed_energy = start_energy - end_energy 31 consumed_energy = start_energy - end_energy
30 energy_rate = consumed_energy * 60 * 60 / seconds 32 energy_rate = consumed_energy * 60 * 60 / seconds
31 33
32 keyvals = {} 34 keyvals = {}
33 keyvals['wh_energy_full'] = status.battery[0].energy_full 35 keyvals['wh_energy_full'] = status.battery[0].energy_full
34 keyvals['wh_start_energy'] = start_energy 36 keyvals['wh_start_energy'] = start_energy
35 keyvals['wh_end_energy'] = end_energy 37 keyvals['wh_end_energy'] = end_energy
36 keyvals['wh_consumed_energy'] = consumed_energy 38 keyvals['wh_consumed_energy'] = consumed_energy
37 keyvals['w_average_energy_rate'] = energy_rate 39 keyvals['w_average_energy_rate'] = energy_rate
38 keyvals['w_end_energy_rate'] = status.battery[0].energy_rate 40 keyvals['w_end_energy_rate'] = status.battery[0].energy_rate
41 keyvals['mc_min_temp'] = status.min_temp
42 keyvals['mc_max_temp'] = status.max_temp
43
39 self.write_perf_keyval(keyvals) 44 self.write_perf_keyval(keyvals)
OLDNEW
« no previous file with comments | « client/cros/power_status.py ('k') | client/site_tests/power_Idle/power_Idle.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698