blob: 2bf7b95873bef56b185b8dcbd26946480a02f6bb [file] [log] [blame]
Kuo Jen Wei7f00bb32018-11-01 15:35:24 +08001# Copyright 2018 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
5'''Login with test account and display chart file using telemetry.'''
6
Kuo Jen Wei7f00bb32018-11-01 15:35:24 +08007import argparse
8import contextlib
9import logging
10import os
11import signal
Kuo Jen Wei987b7eb2020-05-28 15:39:45 +080012import sys
Kuo Jen Wei7f00bb32018-11-01 15:35:24 +080013import time
14
Kuo Jen Weidb663ea2020-03-13 16:39:15 +080015# Set chart process preferred logging format before overridden by importing
16# common package.
17logging.basicConfig(
18 level=logging.DEBUG,
19 format='%(asctime)s - %(levelname)s - %(message)s')
20
21# This sets up import paths for autotest.
22import common
Kuo Jen Wei7f00bb32018-11-01 15:35:24 +080023from autotest_lib.client.bin import utils
24from autotest_lib.client.common_lib.cros import chrome
25from autotest_lib.client.cros.input_playback import keyboard
26
27DISPLAY_LEVEL = 96.0
28
29
30@contextlib.contextmanager
31def set_display_brightness(display_level):
32 SET_BRIGHTNESS_CMD = 'backlight_tool --set_brightness_percent=%s'
33
34 original_display_level = utils.system_output(
35 'backlight_tool --get_brightness_percent')
36 logging.info('Save original display brightness %r '
37 'and fix display brightness to %r', original_display_level,
38 display_level)
39 utils.system(SET_BRIGHTNESS_CMD % display_level)
40 utils.system('stop powerd', ignore_status=True)
41 yield
42 logging.info('Restore display brightness %r', original_display_level)
43 utils.system('start powerd', ignore_status=True)
44 utils.system(SET_BRIGHTNESS_CMD % original_display_level)
45
46
47def display(filepath):
48 """Display chart with filepath on device by using telemetry."""
49 assert os.path.isfile(filepath), 'filepath %r not found.' % filepath
50 filepath = os.path.abspath(filepath)
51
52 logging.info('Setup SIGINT listener for stop displaying.')
53 displaying = [True]
54
55 def handler(signum, frame):
56 """Wait signal to clear running flag."""
57 if signum == signal.SIGINT:
58 displaying.pop()
59
60 signal.signal(signal.SIGINT, handler)
61
Kuo Jen Wei377e99b2020-02-25 16:39:42 +080062 with chrome.Chrome(init_network_controller=True
63 ) as cr, set_display_brightness(DISPLAY_LEVEL):
Kuo Jen Wei7f00bb32018-11-01 15:35:24 +080064 logging.info('Display chart file of path %r.', filepath)
Kuo Jen Wei377e99b2020-02-25 16:39:42 +080065 cr.browser.platform.SetHTTPServerDirectories(os.path.dirname(filepath))
Kuo Jen Wei7f00bb32018-11-01 15:35:24 +080066 tab = cr.browser.tabs[0]
Kuo Jen Wei377e99b2020-02-25 16:39:42 +080067 tab.Navigate(cr.browser.platform.http_server.UrlOf(filepath))
Kuo Jen Wei7f00bb32018-11-01 15:35:24 +080068
69 logging.info('Set chart tab fullscreen.')
70 kb = keyboard.Keyboard()
71 kb.press_key('f4')
72 kb.close()
73
Kuo Jen Weidb663ea2020-03-13 16:39:15 +080074 logging.info('Chart is ready.')
Kuo Jen Wei987b7eb2020-05-28 15:39:45 +080075
76 # Flush the 'is ready' message for server test to sync with ready state.
77 sys.stdout.flush()
78 sys.stderr.flush()
79
Kuo Jen Wei7f00bb32018-11-01 15:35:24 +080080 while displaying:
81 time.sleep(1)
82
83
84if __name__ == '__main__':
85 argparser = argparse.ArgumentParser(
86 description='Display chart file on chrome by using telemetry.'
87 ' Send SIGINT or keyboard interrupt to stop displaying.')
88 argparser.add_argument('filepath', help='Path of displayed chart file.')
89
90 args = argparser.parse_args()
91 display(args.filepath)