Skip to main content

Find all exceptions that your code and its dependencies can raise, to make your work foolproof!

Project description

PyPi version

Python 3


Logo

FoolProof

Find all exceptions that your code and its dependencies can raise, to make your work foolproof!


Report Bug

About The Project

Do you know about the "demo effect"? The fact that your well-tested code will suddently fail the moment you show it to someone? Often, it's because you forgot to handle an exception that you didn't think about.

🪨 FoolProof automatically identifies the exceptions that your code and its dependencies can raise, so you're never caught off guard again!

Getting Started

Using foolproof is very simple.

Install foolproof with pip :

pip install foolproof

To analyse an entire module mypackage, with all the functions and methods it contains, add this lines at the begginning of your code:

import foolproof
import mypackage

foolproof(mypackage)

You can also use it directly on a function:

import foolproof
from mypackage import main

foolproof(main)

(back to top)

Contributing

Ideally, I would like to add more features to foolproof, but I don't have much time for it. If you want to contribute, you're more than welcome to do so!

Roadmap/todo

Task Importance Difficulty Contributor on it Description
Adding links to file 5/5 5/5 - More than printing the raise command, we should print the link to the file in which the raise is used. This implies a major rework of foolproof, as the python ast does not keep the link between ast nodes and files.

(back to top)

How to contribute

Contributing is an awesome way to learn, inspire, and help others. Any contributions you make are greatly appreciated, even if it's just about styling and best practices.

If you have a suggestion that would make this project better, please fork the repo and create a pull request.
Don't forget to give the project a star! Thanks again!

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/YourAmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

Author

This library was created by Nicolas MICAUX.

Acknowledgements

A lot of this code is taken from https://github.com/DontShaveTheYak/deep-ast (https://pypi.org/project/deep-ast/)
License: GNU General Public License v3 (GPLv3)
All credits goes to Levi Blaney - @shady_cuz, shadycuz@gmail.com

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

foolproof-0.1.6.tar.gz (8.8 kB view details)

Uploaded Source

File details

Details for the file foolproof-0.1.6.tar.gz.

File metadata

  • Download URL: foolproof-0.1.6.tar.gz
  • Upload date:
  • Size: 8.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for foolproof-0.1.6.tar.gz
Algorithm Hash digest
SHA256 9324d7c53be7745563469f468bc75eb1cc99ac27f670484d0089505ac529cc50
MD5 d63e7640caf84a20bd83319504a1952a
BLAKE2b-256 435099386b19e8fd11c75f6d49a8c814c1085afb8ace28e11e0fb3a62019fb3e

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