Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jupyterlab/pytest-check-links
pytest plugin that checks URLs
https://github.com/jupyterlab/pytest-check-links
jupyter-notebook markdown pytest pytest-plugin testing
Last synced: 2 months ago
JSON representation
pytest plugin that checks URLs
- Host: GitHub
- URL: https://github.com/jupyterlab/pytest-check-links
- Owner: jupyterlab
- License: bsd-3-clause
- Created: 2017-02-09T13:02:01.000Z (almost 8 years ago)
- Default Branch: main
- Last Pushed: 2024-05-16T23:34:32.000Z (8 months ago)
- Last Synced: 2024-11-07T05:23:52.539Z (3 months ago)
- Topics: jupyter-notebook, markdown, pytest, pytest-plugin, testing
- Language: Python
- Size: 226 KB
- Stars: 17
- Watchers: 8
- Forks: 17
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# pytest-check-links
pytest plugin that checks URLs for HTML-containing files.
[![Tests](https://github.com/jupyterlab/pytest-check-links/workflows/Tests/badge.svg)](https://github.com/jupyterlab/pytest-check-links/actions?query=workflow%3ATests+branch%3Amaster)
[![PyPI version](https://badge.fury.io/py/pytest-check-links.svg)](https://badge.fury.io/py/pytest-check-links)
![PyPI - Python Version](https://img.shields.io/pypi/pyversions/pytest-check-links)## Supported files
- `.html`
- `.rst`
- `.md` (TODO: select renderer)
- `.ipynb` (requires `nbconvert`)## Install
```
pip install pytest-check-links
```## Use
```
pytest --check-links mynotebook.ipynb
```## Configure
#### --links-ext
> default: `md,rst,html,ipynb`
A comma-separated list of extensions to check
#### --check-anchors
Also check whether links with `#anchors` HTML files (either local, or with
served with `html` in the `Content-Type`) actually exist, and point to _exactly one_
named anchor.#### --check-links-ignore
A regular expression that matches URIs that should not be checked.
Can be specified multiple times for multiple ignore patterns.
This can be used for files that have a lot of links to GitHub pages,
such as a Changelog. GitHub has rate limiting, which would normally cause these files to take up to an hour to complete for larger repositories. For example:```
pytest --check-links --check-links-ignore "https://github.com/.*/pull/.*" CHANGELOG.md
```### Cache
Caching requires the installation of `requests-cache`.
```
pip install requests-cache
```If enabled, each occurrence of a link will be checked, no matter how many times
it appears in a collection of files to check.#### --check-links-cache
Cache requests when checking links. Caching is disabled by default, and this option
must be provided, even if other cache configuration options are provided.#### --check-links-cache-name
> default: `.pytest-check-links-cache`
Name of link cache, either the base name of a file or similar, depending on backend.
#### --check-links-cache-backend
> default: `sqlite3`
Cache persistence backend. The other known backends are:
- `memory`
- `redis`
- `mongodb`See the [requests-cache documentation](https://requests-cache.readthedocs.io)
for more information.#### --check-links-cache-expire-after
> default: `None` (unlimited)
Time to cache link responses (seconds).
#### --check-links-cache-backend-opt
Backend-specific options for link cache, provided as `key:value`. These are passed
directly to the `requests_cache.CachedSession` constructor, as they vary depending
on the backend.Values will be parsed as JSON first, so to overload the default of caching all
HTTP response codes (which requires a list of `int`s):```bash
--check-links-backend-opt allowable_codes:[200]
```## Code Styling
`pytest-check-links` has adopted automatic code formatting so you shouldn't
need to worry too much about your code style.
As long as your code is valid,
the pre-commit hook should take care of how it should look.
You can invoke the pre-commit hook by hand at any time with:```bash
pre-commit run
```which should run any autoformatting on your code
and tell you about any errors it couldn't fix automatically.
You may also install [black integration](https://black.readthedocs.io/en/stable/integrations/editors.html)
into your text editor to format code automatically.If you have already committed files before setting up the pre-commit
hook with `pre-commit install`, you can fix everything up using
`pre-commit run --all-files`. You need to make the fixing commit
yourself after that.Some of the hooks only run on CI by default, but you can invoke them by
running with the `--hook-stage manual` argument.## TODO
- pick a markdown renderer (probably commonmark) or make the markdown renderer pluggable
- options for validating links (allow absolute links, only remote or local, etc.)
- find URLs in Python docstrings