
Security News
MCP Community Begins Work on Official MCP Metaregistry
The MCP community is launching an official registry to standardize AI tool discovery and let agents dynamically find and install MCP servers.
.. image:: https://badges.gitter.im/pytest-dev/pytest-splinter.svg :alt: Join the chat at https://gitter.im/pytest-dev/pytest-splinter :target: https://gitter.im/pytest-dev/pytest-splinter?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge
.. image:: https://img.shields.io/pypi/v/pytest-splinter.svg :target: https://pypi.python.org/pypi/pytest-splinter .. image:: https://img.shields.io/pypi/pyversions/pytest-splinter.svg :target: https://pypi.python.org/pypi/pytest-splinter .. image:: https://img.shields.io/coveralls/pytest-dev/pytest-splinter/master.svg :target: https://coveralls.io/r/pytest-dev/pytest-splinter .. image:: https://github.com/pytest-dev/pytest-splinter/actions/workflows/tests.yml/badge.svg :target: https://github.com/pytest-dev/pytest-splinter/actions .. image:: https://readthedocs.org/projects/pytest-splinter/badge/?version=latest :target: https://readthedocs.org/projects/pytest-splinter/?badge=latest :alt: Documentation Status
::
pip install pytest-splinter
The plugin provides a set of fixtures to use splinter <https://splinter.readthedocs.io>
_
for browser testing with pytest <http://pytest.org>
_
browser
Get the splinter's Browser. Fixture is underneath session scoped, so browser process is started
once per test session, but the state of the browser will be clean (current page is blank
, cookies clean).
session_browser
The same as browser
except the lifetime. This fixture is session-scoped so will only be finalized at the
end of the whole test session. Useful if you want to speedup your test suite paying with reduced test isolation.
browser_instance_getter Function to create an instance of the browser. This fixture is required only if you need to have multiple instances of the Browser in a single test at the same time. Example of usage:
.. code-block:: python
@pytest.fixture
def admin_browser(request, browser_instance_getter):
"""Admin browser fixture."""
# browser_instance_getter function receives parent fixture -- our admin_browser
return browser_instance_getter(request, admin_browser)
def test_2_browsers(browser, admin_browser):
"""Test using 2 browsers at the same time."""
browser.visit('http://google.com')
admin_browser.visit('http://admin.example.com')
splinter_selenium_implicit_wait Implicit wait timeout to be passed to Selenium webdriver. Fixture gets the value from the command-line option splinter-implicit-wait (see below)
splinter_wait_time
Explicit wait timeout (for waiting for explicit condition via wait_for_condition
).
Fixture gets the value from the command-line option splinter-wait-time (see below)
splinter_selenium_speed Speed for Selenium, if not 0 then it will sleep between each selenium command. Useful for debugging/demonstration. Fixture gets the value from the command-line option splinter-speed (see below)
splinter_selenium_socket_timeout Socket timeout for communication between the webdriver and the browser. Fixture gets the value from the command-line option splinter-socket-timeout (see below)
splinter_webdriver
Splinter's webdriver name to use. Fixture gets the value from the command-line option
splinter-webdriver (see below). To make pytest-splinter always use certain webdriver, override a fixture
in your conftest.py
file:
.. code-block:: python
import pytest
@pytest.fixture(scope='session')
def splinter_webdriver():
"""Override splinter webdriver name."""
return 'chrome'
splinter_remote_url Splinter's webdriver remote url to use (optional). Fixture gets the value from the command-line option splinter-remote-url (see below). Will be used only if selected webdriver name is 'remote'.
splinter_session_scoped_browser pytest-splinter should use single browser instance per test session. Fixture gets the value from the command-line option splinter-session-scoped-browser (see below)
splinter_file_download_dir Directory, to which browser will automatically download the files it will experience during browsing. For example when you click on some download link. By default it's a temporary directory. Automatic downloading of files is only supported for firefox driver at the moment.
splinter_download_file_types Comma-separated list of content types to automatically download. By default it's the all known system mime types (via mimetypes standard library).
splinter_browser_load_condition Browser load condition, python function which should return True. If function returns False, it will be run several times, until timeout below reached.
splinter_browser_load_timeout Browser load condition timeout in seconds, after this timeout the exception WaitUntilTimeout will be raised.
splinter_wait_time Browser explicit wait timeout in seconds, after this timeout the exception WaitUntilTimeout will be raised.
splinter_firefox_profile_preferences Firefox profile preferences, a dictionary which is passed to selenium webdriver's profile_preferences
splinter_firefox_profile_directory Firefox profile directory to use as template for firefox profile created by selenium. By default, it's an empty directly inside pytest_splinter/profiles/firefox
splinter_driver_kwargs Webdriver keyword arguments, a dictionary which is passed to selenium webdriver's constructor (after applying firefox preferences)
.. code-block:: python
import pytest
from pathlib import Path
@pytest.fixture
def splinter_driver_kwargs():
"""
Webdriver kwargs for Firefox.
https://selenium-python.readthedocs.io/api.html#module-selenium.webdriver.firefox.webdriver
"""
return {"service_log_path": Path("/log/directory/geckodriver.log")}
The snippet below configures Chrome to ignore certificate errors and sets a specific window size
.. code-block:: python
import pytest
from selenium import webdriver
@pytest.fixture(scope='session')
def splinter_driver_kwargs():
"""Override Chrome WebDriver options"""
chrome_options = webdriver.ChromeOptions()
# List of Chromium Command Line Switches
# https://peter.sh/experiments/chromium-command-line-switches/
chrome_options.add_argument("--window-size=1440,1200")
chrome_options.add_argument("--ignore-ssl-errors=yes")
chrome_options.add_argument("--ignore-certificate-errors")
return {"options": chrome_options}
splinter_window_size Size of the browser window on browser initialization. Tuple in form (, ). Default is (1366, 768)
splinter_screenshot_dir
pytest-splinter browser screenshot directory.
This fixture gets the value from the command-line option
splinter-screenshot-dir
(see below).
splinter_make_screenshot_on_failure
Should pytest-splinter take browser screenshots on test failure?
This fixture gets the value from the command-line option
splinter-make-screenshot-on-failure
(see below).
splinter_screenshot_encoding
Encoding of the html
screenshot
on test failure. UTF-8 by default.
splinter_screenshot_getter_html
Function to get browser html screenshot. By default, it saves browser.html
with given path and
splinter_screenshot_encoding
encoding.
splinter_screenshot_getter_png
Function to get browser image (png) screenshot. By default, it calls browser.save_sceenshot
with given path.
splinter_driver_executable
Filesystem path of the webdriver executable.
This fixture gets the value from the command-line option
splinter-webdriver-executable
(see below).
splinter_browser_class
Class to use for browser instance.
Defaults to pytest_splinter.plugin.Browser
.
splinter_clean_cookies_urls List of additional urls to clean cookies on. By default, during the preparation of the browser for the test, pytest-splinter only cleans cookies for the last visited url from previous test, as it's not possible to clean all cookies from all domains at once via webdriver protocol, by design. This limitation can be worked around if you know the list of urls, the domains for which you need to clean cookies (for example https://facebook.com). If so, you can override this fixture and put those urls there, and pytest-splinter will visit each of them and will clean the cookies for each domain.
splinter_headless Run Chrome in headless mode. Defaults to false. http://splinter.readthedocs.io/en/latest/drivers/chrome.html#using-headless-option-for-chrome
--splinter-implicit-wait
Selenium webdriver implicit wait. Seconds (default: 5).
--splinter-speed
selenium webdriver speed (from command to command). Seconds (default: 0).
--splinter-socket-timeout
Selenium webdriver socket timeout for for communication between the webdriver and the browser.
Seconds (default: 120).
--splinter-webdriver
Webdriver name to use. (default: firefox). Options:
For more details refer to the documentation for splinter and selenium.
--splinter-remote-url
Webdriver remote url to use. (default: None). Will be used only if selected webdriver name is 'remote'.
For more details refer to the documentation for splinter and selenium.
--splinter-session-scoped-browser
pytest-splinter should use a single browser instance per test session.
Choices are 'true' or 'false' (default: 'true').
--splinter-make-screenshot-on-failure
pytest-splinter should take browser screenshots on test failure.
Choices are 'true' or 'false' (default: 'true').
--splinter-screenshot-dir
pytest-splinter browser screenshot directory. Defaults to the current
directory.
--splinter-webdriver-executable
Filesystem path of the webdriver executable. Used by chrome driver.
Defaults to the None in which case the shell PATH variable setting determines the location of the executable.
--splinter-headless
Override splinter_headless
fixture. Choices are 'true' or 'false', default: 'true'.
http://splinter.readthedocs.io/en/latest/drivers/chrome.html#using-headless-option-for-chrome
https://splinter.readthedocs.io/en/latest/drivers/firefox.html#using-headless-option-for-firefox
As mentioned above, browser is a fixture made by creating splinter's Browser object, but with some overrides.
visit Added possibility to wait for condition on each browser visit by having a fixture.
wait_for_condition Method copying selenium's wait_for_condition, with difference that condition is in python, so there you can do whatever you want, and not only execute javascript via browser.evaluate_script.
When your functional test fails, it's important to know the reason.
This becomes hard when tests are being run on the continuous integration server,
where you cannot debug (using --pdb).
To simplify things, a special behaviour of the browser fixture is available,
which takes a screenshot on test failure and puts it in a folder with the a
naming convention compatible to the
jenkins plugin <https://wiki.jenkins-ci.org/display/JENKINS/JUnit+Attachments+Plugin>
_.
The html content of the browser page is also stored, this can be useful for debugging the html source.
Creating screenshots is fully compatible with pytest-xdist plugin <https://pypi.python.org/pypi/pytest-xdist>
_ and will transfer the screenshots
from the worker nodes through the communication channel automatically.
If a test (using the browser fixture) fails, you should get a screenshot files in the following path:
::
<splinter-screenshot-dir>/my.dotted.name.test.package/test_name-browser.png
<splinter-screenshot-dir>/my.dotted.name.test.package/test_name-browser.html
The splinter-screenshot-dir
for storing the screenshot is generated by a
fixture and can be provided through a command line argument, as described above
at the configuration options section.
Taking screenshots on test failure is enabled by default. It can be controlled
through the splinter_make_screenshot_on_failure
fixture, where return False
skips it. You can also disable it via a command line argument:
::
pytest tests/functional --splinter-make-screenshot-on-failure=false
In case taking a screenshot fails, a pytest warning will be issued, which
can be viewed using the -rw
argument for pytest
.
Python3 is supported, check if you have recent version of splinter as it was added recently.
test_your_test.py:
.. code-block:: python
def test_some_browser_stuff(browser):
"""Test using real browser."""
url = "http://www.google.com"
browser.visit(url)
browser.fill('q', 'splinter - python acceptance testing for web applications')
# Find and click the 'search' button
button = browser.find_by_name('btnK')
# Interact with elements
button.click()
assert browser.is_text_present('splinter.cobrateam.info'), "splinter.cobrateam.info wasn't found... We need to"
' improve our SEO techniques'
If you have questions, bug reports, suggestions, etc. please create an issue on
the GitHub project page <http://github.com/paylogic/pytest-splinter>
_.
This software is licensed under the MIT license <http://en.wikipedia.org/wiki/MIT_License>
_
See License file <https://github.com/paylogic/pytest-splinter/blob/master/LICENSE.txt>
_
Ā© 2014 Anatoly Bubenkov, Paylogic International and others.
Anatoly Bubenkov <bubenkoff@gmail.com>
_
original idea and implementation, new features and improvements
These people have contributed to pytest-splinter
, in alphabetical order:
Alessio Bogon <youtux@github.com>
_Andreas Pelme <andreas@pelme.se>
_Andrey Makhnach <andrey.makhnach@gmail.com>
_Aymeric Augustin <https://myks.org/>
_Daniel Hahler <github@thequod.de>
_Hugo van Kemenade <https://github.com/hugovk/>
_Ionel Cristian MÄrieČ <contact@ionelmc.ro>
_Joshua Fehler <jsfehler@github.com>
_Laurence Rowe <l@lrowe.co.uk>
_Marco Buccini <markon@github.com>
_MichaÅ Pasternak <michal.dtz@gmail.com>
_Michel Sabchuk <michel@sabchuk.com.br>
_Mikko Ohtamaa <mikko@opensourcehacker.com>
_Oleg Pidsadnyi <oleg.pidsadnyi@gmail.com>
_Peter Lauri <peterlauri@gmail.com>
_Suresh V <sureshvv@github.com>
_TomÔŔ Ehrlich <tomas.ehrlich@gmail.com>
_Tony Narlock <tony@git-pull.com>
_splinter_headless
(mpasternak)--splinter-headless
without arguments defaults to 'true'
#123 <https://github.com/pytest-dev/pytest-splinter/pull/123>
_ (tony)#146 <https://github.com/pytest-dev/pytest-splinter/issues/146>
_
(michelts)#108 <https://github.com/pytest-dev/pytest-splinter/issues/108>
_ (jsfehler)Use getfixturevalue instead of getfuncargvalue #97 <https://github.com/pytest-dev/pytest-splinter/issues/97>
_ (pelme)
Added Chrome headless support (miohtama)
#94 <https://github.com/pytest-dev/pytest-splinter/issues/94>
_ (bubenkoff)#90 <https://github.com/pytest-dev/pytest-splinter/issues/90>
_) (pelme)switch_to
method (some selenium expected_conditions
are broken without
it, see #93 <https://github.com/pytest-dev/pytest-splinter/pull/93>
_)splinter_failure
always exists (bubenkoff, pelme)prepare_browser
(bubenkoff)--splinter-webdriver
(pelme)--splinter-wait-time
to specify splinter explicit wait timeout (pelme)splinter_selenium_implicit_wait
as wait_time
to splinter Browser (lrowe)browser_instance_getter
session scoped, add session_browser
fixture (bubenkoff, sureshvv)mouse_over
comparible with more use-cases (bubenkoff)FAQs
Splinter plugin for pytest testing framework
We found that pytest-splinter demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago.Ā It has 9 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The MCP community is launching an official registry to standardize AI tool discovery and let agents dynamically find and install MCP servers.
Research
Security News
Socket uncovers an npm Trojan stealing crypto wallets and BullX credentials via obfuscated code and Telegram exfiltration.
Research
Security News
Malicious npm packages posing as developer tools target macOS Cursor IDE users, stealing credentials and modifying files to gain persistent backdoor access.