From 6b4be0c9c2fde717cb16fdd399d2b5b186f57a5e Mon Sep 17 00:00:00 2001 From: Joshua Fehler Date: Tue, 11 Jun 2024 11:20:50 -0400 Subject: [PATCH] Add keyboard class and Element.press() --- docs/index.rst | 1 + docs/keyboard.rst | 99 ++++++++++++++++++++ splinter/driver/__init__.py | 14 +++ splinter/driver/webdriver/__init__.py | 6 ++ splinter/driver/webdriver/keyboard.py | 122 +++++++++++++++++++++++++ tests/static/index.html | 16 ++++ tests/tests_webdriver/test_keyboard.py | 66 +++++++++++++ 7 files changed, 324 insertions(+) create mode 100644 docs/keyboard.rst create mode 100644 splinter/driver/webdriver/keyboard.py create mode 100644 tests/tests_webdriver/test_keyboard.py diff --git a/docs/index.rst b/docs/index.rst index 30c857991..7146506a7 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -38,6 +38,7 @@ cookies screenshot javascript + keyboard selenium-keys iframes-and-alerts http-status-code-and-exception diff --git a/docs/keyboard.rst b/docs/keyboard.rst new file mode 100644 index 000000000..620daacf9 --- /dev/null +++ b/docs/keyboard.rst @@ -0,0 +1,99 @@ +.. Copyright 2024 splinter authors. All rights reserved. + Use of this source code is governed by a BSD-style + license that can be found in the LICENSE file. + +.. meta:: + :description: Keyboard + :keywords: splinter, python, tutorial, documentation, selenium integration, selenium keys, keyboard events + +++++++++ +Keyboard +++++++++ + +The browser provides an interface for using the keyboard. + +However, input is limited to the page. You cannot control the browser or your +operating system using this. + +Down +---- + +Hold a key down. + +.. code-block:: python + + from splinter import Browser + + + browser = Browser() + browser.visit("https://duckduckgo.com/") + browser.keyboard.down("CONTROL") + + +Up +-- + +Release a key. If the key is not held down, this will do nothing. + +.. code-block:: python + + from splinter import Browser + + + browser = Browser() + browser.visit("https://duckduckgo.com/") + browser.keyboard.down("CONTROL") + browser.keyboard.up("CONTROL") + + +Press +----- + +Hold and then release a key pattern. + +.. code-block:: python + + from splinter import Browser + + + browser = Browser() + browser.visit("https://duckduckgo.com/") + browser.keyboard.press("CONTROL") + +Key patterns are keys separated by the '+' symbol. +This allows multiple presses to be chained together: + +.. code-block:: python + + from splinter import Browser + + + browser = Browser() + browser.visit("https://duckduckgo.com/") + browser.keyboard.press("CONTROL+a") + +.. warning:: + Although a key pattern such as "SHIFT+awesome" will be accepted, + the press method is designed for single keys. There may be unintended + side effects to using it in place of Element.fill() or Element.type(). + +Element.press() +~~~~~~~~~~~~~~~ + +Elements can be pressed directly. + +.. code-block:: python + + from splinter import Browser + + + browser = Browser() + browser.visit("https://duckduckgo.com/") + elem = browser.find_by_css("#searchbox_input") + elem.fill("splinter python") + elem.press("ENTER") + + results = browser.find_by_xpath("//section[@data-testid='mainline']/ol/li") + + # Open in a new tab behind the current one. + results.first.press("CONTROL+ENTER") diff --git a/splinter/driver/__init__.py b/splinter/driver/__init__.py index a57ea263f..44f8fed7c 100644 --- a/splinter/driver/__init__.py +++ b/splinter/driver/__init__.py @@ -871,6 +871,20 @@ def type(self, value: str, slowly: bool = False) -> str: # NOQA: A003 """ raise NotImplementedError + def press(self, key_pattern: str, delay: int = 0) -> None: + """Focus the element, hold, and then release the specified key pattern. + + Arguments: + key_pattern: Pattern of keys to hold and release. + delay: Time, in seconds, to wait between key down and key up. + + Example: + + >>> browser.find_by_css('.my_element').press('CONTROL+a') + + """ + raise NotImplementedError + def select(self, value: str, slowly: bool = False) -> None: """ Select an ``