Brownie
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-beta.16) - 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
- python3 version 3.6 or greater, python3-dev
- ganache-cli - tested with version 6.12.2
Installation
via pipx
The recommended way to install Brownie is via pipx. pipx installs Brownie into a virtual environment and makes it available directly from the commandline. Once installed, you will never have to activate a virtual environment prior to using Brownie.
To install pipx:
python3 -m pip install --user pipx
python3 -m pipx ensurepathTo install Brownie using pipx:
pipx install eth-brownieTo upgrade to the latest version:
pipx upgrade eth-brownieTo use lastest master or another branch as version:
pipx install git+https://github.com/eth-brownie/brownie.git@mastervia pip
You can install the latest release via pip:
pip install eth-brownievia setuptools
You can clone the repository and use setuptools for the most up-to-date version:
git clone https://github.com/eth-brownie/brownie.git
cd brownie
python3 setup.py installas a library
If you want to install brownie inside your own project (rather than as a standalone cli tool):
export BROWNIE_LIB=1
pip install eth-brownieThis loosens the pins on all dependencies. You'll want to make sure you have your own requirements.txt to make sure upgrades upstream don't surprise anyone.
for development
There are extra tools that are helpful when developing:
git clone https://github.com/eth-brownie/brownie.git
cd brownie
python3 -m venv venv
./venv/bin/pip install wheel
./venv/bin/pip install -e . -r requirements-dev.txtUpgrading the pinned versions of dependencies is easy:
./venv/bin/pip-compile --upgrade
./venv/bin/pip-compile --upgrade requirements-dev.in
./venv/bin/pip-compile --upgrade requirements-windows.in
Even small upgrades of patch versions have broken things in the past, so be sure to run all tests after upgrading things!
Quick Usage
To initialize a new Brownie project, start by creating a new folder. From within that folder, type:
brownie initNext, 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 -e . -r requirements-dev.txtThen 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 -dTo open a session to the container:
docker-compose exec sandbox bashTo 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'Attaching to dockerized RPC clients
You can also attach to a RPC client already running inside a docker container.
For example for running ganache-cli you could just startup the official ganache-cli docker image:
docker run -p 8545:8545 trufflesuite/ganache-cliThen in another terminal on your host you could connect to it:
brownie consoleIf you have your RPC client bound to a specific hostname e.g. ganache you could create a separate brownie network for it:
brownie networks add Development dev cmd=ganache-cli host=http://ganache:8545Then connect to it with:
brownie console --network devContributing
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.

Formed in 2009, the Archive Team (not to be confused with the archive.org Archive-It Team) is a rogue archivist collective dedicated to saving copies of rapidly dying or deleted websites for the sake of history and digital heritage. The group is 100% composed of volunteers and interested parties, and has expanded into a large amount of related projects for saving online and digital history.
