Pular para o conteúdo principal

Como desenvolver e testar um dApp em uma rede de teste local multicliente

clientes
nós
smart contracts
componibilidade
camada de consenso
camada de execução
testando
Intermediário
Tedi Mitiku
11 de abril de 2023
12 minutos de leitura

Introdução

Este guia o orienta no processo de instanciar uma rede de teste local configurável do Ethereum, implantar um contrato inteligente nela e usar a rede de teste para executar testes em seu dApp. Este guia foi elaborado para desenvolvedores de dApps que queiram desenvolver e testar seus dApps localmente em diferentes configurações de rede antes de implantar em uma rede de teste ativa ou na rede principal.

Neste guia, você irá:

  • Instanciar uma rede de teste local do Ethereum com o eth-network-package (opens in a new tab) usando 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 de clientes EL/CL específicos, para permitir fluxos de trabalho de desenvolvimento e teste em várias configurações de rede.

O que é Kurtosis?

Kurtosis (opens in a new tab) é um sistema de compilação componível projetado para configurar ambientes de teste de 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 eth-network-package da 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 componí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, que é uma das principais razões pelas quais a Ethereum Foundation usou o Kurtosis para testar a Fusão (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 que você tenha:

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

Observação: Este comando nomeia sua rede: "local-eth-testnet" usando a flag --enclave.

O Kurtosis imprimirá os passos que está a tomar internamente enquanto trabalha para interpretar, validar e executar as instruções. Ao final, você deverá ver um resultado semelhante ao seguinte:

Parabéns! Você usou o Kurtosis para instanciar uma rede de teste local do Ethereum, com um cliente CL (lighthouse) e um cliente EL (geth), sobre 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á "artefatos de arquivo" e "serviços de usuário".

Os Artefatos de arquivo (opens in a new tab) no 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 no seu enclave. Você notará que um único nó, com um cliente EL e 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, você 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 na 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, execute:

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):

Configurar o Hardhat para usar a rede de teste local

Com seu ambiente de desenvolvimento de dApp configurado, você agora 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 no seu arquivo de configuração hardhat.config.ts pela porta da saída do URI rpc 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 está agora 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 como:

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.

Implantar e testar 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 teste 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 se parecer com:

ChipToken implantado em: 0xAb2A01BC351770D09611Ac80f1DE076D56E0487d

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

A saída deve ser algo como:

npx hardhat test --network localnet

A saída deve ser algo como:

ChipToken
    emissão
      ✔ deve emitir 1000 fichas para o JOGADOR UM

  1 aprovado (654ms)

Revisão

Neste ponto, você configurou um ambiente de desenvolvimento de dApp, conectou-o a uma rede Ethereum local 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 várias 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 configurado, 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 como 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 através 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 Ethereum local.

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

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

Essa configuração cria uma rede heterogênea de implementações de nós Ethereum para testar seu dApp. Seu arquivo de configuração deve ficar assim:

Cada estrutura participants mapeia para um nó na rede, portanto, 3 estruturas participants instruirão o Kurtosis a 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 de gênese 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)"

Observação: 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á por um tempo e imprimirá os passos individuais que estão ocorrendo. Eventualmente, a saída deve ser algo como:

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), realize as mesmas operações que fizemos antes, substituindo <$YOUR_PORT> na estrutura localnet em seu arquivo de configuração hardhat.config.ts pela porta da saída do URI rpc 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 Docker usando o Kurtosis
  • Conectou seu ambiente de desenvolvimento de dApp local à rede Ethereum local
  • Implantou um dApp e executou um teste simples nele na rede Ethereum local
  • Configurou a rede Ethereum subjacente para ter 3 nós

Gostaríamos muito de saber sua opinião sobre o que deu certo para você, o que poderia ser melhorado, ou para responder a qualquer uma de suas perguntas. Não hesite em nos contatar via GitHub (opens in a new tab) ou envie-nos um e-mail (opens email client)!

Outros exemplos e guias

Nós o encorajamos a conferir nosso início rápido (opens in a new tab) (onde você construirá um banco de dados Postgres e uma API sobre ele) e nossos outros exemplos em nosso repositório awesome-kurtosis (opens in a new tab) onde você encontrará ótimos exemplos, incluindo pacotes para:

Última atualização da página: 3 de março de 2026

Este tutorial foi útil?