Skip to main content

A Python framework for Ethereum smart contract deployment, testing and interaction.

Project description

Brownie

Pypi Status Build Status Docs Status Coverage Status

Brownie is a Python-based development and testing framework for smart contracts targeting the Ethereum Virtual Machine.

Features

  • Full support for Solidity (>=0.4.22) and Vyper (0.1.0-b16)
  • Contract testing via pytest, including trace-based coverage evaluation
  • Property-based and stateful testing via hypothesis
  • Powerful debugging tools, including python-style tracebacks and custom error strings
  • Built-in console for quick project interaction
  • Support for ethPM packages

Dependencies

As Brownie relies on py-solc-x, you do not need solc installed locally but you must install all required solc dependencies.

Installation

You can install the latest release via pip:

pip install eth-brownie

Or clone the repository and use setuptools for the most up-to-date version:

python setup.py install

Quick Usage

To set up the default folder and file structure for Brownie use:

brownie init

Next, type brownie --help for basic usage information.

Documentation and Support

Brownie documentation is hosted at Read the Docs.

If you have any questions about how to use Brownie, feel free to ask on Ethereum StackExchange or join us on Gitter.

Testing

To run the tests, first install the developer dependencies:

pip install -r requirements-dev.txt

Then use tox to run the complete suite against the full set of build targets, or pytest to run tests against a specific version of Python. If you are using pytest you must include the -p no:pytest-brownie flag to prevent it from loading the Brownie plugin.

Using Docker

You can use a sandbox container provided in the docker-compose.yml file for testing inside a Docker environment.

This container provides everything you need to test using a Python 3.6 interpreter.

Start the test environment:

docker-compose up -d

To open a session to the container:

docker-compose exec sandbox bash

To run arbitrary commands, use the bash -c prefix.

docker-compose exec sandbox bash -c ''

For example, to run the tests in brownie/tests/test_format_input.py:

docker-compose exec sandbox bash -c 'python -m pytest tests/convert/test_format_input.py'

Contributing

Help is always appreciated! Feel free to open an issue if you find a problem, or a pull request if you've solved an issue.

Please check out our Contribution Guide prior to opening a pull request, and join the Brownie Gitter channel if you have any questions.

License

This project is licensed under the MIT 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

eth-brownie-1.6.4.tar.gz (102.4 kB view details)

Uploaded Source

Built Distribution

eth_brownie-1.6.4-py3-none-any.whl (129.0 kB view details)

Uploaded Python 3

File details

Details for the file eth-brownie-1.6.4.tar.gz.

File metadata

  • Download URL: eth-brownie-1.6.4.tar.gz
  • Upload date:
  • Size: 102.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.7.5

File hashes

Hashes for eth-brownie-1.6.4.tar.gz
Algorithm Hash digest
SHA256 66b9d4bac4e500a95885f44f82e7935e32a5bd12a9bf204b92fea3f53ad2747f
MD5 96a84e02bb5c9cee73a41b957d6d3d43
BLAKE2b-256 f01707ceb6b6daa56e5ee93dac2ba7f19643688a25696ab6ded083972686c88c

See more details on using hashes here.

File details

Details for the file eth_brownie-1.6.4-py3-none-any.whl.

File metadata

  • Download URL: eth_brownie-1.6.4-py3-none-any.whl
  • Upload date:
  • Size: 129.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.7.5

File hashes

Hashes for eth_brownie-1.6.4-py3-none-any.whl
Algorithm Hash digest
SHA256 d803888aef7709846c54d38e2b710487956620548ca590c012e6c6d5b0002c74
MD5 a2fe8a78709dcdc6a28c9795870675f9
BLAKE2b-256 c9742779628c5c0a405a9eefd635c3eb84831870952a6d652cdcfa1cb4a2d6a3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page