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, severe, moderate, 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.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.1.7.tar.gz (64.8 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.1.7-py2.py3-none-any.whl (66.5 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

File hashes

Hashes for axe-selenium-python-1.1.7.tar.gz
Algorithm Hash digest
SHA256 7a7e1e3db1aeef0fee7be833de24ffbe73b6c75c59050a2900e04e18ef3771ee
MD5 36bc7b96b94db85cf631c4a4d3deb66f
BLAKE2b-256 f9521f74f54da82f6f25d211c0944a33cbf90c3d49282ae0c23ada23b4540c05

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for axe_selenium_python-1.1.7-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 32469b4d92f5e5d0cd826c6f42512dd31e3a56aba1105f7c3f2324a98352f214
MD5 87b3e8480a5de307f98e56691dbd4f03
BLAKE2b-256 69893c16ee14a238b5c043833c6fabe494d50030775c8ca30b75c30f1eacaf1b

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