Skip to main content

Pytest plugin for WCAG 2.1 A/AA/AAA compliance checks on PDFs.

Project description

Swarmauri Logo

PyPI - Downloads Hits PyPI - Python Version PyPI - License PyPI - wcag-pdf-pytest


wcag-pdf-pytest

wcag-pdf-pytest is a pytest plugin that scaffolds WCAG 2.1 compliance testing for PDF documents. The plugin auto-generates one test per WCAG 2.1 Success Criterion (SC) that applies to PDFs, organizes them by conformance level, and exposes CLI switches for narrowing execution to the criteria relevant to your review.

Features

  • SC-aware test generation — each applicable WCAG 2.1 SC ships as an individual pytest module with structured docstrings that document the requirement.
  • Level-based selection — mark sets (A, AA, AAA) and CLI flags allow you to focus on the conformance tier under audit.
  • Context-aware filtering — opt-in inclusion of "Depends" criteria lets you decide when to execute context-sensitive checks.
  • Extensible PDF inspection — centralize heavy lifting in pdf_inspector.py so new assertions or document parsers can be layered in without touching the generated tests.

Installation

pip

pip install wcag-pdf-pytest[pdf]

uv

uv add wcag-pdf-pytest[pdf]

Install the optional pdf extra when you need the bundled pypdf helpers.

Usage

Run the full WCAG 2.1 test suite against a PDF document:

pytest --wcag-pdf path/to/file.pdf

Execute only Level AA criteria using pytest markers:

pytest -m "AA" --wcag-pdf path/to/file.pdf

The plugin also exposes explicit CLI options:

pytest --wcag-pdf-level AA --wcag-pdf path/to/file.pdf
pytest --wcag-pdf-include-depends --wcag-pdf path/to/file.pdf

Tests are namespaced under the wcag21 marker to keep discovery isolated from other pytest plugins. Each test is seeded with an xfail placeholder so you can progressively replace the stub assertion with a concrete PDF accessibility check.

CLI reference

Option Description
--wcag-pdf Path to one or more PDF files to validate.
--wcag-pdf-level {A,AA,AAA} Restrict execution to a specific WCAG level.
--wcag-pdf-include-depends Execute context-dependent criteria flagged as "Depends".

Combine CLI switches with pytest marker expressions for granular selection during CI runs.

Extending PDF checks

Extend wcag_pdf_pytest/pdf_inspector.py with reusable utilities that evaluate individual criteria. Generated tests should stay declarative — import helpers from the inspector module to keep assertions maintainable and consistent across the suite.

License

Apache License 2.0. See LICENSE for details.

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

wcag_pdf_pytest-0.2.1.tar.gz (21.3 kB view details)

Uploaded Source

Built Distribution

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

wcag_pdf_pytest-0.2.1-py3-none-any.whl (58.3 kB view details)

Uploaded Python 3

File details

Details for the file wcag_pdf_pytest-0.2.1.tar.gz.

File metadata

  • Download URL: wcag_pdf_pytest-0.2.1.tar.gz
  • Upload date:
  • Size: 21.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for wcag_pdf_pytest-0.2.1.tar.gz
Algorithm Hash digest
SHA256 c819b934a2ffee4a803daeac88aca64141155cbf0a9b00c67d3910bfff9b05db
MD5 2c42630d04f63f62dd9bd55692ecada6
BLAKE2b-256 54225de681fbe0bd8e952656cb2f6c5a2a582b429db949b126c34b9e53aacfdf

See more details on using hashes here.

File details

Details for the file wcag_pdf_pytest-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: wcag_pdf_pytest-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 58.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for wcag_pdf_pytest-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 29baf304fca7e81ac19750366ccadd65afbc0bc246c32239c68da8ed13b0b60a
MD5 c185bc3c50fdd6793370f19999613d69
BLAKE2b-256 6fca9b70d83aca2bb8c9c61b7a8120920215ca98f7a4262e67fb531d7f1f11ec

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