deal


Namedeal JSON
Version 4.24.4 PyPI version JSON
download
home_pageNone
Summary**Deal** is a Python library for [design by contract][wiki] (DbC) programming.
upload_time2024-03-23 10:26:56
maintainerNone
docs_urlNone
authorNone
requires_python>=3.8
licenseNone
keywords deal contracts pre post invariant decorators validation pythonic functional
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # ![Deal](https://raw.githubusercontent.com/life4/deal/master/logo.png)

[![Build Status](https://cloud.drone.io/api/badges/life4/deal/status.svg)](https://cloud.drone.io/life4/deal)
[![PyPI version](https://img.shields.io/pypi/v/deal.svg)](https://pypi.python.org/pypi/deal)
[![Development Status](https://img.shields.io/pypi/status/deal.svg)](https://pypi.python.org/pypi/deal)

A Python library for [design by contract](https://en.wikipedia.org/wiki/Design_by_contract) (DbC) and checking values, exceptions, and side-effects. In a nutshell, deal empowers you to write bug-free code. By adding a few decorators to your code, you get for free tests, static analysis, formal verification, and much more. Read [intro](https://deal.readthedocs.io/basic/intro.html) to get started.

## Features

* [Classic DbC: precondition, postcondition, invariant.][values]
* [Tracking exceptions and side-effects.][exceptions]
* [Property-based testing.][tests]
* [Static checker.][linter]
* Integration with pytest, flake8, sphinx, and hypothesis.
* Type annotations support.
* [External validators support.][validators]
* [Contracts for importing modules.][module_load]
* [Can be enabled or disabled on production.][runtime]
* [Colorless][colorless]: annotate only what you want. Hence, easy integration into an existing project.
* Colorful: syntax highlighting for every piece of code in every command.
* [Memory leaks detection][leaks]: deal makes sure that pure functions don't leave unexpected objects in the memory.
* DRY: test discovery, error messages generation.
* Partial execution: linter executes contracts to statically check possible values.
* [Formal verification][verification]: prove that your code works for all input (or find out when it doesn't).
* Zero-dependency runtime: there are some dependencies for analysis tools, but nothing of it is required on the production.
* Fast: each code change is benchmarked and profiled.
* Reliable: the library has 100% test coverage, partially verified, and runs on production by multiple companies since 2018.

[values]: https://deal.readthedocs.io/basic/values.html
[exceptions]: https://deal.readthedocs.io/basic/exceptions.html
[tests]: https://deal.readthedocs.io/basic/tests.html
[linter]: https://deal.readthedocs.io/basic/linter.html
[validators]: https://deal.readthedocs.io/details/contracts.html#external-validators
[module_load]: https://deal.readthedocs.io/details/module_load.html
[runtime]: https://deal.readthedocs.io/basic/runtime.html
[colorless]: http://journal.stuffwithstuff.com/2015/02/01/what-color-is-your-function/
[leaks]: https://deal.readthedocs.io/basic/tests.html#memory-leaks
[verification]: https://deal.readthedocs.io/basic/verification.html

## Deal in 30 seconds

```python
# the result is always non-negative
@deal.post(lambda result: result >= 0)
# the function has no side-effects
@deal.pure
def count(items: List[str], item: str) -> int:
    return items.count(item)

# generate test function
test_count = deal.cases(count)
```

Now we can:

* Run `python3 -m deal lint` or `flake8` to statically check errors.
* Run `python3 -m deal test` or `pytest` to generate and run tests.
* Just use the function in the project and check errors in runtime.

Read more in the [documentation](https://deal.readthedocs.io/).

## Installation

```bash
python3 -m pip install --user 'deal[all]'
```

## Contributing

Contributions are welcome! A few ideas what you can contribute:

* Add new checks for the linter.
* Improve documentation.
* Add more tests.
* Improve performance.
* Found a bug? Fix it!
* Made an article about deal? Great! Let's add it into the `README.md`.
* Don't have time to code? No worries! Just tell your friends and subscribers about the project. More users -> more contributors -> more cool features.

To run tests locally, all you need is [task](http://taskfile.dev/). Run `task all` to run all code formatters, linters, and tests.

Thank you :heart:

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "deal",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": null,
    "keywords": "deal, contracts, pre, post, invariant, decorators, validation, pythonic, functional",
    "author": null,
    "author_email": "Gram <gram@orsinium.dev>",
    "download_url": "https://files.pythonhosted.org/packages/2b/7f/50dc3e77b4bb4ea0164f8e09204b263de3ce7d2f206cd8ee8bc49a9a956b/deal-4.24.4.tar.gz",
    "platform": null,
    "description": "# ![Deal](https://raw.githubusercontent.com/life4/deal/master/logo.png)\n\n[![Build Status](https://cloud.drone.io/api/badges/life4/deal/status.svg)](https://cloud.drone.io/life4/deal)\n[![PyPI version](https://img.shields.io/pypi/v/deal.svg)](https://pypi.python.org/pypi/deal)\n[![Development Status](https://img.shields.io/pypi/status/deal.svg)](https://pypi.python.org/pypi/deal)\n\nA Python library for [design by contract](https://en.wikipedia.org/wiki/Design_by_contract) (DbC) and checking values, exceptions, and side-effects. In a nutshell, deal empowers you to write bug-free code. By adding a few decorators to your code, you get for free tests, static analysis, formal verification, and much more. Read [intro](https://deal.readthedocs.io/basic/intro.html) to get started.\n\n## Features\n\n* [Classic DbC: precondition, postcondition, invariant.][values]\n* [Tracking exceptions and side-effects.][exceptions]\n* [Property-based testing.][tests]\n* [Static checker.][linter]\n* Integration with pytest, flake8, sphinx, and hypothesis.\n* Type annotations support.\n* [External validators support.][validators]\n* [Contracts for importing modules.][module_load]\n* [Can be enabled or disabled on production.][runtime]\n* [Colorless][colorless]: annotate only what you want. Hence, easy integration into an existing project.\n* Colorful: syntax highlighting for every piece of code in every command.\n* [Memory leaks detection][leaks]: deal makes sure that pure functions don't leave unexpected objects in the memory.\n* DRY: test discovery, error messages generation.\n* Partial execution: linter executes contracts to statically check possible values.\n* [Formal verification][verification]: prove that your code works for all input (or find out when it doesn't).\n* Zero-dependency runtime: there are some dependencies for analysis tools, but nothing of it is required on the production.\n* Fast: each code change is benchmarked and profiled.\n* Reliable: the library has 100% test coverage, partially verified, and runs on production by multiple companies since 2018.\n\n[values]: https://deal.readthedocs.io/basic/values.html\n[exceptions]: https://deal.readthedocs.io/basic/exceptions.html\n[tests]: https://deal.readthedocs.io/basic/tests.html\n[linter]: https://deal.readthedocs.io/basic/linter.html\n[validators]: https://deal.readthedocs.io/details/contracts.html#external-validators\n[module_load]: https://deal.readthedocs.io/details/module_load.html\n[runtime]: https://deal.readthedocs.io/basic/runtime.html\n[colorless]: http://journal.stuffwithstuff.com/2015/02/01/what-color-is-your-function/\n[leaks]: https://deal.readthedocs.io/basic/tests.html#memory-leaks\n[verification]: https://deal.readthedocs.io/basic/verification.html\n\n## Deal in 30 seconds\n\n```python\n# the result is always non-negative\n@deal.post(lambda result: result >= 0)\n# the function has no side-effects\n@deal.pure\ndef count(items: List[str], item: str) -> int:\n    return items.count(item)\n\n# generate test function\ntest_count = deal.cases(count)\n```\n\nNow we can:\n\n* Run `python3 -m deal lint` or `flake8` to statically check errors.\n* Run `python3 -m deal test` or `pytest` to generate and run tests.\n* Just use the function in the project and check errors in runtime.\n\nRead more in the [documentation](https://deal.readthedocs.io/).\n\n## Installation\n\n```bash\npython3 -m pip install --user 'deal[all]'\n```\n\n## Contributing\n\nContributions are welcome! A few ideas what you can contribute:\n\n* Add new checks for the linter.\n* Improve documentation.\n* Add more tests.\n* Improve performance.\n* Found a bug? Fix it!\n* Made an article about deal? Great! Let's add it into the `README.md`.\n* Don't have time to code? No worries! Just tell your friends and subscribers about the project. More users -> more contributors -> more cool features.\n\nTo run tests locally, all you need is [task](http://taskfile.dev/). Run `task all` to run all code formatters, linters, and tests.\n\nThank you :heart:\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "**Deal** is a Python library for [design by contract][wiki] (DbC) programming.",
    "version": "4.24.4",
    "project_urls": {
        "Documentation": "https://deal.readthedocs.io/",
        "Repository": "https://github.com/life4/deal"
    },
    "split_keywords": [
        "deal",
        " contracts",
        " pre",
        " post",
        " invariant",
        " decorators",
        " validation",
        " pythonic",
        " functional"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "7bcf4c27b6c1afc6320c79c3db756e54f337ba0c36c243a16c2c1ea54d61e8d1",
                "md5": "bd2033e6c92b647a628ae7e2c173d6c4",
                "sha256": "7fa4139296843fc16e5b8edd49b9a379d829113b1b4bdab0d8a7374cc826e031"
            },
            "downloads": -1,
            "filename": "deal-4.24.4-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "bd2033e6c92b647a628ae7e2c173d6c4",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 206879,
            "upload_time": "2024-03-23T10:26:52",
            "upload_time_iso_8601": "2024-03-23T10:26:52.567628Z",
            "url": "https://files.pythonhosted.org/packages/7b/cf/4c27b6c1afc6320c79c3db756e54f337ba0c36c243a16c2c1ea54d61e8d1/deal-4.24.4-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "2b7f50dc3e77b4bb4ea0164f8e09204b263de3ce7d2f206cd8ee8bc49a9a956b",
                "md5": "9b8b81dfef33cc1e5a541fee1613bd34",
                "sha256": "0470af54234cebc760346f4be1a6fdaeefe0215fc58efd630cd4b2d193e4e82e"
            },
            "downloads": -1,
            "filename": "deal-4.24.4.tar.gz",
            "has_sig": false,
            "md5_digest": "9b8b81dfef33cc1e5a541fee1613bd34",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 724356,
            "upload_time": "2024-03-23T10:26:56",
            "upload_time_iso_8601": "2024-03-23T10:26:56.223789Z",
            "url": "https://files.pythonhosted.org/packages/2b/7f/50dc3e77b4bb4ea0164f8e09204b263de3ce7d2f206cd8ee8bc49a9a956b/deal-4.24.4.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-03-23 10:26:56",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "life4",
    "github_project": "deal",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "deal"
}
        
Elapsed time: 3.53398s