1# -*- coding: utf-8 -*-
2# Copyright (c) 2010 The Chromium OS Authors. All rights reserved.
3# Use of this source code is governed by a BSD-style license that can be
4# found in the LICENSE file.
5
6
7import logging
8import os
9import re
10import time
11
12from autotest_lib.client.bin import test
13from autotest_lib.client.common_lib import error, utils
14
15
16_DPMS_DOWN = ['standby', 'suspend', 'stop']
17_LOG_CHECKLIST = ['Found device', 'CH7036 MCU ver']
18_SERVER = 'chrontel'
19_XENV = 'LD_LIBRARY_PATH=/usr/local/lib ' + \
20    'XAUTHORITY=/var/run/chromelogin.auth DISPLAY=:0'
21
22
23def run_cmd(cmd):
24    try:
25        cmd_out = utils.system_output(cmd, retain_output=True)
26    except error.CmdError, e:
27        logging.debug(e)
28        raise error.TestFail(cmd)
29    return cmd_out
30
31
32def check_server(server):
33    ups_str = run_cmd('initctl status %s' % (server))
34    ups_list = ups_str.strip().split()
35    if ups_list[1] != 'start/running,':
36        raise error.TestFail('%s not running :: %s' % (server, ups_list[1]))
37    return ups_list[3]
38
39
40def stress_server():
41    # Make sure it responds favorably to DPMS events
42    utils.assert_has_X_server()
43    for dpms_verb in _DPMS_DOWN:
44        run_cmd("%s xset dpms force %s" % (_XENV, dpms_verb))
45        time.sleep(5)
46        run_cmd("%s xset dpms force on" % (_XENV))
47        time.sleep(5)
48
49
50def check_log():
51    # two listings (stdout, stderr) + header
52    lsof_out = run_cmd('lsof -c /ch7036_monitor/ ' + \
53                           '-a -u root -a +D /var/log | tail -1')
54    if not lsof_out:
55        raise error.TestFail('Unable to locate logfile in lsof output')
56
57    lsof_list = lsof_out.rstrip().split()
58    log = lsof_list[8]
59    log.rstrip()
60    logging.debug('log = %s' % (log))
61    if not os.path.isfile(log):
62        raise error.TestFail('no log at %s' % (log))
63
64    fd = open(log)
65    found = dict((k, False) for k in _LOG_CHECKLIST)
66    found_cnt = 0
67    for ln in fd:
68        ln.rstrip()
69        for k in found:
70            if re.search(k, ln, re.I):
71                logging.debug(ln)
72                found[k] = True
73                found_cnt += 1
74        if found_cnt == len(found):
75            break
76
77    if found_cnt < len(found):
78        errs = ''
79        for k in found:
80            if not found[k]:
81                errs += "%s " % (k)
82        raise error.TestFail('Failed to validate log for %s' % (errs))
83    fd.close()
84    return log
85
86
87class hardware_ch7036(test.test):
88    version = 1
89
90
91    def run_once(self):
92        pid1 = check_server(_SERVER)
93        stress_server()
94        self._log = check_log()
95        pid2 = check_server(_SERVER)
96        logging.debug("pids %s %s" % (pid1, pid2))
97        if pid1 != pid2:
98            raise error.TestFail('Appears server %s restarted (%s != %s)' %
99                                 (_SERVER, pid1, pid2))
100