Pytest plugin reporting dependency licenses
Project description
Overview
swarmauri_tests_pylicense is a pytest plugin that
scans a package's full dependency tree and ensures each dependency declares a
license. The plugin resolves dependencies recursively, checking every
transitive requirement. It inspects both the License metadata field and
any Classifier entries that declare a license.
By default, the plugin runs in parameterized mode which creates one test per dependency. An aggregate mode is also available that reports all missing licenses in a single test.
Installation
pip install swarmauri_tests_pylicense
pytest automatically discovers the plugin once it is installed.
Usage
Parameterized (default)
Run pytest with the package name to scan its dependency licenses:
pytest --pylicense-package=<your-package>
Each generated test encodes the full dependency path, the resolved version, and the detected license of the terminal package. For example:
swarmauri_tests_pylicense:license::pkg::depA::depB==1.2.3 [Apache-2.0]
Aggregate
Use the --pylicense-mode=aggregate flag to consolidate checks into one test:
pytest --pylicense-package=<your-package> --pylicense-mode=aggregate
Allow and Disallow Lists
To restrict acceptable licenses, provide a comma-separated allow list or disallow list. These can be passed via command-line options or environment variables.
Command-line:
pytest --pylicense-package=<your-package> --pylicense-allow-list=MIT,Apache-2.0
pytest --pylicense-package=<your-package> --pylicense-disallow-list=GPL
Environment variables:
export PYLICENSE_ALLOW_LIST="MIT,Apache-2.0"
export PYLICENSE_DISALLOW_LIST="GPL"
pytest --pylicense-package=<your-package>
If both are provided, any license not in the allow list or explicitly present in the disallow list will cause a test failure. By default, all licenses are allowed and none are disallowed.
Accepting Specific Dependencies
Some transitive dependencies may ship with unusual or proprietary licenses that
are acceptable for your project. Use --pylicense-accept-deps (or the
PYLICENSE_ACCEPT_DEPS environment variable) with a comma-separated list to
explicitly bypass those packages. For example:
pytest --pylicense-package=<your-package> --pylicense-accept-deps=cffi
This tells the plugin to treat cffi as pre-approved. Any license issues for
cffi?including unknown or non-standard licenses?are ignored while other
dependencies continue to be validated normally.
License
Licensed under the Apache 2.0 License.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file swarmauri_tests_pylicense-0.11.0.dev1.tar.gz.
File metadata
- Download URL: swarmauri_tests_pylicense-0.11.0.dev1.tar.gz
- Upload date:
- Size: 9.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.26 {"installer":{"name":"uv","version":"0.11.26","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d325ddeb487f2c718f5770e8c1d460ee014ef6689b9f4face3dc3c05330b840e
|
|
| MD5 |
12ba5396403a38cd6d1cb234c4d2c68f
|
|
| BLAKE2b-256 |
88eb01dc82b19eb0c2082cf221d81208edfe982f9586d445be0ecb0a2f321b77
|
File details
Details for the file swarmauri_tests_pylicense-0.11.0.dev1-py3-none-any.whl.
File metadata
- Download URL: swarmauri_tests_pylicense-0.11.0.dev1-py3-none-any.whl
- Upload date:
- Size: 10.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.26 {"installer":{"name":"uv","version":"0.11.26","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3141d4f64028af2248e7a4f9289269b6b2cccf312a7fcd2f59b4a957ded3f487
|
|
| MD5 |
ad2fa865fdf9714762b59d694dfa0a48
|
|
| BLAKE2b-256 |
c0d1b17c56bead1cd93954caefada89db93827333fdbf41d222096aa9ccf0b94
|