| # Copyright 2017 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 os |
| |
| from autotest_lib.client.common_lib import error |
| from autotest_lib.client.cros.input_playback import input_playback |
| |
| _KEYBOARD = 'keyboard' |
| _KEY_FILENAME = 'keyboard_%s' |
| |
| class Keyboard(object): |
| """An emulated keyboard device used for UI automation.""" |
| |
| def __init__(self): |
| """Prepare an emulated keyboard device.""" |
| self.dirname = os.path.dirname(__file__) |
| # Create an emulated keyboard device. |
| self.keyboard = input_playback.InputPlayback() |
| self.keyboard.emulate(input_type=_KEYBOARD) |
| self.keyboard.find_connected_inputs() |
| |
| def press_key(self, key): |
| """Replay the recorded key events if exists. |
| |
| @param key: the target key name, e.g. f1, f2, tab or combination of keys |
| 'alt+shift+i', 'ctrl+f5', etc. |
| |
| """ |
| event_file = os.path.join(self.dirname, _KEY_FILENAME % key) |
| if not os.path.exists(event_file): |
| raise error.TestError('No such key file keyboard_%s in %s' |
| % (key, self.dirname)) |
| self.keyboard.blocking_playback(filepath=event_file, |
| input_type=_KEYBOARD) |
| |
| def playback(self, event_file): |
| """Replay the specified key events file. |
| |
| @param event_file: the filename of the key events |
| |
| """ |
| self.keyboard.blocking_playback(filepath=event_file, |
| input_type=_KEYBOARD) |
| |
| def close(self): |
| """Clean up the files/handles created in the class.""" |
| if self.keyboard: |
| self.keyboard.close() |
| self.keyboard = None |
| |
| def __enter__(self): |
| """Allow usage in 'with' statements.""" |
| return self |
| |
| def __exit__(self, exc_type, exc_val, exc_tb): |
| """Release resources on completion of a 'with' statement.""" |
| self.close() |