Pular para o conteúdo principal

Como desenvolver e testar um dapp em uma rede de teste local com múltiplos clientes

clientes
nós
contratos inteligentes
compunibilidade
camada de consenso
camada de execução
tes
Intermediário
Tedi Mitiku
11 de abril de 2023
12 minutos de leitura

Introdução

Este guia orienta você no processo de instanciação de uma rede de teste local configurável do Ethereum, na implantação de um contrato inteligente nela e no uso da rede de teste para executar testes em seu aplicativo descentralizado (dapp). Este guia foi desenvolvido para desenvolvedores de dapps que desejam desenvolver e testar seus dapps localmente em diferentes configurações de rede antes de implantar em uma rede de teste ativa ou na Mainnet.

Neste guia, você irá:

  • Instanciar uma rede de teste local do Ethereum com o eth-network-package (opens in a new tab) usando o Kurtosis (opens in a new tab),
  • Conectar seu ambiente de desenvolvimento de dapp Hardhat à rede de teste local para compilar, implantar e testar um dapp, e
  • Configurar a rede de teste local, incluindo parâmetros como o número de nós e pares específicos de clientes da camada de execução (EL) e da camada de consenso (CL), para permitir fluxos de trabalho de desenvolvimento e testes em várias configurações de rede.

O que é o Kurtosis?

O Kurtosis (opens in a new tab) é um sistema de compilação compunível projetado para configurar ambientes de teste com múltiplos contêineres. Ele permite especificamente que os desenvolvedores criem ambientes reprodutíveis que exigem lógica de configuração dinâmica, como redes de teste de blockchain.

Neste guia, o pacote eth-network-package do Kurtosis inicia uma rede de teste local do Ethereum com suporte para o cliente da camada de execução (EL) geth (opens in a new tab), bem como para os clientes da camada de consenso (CL) teku (opens in a new tab), lighthouse (opens in a new tab) e lodestar (opens in a new tab). Este pacote serve como uma alternativa configurável e compunível para redes em frameworks como Hardhat Network, Ganache e Anvil. O Kurtosis oferece aos desenvolvedores maior controle e flexibilidade sobre as redes de teste que utilizam, o que é um dos principais motivos pelos quais a Fundação Ethereum usou o Kurtosis para testar o The Merge (opens in a new tab) e continua a usá-lo para testar atualizações de rede.

Configurando o Kurtosis

Antes de prosseguir, certifique-se de ter:

Instanciando uma rede de teste local do Ethereum

Para iniciar uma rede de teste local do Ethereum, execute:

kurtosis --enclave local-eth-testnet run github.com/kurtosis-tech/eth-network-package

Nota: Este comando nomeia sua rede como: "local-eth-testnet” usando a flag --enclave.

O Kurtosis imprimirá as etapas que está realizando internamente enquanto trabalha para interpretar, validar e, em seguida, executar as instruções. No final, você deverá ver uma saída semelhante à seguinte:

Parabéns! Você usou o Kurtosis para instanciar uma rede de teste local do Ethereum, com um cliente da camada de consenso (CL) (lighthouse) e um cliente da camada de execução (EL) (geth), sobre o Docker.

Revisão

Nesta seção, você executou um comando que instruiu o Kurtosis a usar o eth-network-package hospedado remotamente no GitHub (opens in a new tab) para iniciar uma rede de teste local do Ethereum dentro de um Enclave (opens in a new tab) do Kurtosis. Dentro do seu enclave, você encontrará tanto "artefatos de arquivo" quanto "serviços de usuário".

Os Artefatos de Arquivo (opens in a new tab) em seu enclave incluem todos os dados gerados e utilizados para inicializar os clientes EL e CL. Os dados foram criados usando o serviço prelaunch-data-generator construído a partir desta imagem Docker (opens in a new tab)

Os serviços de usuário exibem todos os serviços em contêineres operando em seu enclave. Você notará que um único nó, apresentando tanto um cliente EL quanto um cliente CL, foi criado.

Conecte seu ambiente de desenvolvimento de dapp à rede de teste local do Ethereum

Configure o ambiente de desenvolvimento de dapp

Agora que você tem uma rede de teste local em execução, pode conectar seu ambiente de desenvolvimento de dapp para usar sua rede de teste local. O framework Hardhat será usado neste guia para implantar um dapp de blackjack em sua rede de teste local.

Para configurar seu ambiente de desenvolvimento de dapp, clone o repositório que contém nosso dapp de exemplo e instale suas dependências, executando:

git clone https://github.com/kurtosis-tech/awesome-kurtosis.git && cd awesome-kurtosis/smart-contract-example && yarn

A pasta smart-contract-example (opens in a new tab) usada aqui contém a configuração típica para um desenvolvedor de dapp usando o framework Hardhat (opens in a new tab):

Configure o Hardhat para usar a rede de teste local

Com o seu ambiente de desenvolvimento de dapp configurado, agora você conectará o Hardhat para usar a rede de teste local do Ethereum gerada usando o Kurtosis. Para fazer isso, substitua <$YOUR_PORT> na estrutura localnet em seu arquivo de configuração hardhat.config.ts pela porta da saída do rpc uri de qualquer serviço el-client-<num>. Neste caso de exemplo, a porta seria 64248. Sua porta será diferente.

Exemplo em hardhat.config.ts:

Depois de salvar seu arquivo, seu ambiente de desenvolvimento de dapp Hardhat estará conectado à sua rede de teste local do Ethereum! Você pode verificar se sua rede de teste está funcionando executando:

npx hardhat balances --network localnet

A saída deve ser algo parecido com isto:

0x878705ba3f8Bc32FCf7F4CAa1A35E72AF65CF766 has balance 10000000000000000000000000
0x4E9A3d9D1cd2A2b2371b8b3F489aE72259886f1A has balance 10000000000000000000000000
0xdF8466f277964Bb7a0FFD819403302C34DCD530A has balance 10000000000000000000000000
0x5c613e39Fc0Ad91AfDA24587e6f52192d75FBA50 has balance 10000000000000000000000000
0x375ae6107f8cC4cF34842B71C6F746a362Ad8EAc has balance 10000000000000000000000000
0x1F6298457C5d76270325B724Da5d1953923a6B88 has balance 10000000000000000000000000

Isso confirma que o Hardhat está usando sua rede de teste local e detecta as contas pré-financiadas criadas pelo eth-network-package.

Implante e teste seu dapp localmente

Com o ambiente de desenvolvimento de dapp totalmente conectado à rede de teste local do Ethereum, agora você pode executar fluxos de trabalho de desenvolvimento e testes em seu dapp usando a rede de teste local.

Para compilar e implantar o contrato inteligente ChipToken.sol para prototipagem e desenvolvimento local, execute:

npx hardhat compile
npx hardhat run scripts/deploy.ts --network localnet

A saída deve ser algo parecido com:

ChipToken deployed to: 0xAb2A01BC351770D09611Ac80f1DE076D56E0487d

Agora tente executar o teste simple.js em seu dapp local para confirmar que cada jogador em nosso dapp de Blackjack tem 1000 cunhados para eles:

A saída deve ser algo parecido com isto:

npx hardhat test --network localnet

A saída deve ser algo parecido com isto:

ChipToken
    mint
      ✔ should mint 1000 chips for PLAYER ONE

  1 passing (654ms)

Revisão

Neste ponto, você configurou um ambiente de desenvolvimento de dapp, conectou-o a uma rede local do Ethereum criada pelo Kurtosis e compilou, implantou e executou um teste simples em seu dapp.

Agora vamos explorar como você pode configurar a rede subjacente para testar nossos dapps sob diferentes configurações de rede.

Configurando a rede de teste local do Ethereum

Alterando as configurações do cliente e o número de nós

Sua rede de teste local do Ethereum pode ser configurada para usar diferentes pares de clientes EL e CL, bem como um número variável de nós, dependendo do cenário e da configuração de rede específica que você deseja desenvolver ou testar. Isso significa que, uma vez configurada, você pode iniciar uma rede de teste local personalizada e usá-la para executar os mesmos fluxos de trabalho (implantação, testes, etc.) sob várias configurações de rede para garantir que tudo funcione conforme o esperado. Para saber mais sobre os outros parâmetros que você pode modificar, visite este link.

Experimente! Você pode passar várias opções de configuração para o eth-network-package por meio de um arquivo JSON. Este arquivo JSON de parâmetros de rede fornece as configurações específicas que o Kurtosis usará para configurar a rede local do Ethereum.

Pegue o arquivo de configuração padrão e edite-o para iniciar dois nós com diferentes pares EL/CL:

  • Nó 1 com geth/lighthouse
  • Nó 2 com geth/lodestar
  • Nó 3 com geth/teku

Esta configuração cria uma rede heterogênea de implementações de nós do Ethereum para testar seu dapp. Seu arquivo de configuração agora deve ser parecido com:

Cada estrutura participants mapeia para um nó na rede, portanto, 3 estruturas participants dirão ao Kurtosis para iniciar 3 nós em sua rede. Cada estrutura participants permitirá que você especifique o par EL e CL usado para aquele nó específico.

A estrutura network_params configura as definições de rede que são usadas para criar os arquivos genesis para cada nó, bem como outras configurações, como os segundos por slot da rede.

Salve seu arquivo de parâmetros editado em qualquer diretório que desejar (no exemplo abaixo, ele é salvo na área de trabalho) e, em seguida, use-o para executar seu pacote Kurtosis executando:

kurtosis clean -a && kurtosis run --enclave local-eth-testnet github.com/kurtosis-tech/eth-network-package "$(cat ~/eth-network-params.json)"

Nota: o comando kurtosis clean -a é usado aqui para instruir o Kurtosis a destruir a antiga rede de teste e seu conteúdo antes de iniciar uma nova.

Novamente, o Kurtosis trabalhará um pouco e imprimirá as etapas individuais que estão ocorrendo. Eventualmente, a saída deve ser algo parecido com:

Parabéns! Você configurou com sucesso sua rede de teste local para ter 3 nós em vez de 1. Para executar os mesmos fluxos de trabalho que você fez antes em seu dapp (implantar e testar), execute as mesmas operações que fizemos antes substituindo o <$YOUR_PORT> na estrutura localnet em seu arquivo de configuração hardhat.config.ts pela porta da saída do rpc uri de qualquer serviço el-client-<num> em sua nova rede de teste local de 3 nós.

Conclusão

E é isso! Para recapitular este breve guia, você:

  • Criou uma rede de teste local do Ethereum sobre o Docker usando o Kurtosis
  • Conectou seu ambiente de desenvolvimento de dapp local à rede local do Ethereum
  • Implantou um dapp e executou um teste simples nele na rede local do Ethereum
  • Configurou a rede Ethereum subjacente para ter 3 nós

Adoraríamos saber de você o que funcionou bem, o que poderia ser melhorado ou responder a qualquer uma de suas perguntas. Não hesite em entrar em contato via GitHub (opens in a new tab) ou enviar um e-mail para nós (opens email client)!

Outros exemplos e guias

Incentivamos você a conferir nosso guia de início rápido (opens in a new tab) (onde você construirá um banco de dados Postgres e uma API por cima) e nossos outros exemplos em nosso repositório awesome-kurtosis (opens in a new tab), onde você encontrará alguns ótimos exemplos, incluindo pacotes para: