Passer au contenu principal

Comment développer et tester une dApp sur un réseau de test local multi-clients

clients
nœuds
contrats intelligents
composabilité
couche de consensus
couche d'exécution
test
Intermédiaire
Tedi Mitiku
11 avril 2023
12 minutes de lecture

Introduction

Ce guide vous explique comment instancier un réseau de test Ethereum local configurable, y déployer un contrat intelligent et utiliser ce réseau de test pour exécuter des tests sur votre dApp. Ce guide est conçu pour les développeurs de dApps qui souhaitent développer et tester leurs dApps localement avec différentes configurations de réseau avant de les déployer sur un réseau de test public ou sur le réseau principal.

Dans ce guide, vous allez :

  • Instancier un réseau de test Ethereum local avec le eth-network-package (opens in a new tab) en utilisant Kurtosis (opens in a new tab),
  • Connecter votre environnement de développement de dApp Hardhat au réseau de test local pour compiler, déployer et tester une dApp, et
  • Configurer le réseau de test local, y compris des paramètres comme le nombre de nœuds et les paires de clients EL/CL spécifiques, pour permettre des flux de travail de développement et de test sur diverses configurations de réseau.

Qu'est-ce que Kurtosis ?

Kurtosis (opens in a new tab) est un système de construction composable conçu pour configurer des environnements de test multi-conteneurs. Il permet spécifiquement aux développeurs de créer des environnements reproductibles qui nécessitent une logique de configuration dynamique, comme les réseaux de test de blockchain.

Dans ce guide, le paquet eth-network-package de Kurtosis lance un réseau de test Ethereum local avec prise en charge du client de couche d'exécution (EL) geth (opens in a new tab), ainsi que des clients de couche de consensus (CL) teku (opens in a new tab), lighthouse (opens in a new tab) et lodestar (opens in a new tab). Ce paquet sert d'alternative configurable et composable aux réseaux dans des cadres de développement comme Hardhat Network, Ganache et Anvil. Kurtosis offre aux développeurs un contrôle et une flexibilité accrus sur les réseaux de test qu'ils utilisent, ce qui est l'une des raisons principales pour lesquelles la Fondation Ethereum a utilisé Kurtosis pour tester la Fusion (opens in a new tab) et continue de l'utiliser pour tester les mises à niveau du réseau.

Configuration de Kurtosis

Avant de continuer, assurez-vous d'avoir :

Instanciation d'un réseau de test Ethereum local

Pour lancer un réseau de test Ethereum local, exécutez :

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

Remarque : cette commande nomme votre réseau « local-eth-testnet » à l'aide de l'indicateur --enclave.

Kurtosis affichera les étapes qu'il exécute en arrière-plan pendant qu'il interprète, valide, puis exécute les instructions. À la fin, vous devriez voir une sortie qui ressemble à ce qui suit :

Félicitations ! Vous avez utilisé Kurtosis pour instancier un réseau de test Ethereum local, avec un client CL (lighthouse) et un client EL (geth), via Docker.

Résumé

Dans cette section, vous avez exécuté une commande qui a demandé à Kurtosis d'utiliser le eth-network-package hébergé à distance sur GitHub (opens in a new tab) pour lancer un réseau de test Ethereum local dans une Enclave (opens in a new tab) Kurtosis. À l'intérieur de votre enclave, vous trouverez à la fois des « artefacts de fichiers » et des « services utilisateur ».

Les Artefacts de fichiers (opens in a new tab) dans votre enclave incluent toutes les données générées et utilisées pour amorcer les clients EL et CL. Les données ont été créées à l'aide du service prelaunch-data-generator construit à partir de cette image Docker (opens in a new tab)

Les services utilisateur affichent tous les services conteneurisés fonctionnant dans votre enclave. Vous remarquerez qu'un seul nœud, comprenant à la fois un client EL et un client CL, a été créé.

Connecter votre environnement de développement de dApp au réseau de test Ethereum local

Configurer l'environnement de développement de la dApp

Maintenant que vous disposez d'un réseau de test local en cours d'exécution, vous pouvez connecter votre environnement de développement de dApp pour utiliser votre réseau de test local. Le cadre de développement Hardhat sera utilisé dans ce guide pour déployer une dApp de blackjack sur votre réseau de test local.

Pour configurer votre environnement de développement de dApp, clonez le dépôt qui contient notre exemple de dApp et installez ses dépendances, exécutez :

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

Le dossier smart-contract-example (opens in a new tab) utilisé ici contient la configuration typique pour un développeur de dApp utilisant le cadre de développement Hardhat (opens in a new tab) :

Configurer Hardhat pour utiliser le réseau de test local

Une fois votre environnement de développement de dApp configuré, vous allez maintenant connecter Hardhat pour utiliser le réseau de test Ethereum local généré à l'aide de Kurtosis. Pour ce faire, remplacez <$YOUR_PORT> dans la structure localnet de votre fichier de configuration hardhat.config.ts par le port de la sortie de l'URI rpc de n'importe quel service el-client-<num>. Dans cet exemple, le port serait 64248. Votre port sera différent.

Exemple dans hardhat.config.ts :

Une fois que vous avez enregistré votre fichier, votre environnement de développement de dApp Hardhat est maintenant connecté à votre réseau de test Ethereum local ! Vous pouvez vérifier que votre réseau de test fonctionne en exécutant :

npx hardhat balances --network localnet

La sortie devrait ressembler à ceci :

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

Cela confirme que Hardhat utilise votre réseau de test local et détecte les comptes pré-financés créés par le eth-network-package.

Déployer et tester votre dApp localement

L'environnement de développement de la dApp étant entièrement connecté au réseau de test Ethereum local, vous pouvez maintenant exécuter des flux de travail de développement et de test sur votre dApp en utilisant le réseau de test local.

Pour compiler et déployer le contrat intelligent ChipToken.sol pour le prototypage et le développement local, exécutez :

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

La sortie devrait ressembler à :

ChipToken déployé à : 0xAb2A01BC351770D09611Ac80f1DE076D56E0487d

Essayez maintenant d'exécuter le test simple.js sur votre dApp locale pour confirmer que chaque joueur de notre dApp de Blackjack a reçu 1000 jetons frappés pour lui :

La sortie devrait ressembler à ceci :

npx hardhat test --network localnet

La sortie devrait ressembler à ceci :

ChipToken
    mint
      ✔ devrait frapper 1000 jetons pour PLAYER ONE

  1 réussi (654ms)

Résumé

À ce stade, vous avez configuré un environnement de développement de dApp, l'avez connecté à un réseau Ethereum local créé par Kurtosis, et avez compilé, déployé et exécuté un test simple sur votre dApp.

Explorons maintenant comment vous pouvez configurer le réseau sous-jacent pour tester nos dApps dans diverses configurations de réseau.

Configuration du réseau de test Ethereum local

Modification des configurations du client et du nombre de nœuds

Votre réseau de test Ethereum local peut être configuré pour utiliser différentes paires de clients EL et CL, ainsi qu'un nombre variable de nœuds, en fonction du scénario et de la configuration réseau spécifique que vous souhaitez développer ou tester. Cela signifie qu'une fois configuré, vous pouvez lancer un réseau de test local personnalisé et l'utiliser pour exécuter les mêmes flux de travail (déploiement, tests, etc.) dans diverses configurations de réseau pour vous assurer que tout fonctionne comme prévu. Pour en savoir plus sur les autres paramètres que vous pouvez modifier, consultez ce lien.

Essayez ! Vous pouvez transmettre diverses options de configuration au eth-network-package via un fichier JSON. Ce fichier JSON de paramètres réseau fournit les configurations spécifiques que Kurtosis utilisera pour configurer le réseau Ethereum local.

Prenez le fichier de configuration par défaut et modifiez-le pour lancer trois nœuds avec différentes paires EL/CL :

  • Nœud 1 avec geth/lighthouse
  • Nœud 2 avec geth/lodestar
  • Nœud 3 avec geth/teku

Cette configuration crée un réseau hétérogène d'implémentations de nœuds Ethereum pour tester votre dApp. Votre fichier de configuration devrait maintenant ressembler à :

Chaque structure participants correspond à un nœud du réseau, donc 3 structures participants indiqueront à Kurtosis de lancer 3 nœuds dans votre réseau. Chaque structure participants vous permettra de spécifier la paire EL et CL utilisée pour ce nœud spécifique.

La structure network_params configure les paramètres réseau qui sont utilisés pour créer les fichiers de genèse pour chaque nœud ainsi que d'autres paramètres comme les secondes par créneau du réseau.

Enregistrez votre fichier de paramètres modifié dans le répertoire de votre choix (dans l'exemple ci-dessous, il est enregistré sur le bureau), puis utilisez-le pour exécuter votre paquetage Kurtosis en exécutant :

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

Remarque : la commande kurtosis clean -a est utilisée ici pour demander à Kurtosis de détruire l'ancien réseau de test et son contenu avant d'en démarrer un nouveau.

Encore une fois, Kurtosis fonctionnera un instant et affichera les différentes étapes qui se déroulent. Finalement, la sortie devrait ressembler à :

Félicitations ! Vous avez configuré avec succès votre réseau de test local pour avoir 3 nœuds au lieu de 1. Pour exécuter les mêmes flux de travail que précédemment sur votre dApp (déploiement et test), effectuez les mêmes opérations que nous avons faites auparavant en remplaçant le <$YOUR_PORT> dans la structure localnet de votre fichier de configuration hardhat.config.ts par le port de la sortie de l'URI rpc de n'importe quel service el-client-<num> dans votre nouveau réseau de test local à 3 nœuds.

Conclusion

Et c'est tout ! Pour résumer ce court guide, vous avez :

  • Créé un réseau de test Ethereum local sur Docker en utilisant Kurtosis
  • Connecté votre environnement de développement de dApp local au réseau Ethereum local
  • Déployé une dApp et exécuté un test simple sur celle-ci sur le réseau Ethereum local
  • Configuré le réseau Ethereum sous-jacent pour avoir 3 nœuds

Nous serions ravis d'avoir votre retour sur ce qui s'est bien passé pour vous, ce qui pourrait être amélioré, ou de répondre à vos questions. N'hésitez pas à nous contacter via GitHub (opens in a new tab) ou à nous envoyer un e-mail (opens email client) !

Autres exemples et guides

Nous vous encourageons à consulter notre guide de démarrage rapide (opens in a new tab) (où vous construirez une base de données Postgres et une API par-dessus) et nos autres exemples dans notre dépôt awesome-kurtosis (opens in a new tab) où vous trouverez d'excellents exemples, y compris des paquetages pour :

Dernière mise à jour de la page : 3 mars 2026

Ce tutoriel vous a-t-il été utile ?