Prevent Exception Handling AntiPatterns
Project description
Prevent Exception Handling AntiPatterns in Python
Inspired by this blog post. I described the building process of this tool here.
“For those who like dinosaurs 🦖 and clean try/except ✨ blocks.”
Summary
- Installation and usage
- Violations
- Pre-commit
- Show your style
- Extra Resources
- Contributing
- Change log
- License
- Credits
Installation and usage
Installation
pip install tryceratops
OR
poetry add -D tryceratops
Usage
tryceratops [filename or dir...]
You can enable experimental analyzers by running:
tryceratops --experimental [filename or dir...]
You can ignore specific violations by using: --ignore TRYXXX
repeatedly:
tryceratops --ignore TRY201 --ignore TRY202 [filename or dir...]
You can exclude dirs by using: --exclude dir/path
repeatedly:
tryceratops --exclude tests --exclude .venv [filename or dir...]
You can also autofix some violations:
tryceratops --autofix [filename or dir...]
flake8
Plugin
🦖 Tryceratops is also a plugin for flake8
, so you can:
❯ flake8 --select TRY src/tests/samples/violations/call_raise_vanilla.py
src/tests/samples/violations/call_raise_vanilla.py:13:9: TRY002 Create your own exception
src/tests/samples/violations/call_raise_vanilla.py:13:9: TRY003 Avoid specifying long messages outside the exception class
src/tests/samples/violations/call_raise_vanilla.py:21:9: TRY201 Simply use 'raise' without specifying exception object again
Violations
All violations and its descriptions can be found in docs.
Autofix support
So far, autofix only supports violations: TRY200, TRY201, and TRY400.
Ignoring violations
If you want to ignore a violation in a specific file, you can either:
- Add a comment with
noqa
to the top of the file you want to ignore - Add a comment with
noqa
to the line you want to ignore - Add a comment with
noqa: CODE
to the line you want to ignore a specific violation
Example:
def verbose_reraise_1():
try:
a = 1
except Exception as ex:
raise ex # noqa: TRY202
Configuration
You can set up a pyproject.toml
file to set rules.
This is useful to avoid reusing the same CLI flags over and over again and helps to define the structure of your project.
Example:
[tool.tryceratops]
exclude = ["samples"]
ignore = ["TRY002", "TRY200", "TRY300"]
experimental = false
check_pickable = false
allowed_base_exceptions = ["MyAppBase"]
CLI flags always overwrite the config file.
Pre-commit
If you wish to use pre-commit, add this:
- repo: https://github.com/guilatrova/tryceratops
rev: v2.3.0
hooks:
- id: tryceratops
Show your style
Add this fancy badge to your project's README.md
:
[![try/except style: tryceratops](https://img.shields.io/badge/try%2Fexcept%20style-tryceratops%20%F0%9F%A6%96%E2%9C%A8-black)](https://github.com/guilatrova/tryceratops)
Extra Resources
If you want to read more about:
Contributing
Thank you for considering making Tryceratops better for everyone!
Refer to Contributing docs.
Change log
See CHANGELOG.
License
MIT
Credits
Thanks to God for the inspiration 🙌 ☁️ ☀️
The black project for insights.
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
File details
Details for the file tryceratops-2.3.0.tar.gz
.
File metadata
- Download URL: tryceratops-2.3.0.tar.gz
- Upload date:
- Size: 20.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.9.6 readme-renderer/37.3 requests/2.30.0 requests-toolbelt/1.0.0 urllib3/1.26.15 tqdm/4.65.0 importlib-metadata/6.6.0 keyring/23.13.1 rfc3986/2.0.0 colorama/0.4.6 CPython/3.8.16
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 765678ebb55efc2db7b2d6ccccee9877fe13d4672f8fed27d83263b944b68150 |
|
MD5 | 369f0b9d99fd9530da0b067080a754e2 |
|
BLAKE2b-256 | a439574d538d5f37a273482c9435d630c9d2ad7456d36a2ba4468a472561ff89 |
File details
Details for the file tryceratops-2.3.0-py3-none-any.whl
.
File metadata
- Download URL: tryceratops-2.3.0-py3-none-any.whl
- Upload date:
- Size: 27.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.9.6 readme-renderer/37.3 requests/2.30.0 requests-toolbelt/1.0.0 urllib3/1.26.15 tqdm/4.65.0 importlib-metadata/6.6.0 keyring/23.13.1 rfc3986/2.0.0 colorama/0.4.6 CPython/3.8.16
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f7aa2e5240f3aa9a0bd68ac32d231c8e99b3bcac5a7bc6816eb76acc2a299892 |
|
MD5 | 3c0323b6e959ee30f112a0bb4f34965f |
|
BLAKE2b-256 | b352bb71987eb4c1c374b343686e6092a8e359ea96e4d3e69a3b639d8e31e3c6 |