From 2a9647725163bcc89bb15c0a3545253836ce33ed Mon Sep 17 00:00:00 2001 From: Maryam Huntsperger Date: Thu, 18 Apr 2024 06:42:55 -0700 Subject: [PATCH] Add modifiers support for keypress --- internal/devtools.py | 18 ++++++++++-------- internal/devtools_browser.py | 13 ++++++++++++- 2 files changed, 22 insertions(+), 9 deletions(-) diff --git a/internal/devtools.py b/internal/devtools.py index c1645e230..751f91354 100644 --- a/internal/devtools.py +++ b/internal/devtools.py @@ -1313,7 +1313,7 @@ def key_info(self, key): info['text'] = definition['text'] return info - def key_down(self, key): + def key_down(self, key, modifier): """Press down a key""" info = self.key_info(key) params = { @@ -1321,7 +1321,8 @@ def key_down(self, key): 'key': info['key'], 'windowsVirtualKeyCode': info['keyCode'], 'code': info['code'], - 'location': info['location'] + 'location': info['location'], + 'modifiers': modifier } if 'text' in info: params['type'] = 'keyDown' @@ -1331,7 +1332,7 @@ def key_down(self, key): params['isKeypad'] = True self.send_command('Input.dispatchKeyEvent', params) - def key_up(self, key): + def key_up(self, key, modifier): """Let up a key""" info = self.key_info(key) self.send_command('Input.dispatchKeyEvent', { @@ -1339,14 +1340,15 @@ def key_up(self, key): 'key': info['key'], 'windowsVirtualKeyCode': info['keyCode'], 'code': info['code'], - 'location': info['location'] + 'location': info['location'], + 'modifiers': modifier }) - def keypress(self, key): + def keypress(self, key, modifier): """Simulate pressing a keyboard key""" try: - self.key_down(key) - self.key_up(key) + self.key_down(key, modifier) + self.key_up(key, modifier) except Exception: logging.exception('Error running keypress command') @@ -1355,7 +1357,7 @@ def type_text(self, string): try: for char in string: if char in self.key_definitions: - self.keypress(char) + self.keypress(char, 0) else: self.send_character(char) except Exception: diff --git a/internal/devtools_browser.py b/internal/devtools_browser.py index 0049b53c2..77b230f64 100644 --- a/internal/devtools_browser.py +++ b/internal/devtools_browser.py @@ -30,6 +30,11 @@ import json from .optimization_checks import OptimizationChecks +KeyModifiers = { + "ALT": 1, + "CTRL": 2, + "SHIFT": 8 +} class DevtoolsBrowser(object): """Devtools Browser base""" @@ -765,7 +770,13 @@ def process_command(self, command): elif command['command'] == 'type': self.devtools.type_text(command['target']) elif command['command'] == 'keypress': - self.devtools.keypress(command['target']) + modifier = 0 + value = command['value'] + if value is not None: + keyModifier = value.upper() + if keyModifier in KeyModifiers.keys(): + modifier = KeyModifiers[keyModifier] + self.devtools.keypress(command['target'], modifier) elif command['command'] == 'waitfor': try: self.devtools.wait_for_script = command['target'] if command['target'] else None