Saudação, querido entusiasta de criptografia!
Hoje falaremos sobre Brownie - um análogo da estrutura Truffle , que é freqüentemente usada para desenvolver contratos inteligentes para Solidity, testá-los e implantá-los (sobre os quais você pode ler em uma série de artigos relacionados aqui ).
Então, por que precisamos de outra estrutura e qual é a principal diferença da Trufa?
- Primeiro, eles usam idiomas diferentes - enquanto o Truffle conta com JS, nem todo mundo conhece esse idioma e nem todo mundo se sente confortável em usá-lo; brownie usa Python 3.
- Em segundo lugar, o brownie, devido à integração de vários softwares, torna o desenvolvimento mais conveniente: eis o gerenciador de pacotes ethpm para contratos inteligentes e o ganache para implantar uma cadeia de testes local, e testes através do pytest, todas as versões dos compiladores solc e até ligações para o MythX - uma ferramenta para pesquisa automática por erros em contratos inteligentes - em outras palavras, o brownie oferece ferramentas para todo o ciclo de desenvolvimento. Obviamente, o Truffle também permite que você use todas essas ferramentas, mas elas não são embutidas na estrutura e precisam ser instaladas adicionalmente.
- Em terceiro lugar, o brownie permite que você trabalhe não apenas com contratos inteligentes no Solidity, mas também no vyper - um baseado em python digitado para desenvolver contratos inteligentes.
Portanto, se vocĂŞ prefere trabalhar com o Python e deseja facilitar o desenvolvimento de contratos inteligentes, vale a pena tentar o brownie.
O que mais o brownie pode fazer?
Conforme declarado no prĂłprio repositĂłrio, o brownie Ă© uma estrutura de desenvolvimento de contrato inteligente de ciclo completo para plataformas baseadas no Ethereum que suporta:
- Várias linguagens de programação de contratos inteligentes: Solidity e Vyper.
- Construa contratos.
- Interação interativa com contratos.
- Testando contratos inteligentes com pytest.
- Scripts para interagir com contratos inteligentes.
- Trabalhando com modelos de contrato inteligentes.
brownie , brownie . pip:
pip install eth-brownie
brownie .
brownie --help
Brownie v1.6.9 - Python development framework for Ethereum
Usage: brownie <command> [<args>...] [options <args>]
Commands:
init Initialize a new brownie project
bake Initialize from a brownie-mix template
ethpm Commands related to the ethPM package manager
compile Compiles the contract source files
console Load the console
test Run test cases in the tests/ folder
run Run a script in the scripts/ folder
accounts Manage local accounts
gui Load the GUI to view opcodes and test coverage
analyze Find security vulnerabilities using the MythX API
Options:
--help -h Display this message
Type 'brownie <command> --help' for specific options and more information about
each command.
brownie
brownie brownie-config.yaml
. brownie init
brownie init salut_habr
Brownie v1.6.9 - Python development framework for Ethereum
SUCCESS: Brownie environment has been initiated at salut_habr
brownie bake template_name
brownie bake token
Brownie v1.6.9 - Python development framework for Ethereum
Downloading from https://github.com/brownie-mix/token-mix/archive/master.zip...
5.62kiB [00:00, 2.82MiB/s]
SUCCESS: Brownie mix 'token' has been initiated at token
ERC-20 ( token).
:
├───build # , .
│ ├───contracts # , ABI .
│ └───deployments # .
├───contracts # ( ).
├───interfaces # .
├───reports # .
├───scripts # Python run.
└───tests # pytest .
, brownie , brownie-config.yaml
— , .
brownie
brownie , , : compile
, console
, test
run
.
brownie compile
, contracts . , , "_",- brownie ( ).
./build/contracts/
json-, ABI , - -.
brownie , , . , -all
.
brownie compile --all
Brownie v1.6.9 - Python development framework for Ethereum
Compiling contracts...
Solc version: 0.5.17+commit.d19bba13.Windows.msvc
Optimizer: Enabled Runs: 200
EVM Version: Istanbul
Generating build data...
- Token...
- SafeMath...
Brownie project has been compiled at C:\Users\Default\Documents\token\build\contracts
, , brownie-config.yaml
brownie test
pytest, , , CI/CD.
brownie test
Brownie v1.6.9 - Python development framework for Ethereum
==================================================================================================== test session starts =====================================================================================================
platform win32 -- Python 3.8.3, pytest-5.4.1, py-1.8.1, pluggy-0.13.1
rootdir: C:\Users\Default\Documents\token
plugins: eth-brownie-1.6.9, hypothesis-5.5.4, forked-1.1.3, xdist-1.31.0, web3-5.5.1
collecting ... Launching 'ganache-cli.cmd --port 8545 --gasLimit 6721975 --accounts 10 --hardfork istanbul --mnemonic brownie'...
collected 7 items
tests\test_approve_transferFrom.py ...... [ 85%]
tests\test_transfer.py . [100%]
===================================================================================================== 7 passed in 9.35s ======================================================================================================
Terminating local RPC client...
tests/
brownie run
scripts. brownie 2.x, CI/CD ( ).
brownie run token
Brownie v1.6.9 - Python development framework for Ethereum
TokenProject is the active project.
Launching 'ganache-cli.cmd --port 8545 --gasLimit 6721975 --accounts 10 --hardfork istanbul --mnemonic brownie'...
Running 'scripts.token.main'...
Transaction sent: 0xe36fbf7d93c1c91bde5e9290128999ed06ea54eb68352fb477fa91ce8072f472
Gas price: 0.0 gwei Gas limit: 549953
Token.constructor confirmed - Block: 1 Gas used: 549953 (100.00%)
Token deployed at: 0x3194cBDC3dbcd3E11a07892e7bA5c3394048Cc87
Terminating local RPC client...
brownie console
brownie: , . :
brownie console
Brownie v1.6.9 - Python development framework for Ethereum
TokenProject is the active project.
Launching 'ganache-cli.cmd --port 8545 --gasLimit 6721975 --accounts 10 --hardfork istanbul --mnemonic brownie'...
Brownie environment is ready.
>>> dir()
[Fixed, Gui, SafeMath, Token, Wei, a, accounts, alert, compile_source, config, dir, history, network, project, rpc, run, web3]
brownie, , web3py.
/
brownie ganache ( Ethereum) , ( Quorum!). --network network_name
console run, network_name brownie-config.yaml. ETH ETC, . , yaml . develop, test master ( ), Azure .
Para resumir, podemos dizer que o brownie é atualmente uma solução madura para o Ethereum pronta para o Enterpise e é capaz de satisfazer quase todas as necessidades que surgem em seu processo. Os pythonistas e não apenas definitivamente deveriam tentar fazer seu próximo projeto.