Ethereum + Python = Brownie

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 .



help 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



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
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.




All Articles