Skip to main content

Python library to integrate axe and selenium for web accessibility testing.

Project description

axe-selenium-python integrates aXe and selenium to enable automated web accessibility testing.

License PyPI wheel Travis Issues

Requirements

You will need the following prerequisites in order to use axe-selenium-python:

Optional

  • tox

Installation

To install axe-selenium-python:

$ pip install axe-selenium-python

To install pytest-axe:

$ pip install pytest-axe

Usage

test_accessibility.py

import pytest

 @pytest.mark.nondestructive
 def test_header_accessibility(axe):
     violations = axe.run('header', None, 'critical')
     assert len(violations) == 0, axe.report(violations)

The above example runs aXe against only the content within the <header> tag, and filters for violations labeled critical.

The method axe.run() accepts three parameters: context, options, and impact.

For more information on context and options, view the aXe documentation here.

The third parameter, impact, allows you to filter violations by their impact level. The options are critical, serious and minor, with the default value set to None.

This will filter violations for the impact level specified, and all violations with a higher impact level.

To run the above test you will need to specify the browser instance to be invoked, and the base_url.

$ pytest --base-url http://www.mozilla.com --driver Firefox test_accessibility.py

Resources

CHANGELOG

version 1.2.1

  • Updated axe.min.js to latest version of axe-core

  • Modified impact_included class method to reflect changes to the aXe API:

  • There are now only 3 impact levels: ‘critical’, ‘serious’, and ‘minor’

version 1.0.0

  • Updated usage examples in README

  • Added docstrings to methods lacking documentation

  • Removed unused files

version 0.0.3

  • Added run method to Axe class to simplify the usage in existing test suites

  • run method includes the ability to set what impact level to test for: ‘minor’, ‘moderate’, ‘severe’, ‘critical’

version 0.0.276

  • Added pytest-axe usage example to README

version 0.0.275

  • Added usage example to README

version 0.0.273

  • Added selenium instance as a class attribute

  • Changed file paths to OS independent structure

  • Fixed file read operations to use with keyword

version 0.0.21

  • Fixed include of aXe API file and references to it

  • Updated README

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

axe-selenium-python-1.2.1.tar.gz (66.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

axe_selenium_python-1.2.1-py2.py3-none-any.whl (68.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file axe-selenium-python-1.2.1.tar.gz.

File metadata

File hashes

Hashes for axe-selenium-python-1.2.1.tar.gz
Algorithm Hash digest
SHA256 6d91d850127f7fd37e9f9eadc7d96efa12f8ef25dd84de4b169dfd9b83bed310
MD5 027d858e4298943483aa4be4cf5b1df9
BLAKE2b-256 50ba74dfa3cbd81db2d688257911d9d828f43b1a7526e9d29d709087d1d4ef50

See more details on using hashes here.

File details

Details for the file axe_selenium_python-1.2.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for axe_selenium_python-1.2.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 30191a9b69bd97bbcb5cd9f5143c7be504f495fb99c25e412cbd84f536a1a2a1
MD5 6990ffda0f176b2720d7e128cc0408db
BLAKE2b-256 831fadac228f9342a7cc025841823016de4c405dbc12b5e16a5698e5d3d385fa

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page