Skip to main content

A MkDocs plugin that validates URL in rendered HTML files

Project description

mkdocs-htmlproofer-plugin PyPI - Version

GitHub Actions

A MkDocs plugin that validates URLs, including anchors, in rendered html files.

Installation

  1. Prerequisites
  • Python >= 3.6
  • MkDocs >= 0.17
  1. Install the package with pip:
pip install mkdocs-htmlproofer-plugin
  1. Enable the plugin in your mkdocs.yml:

Note: If you have no plugins entry in your config file yet, you'll likely also want to add the search plugin. MkDocs enables it by default if there is no plugins entry set, but now you have to enable it explicitly.

plugins:
    - search
    - htmlproofer

To enable cross-page anchor validation, you must set use_directory_urls = False in mkdocs.yml:

use_directory_urls: False

Configuring

enabled

True by default, allows toggling whether the plugin is enabled. Useful for local development where you may want faster build times.

plugins:
  - htmlproofer:
      enabled: !ENV [ENABLED_HTMLPROOFER, True]

Which enables you do disable the plugin locally using:

export ENABLED_HTMLPROOFER=false
mkdocs serve

raise_error

Optionally, you may raise an error and fail the build on bad url status.

plugins:
  - htmlproofer:
      raise_error: True

raise_error_excludes

When specifying raise_error: True, it is possible to ignore errors for combinations of urls ('*' means all urls) and status codes with raise_error_excludes.

plugins:
  - search
  - htmlproofer:
      raise_error: True
      raise_error_excludes:
        504: ['https://www.mkdocs.org/']
        404: ['https://github.com/manuzhang/mkdocs-htmlproofer-plugin']
        400: ['*']

validate_external_urls

Avoids validating any external URLs (i.e those starting with http:// or https://). This will be faster if you just want to validate local anchors, as it does not make any network requests.

plugins:
  - htmlproofer:
      validate_external_urls: False

validate_rendered_template

Validates the entire rendered template for each page - including the navigation, header, footer, etc. This defaults to off because it is much slower and often redundant to repeat for every single page.

plugins:
  - htmlproofer:
      validate_rendered_template: True

Improving

More information about plugins in the MkDocs documentation

Acknowledgement

This work is based on the mkdocs-markdownextradata-plugin project and the Finding and Fixing Website Link Rot with Python, BeautifulSoup and Requests article.

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

mkdocs-htmlproofer-plugin-0.10.2.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

mkdocs_htmlproofer_plugin-0.10.2-py3-none-any.whl (6.8 kB view details)

Uploaded Python 3

File details

Details for the file mkdocs-htmlproofer-plugin-0.10.2.tar.gz.

File metadata

File hashes

Hashes for mkdocs-htmlproofer-plugin-0.10.2.tar.gz
Algorithm Hash digest
SHA256 11faeeaf7b75dd503d72d6ccd47778c4e68e0949737768efab24b68ef651fd19
MD5 643f32ae67127023147cc78cb3dc72ee
BLAKE2b-256 33a29c1c29ae7d30d4adbfdb338ceef488192be638702ddb87240985850e6a12

See more details on using hashes here.

File details

Details for the file mkdocs_htmlproofer_plugin-0.10.2-py3-none-any.whl.

File metadata

File hashes

Hashes for mkdocs_htmlproofer_plugin-0.10.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e8be2d4769abc85e54e403482d85ffdb5c0ea306d2b091a20fcfa2577e00708d
MD5 5eda86fcc7aee77286dc20f38489b707
BLAKE2b-256 44a897ff0eddadc18d3c943ecde7ad8b5713f41ec031d90e1defeb0323a22214

See more details on using hashes here.

Supported by

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