Saltar al contenido principal

Cómo desarrollar y probar una dApp en una red de prueba local multicliente

clientes
nodos
contratos Inteligentes
composabilidad
capa de consenso
capa de ejecución
pruebas
Intermedio
Tedi Mitiku
11 de abril de 2023
12 minuto leído

Introducción

Esta guía le guía a través del proceso de instanciación de una red de prueba local configurable de Ethereum, desplegando un contrato inteligente en ella y usando la red de prueba para ejecutar pruebas en su dApp. Esta guía está diseñada para desarrolladores de dApps que desean desarrollar y probar sus dApps localmente con diferentes configuraciones de red antes de desplegarlas en una red de prueba activa o en la red principal.

En esta guía, usted:

  • Instanciar una red de prueba local de Ethereum con el eth-network-package (opens in a new tab) usando Kurtosis (opens in a new tab),
  • Conectar su entorno de desarrollo de dApps Hardhat a la red de prueba local para compilar, desplegar y probar una dApp, y
  • Configurar la red de prueba local, incluyendo parámetros como el número de nodos y emparejamientos específicos de clientes EL/CL, para permitir flujos de trabajo de desarrollo y prueba con varias configuraciones de red.

¿Qué es Kurtosis?

Kurtosis (opens in a new tab) es un sistema de compilación componible diseñado para configurar entornos de prueba de múltiples contenedores. Permite específicamente a los desarrolladores crear entornos reproducibles que requieren una lógica de configuración dinámica, como las redes de prueba de la cadena de bloques.

En esta guía, el paquete eth-network-package de Kurtosis pone en marcha una red de prueba local de Ethereum con soporte para el cliente de la capa de ejecución (EL) geth (opens in a new tab), así como para los clientes de la capa de consenso (CL) teku (opens in a new tab), lighthouse (opens in a new tab) y lodestar (opens in a new tab). Este paquete sirve como una alternativa configurable y componible a las redes en marcos como Hardhat Network, Ganache y Anvil. Kurtosis ofrece a los desarrolladores un mayor control y flexibilidad sobre las redes de prueba que utilizan, que es una razón importante por la que la Ethereum Foundation utilizó Kurtosis para probar la Fusión (opens in a new tab) y continúa usándolo para probar las actualizaciones de la red.

Configuración de Kurtosis

Antes de continuar, asegúrese de que tiene:

Instanciar una red de prueba local de Ethereum

Para poner en marcha una red de prueba local de Ethereum, ejecute:

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

Nota: Este comando nombra su red como: "local-eth-testnet" usando la bandera --enclave.

Kurtosis imprimirá los pasos que está realizando internamente mientras trabaja para interpretar, validar y luego ejecutar las instrucciones. Al final, debería ver una salida que se parezca a la siguiente:

¡Felicitaciones! Ha utilizado Kurtosis para instanciar una red de prueba local de Ethereum, con un cliente de CL (lighthouse) y un cliente de EL (geth), sobre Docker.

Revisión

En esta sección, ejecutó un comando que ordenó a Kurtosis que utilizara el eth-network-package alojado de forma remota en GitHub (opens in a new tab) para poner en marcha una red de prueba local de Ethereum dentro de un Enclave (opens in a new tab) de Kurtosis. Dentro de su enclave, encontrará tanto "artefactos de archivo" como "servicios de usuario".

Los Artefactos de archivo (opens in a new tab) en su enclave incluyen todos los datos generados y utilizados para arrancar los clientes EL y CL. Los datos se crearon utilizando el servicio prelaunch-data-generator creado a partir de esta imagen de Docker (opens in a new tab)

Los servicios de usuario muestran todos los servicios en contenedores que operan en su enclave. Notará que se ha creado un único nodo, que cuenta con un cliente de EL y un cliente de CL.

Conecte su entorno de desarrollo de dApp a la red de prueba local de Ethereum

Configurar el entorno de desarrollo de dApp

Ahora que tiene una red de prueba local en funcionamiento, puede conectar su entorno de desarrollo de dApp para usar su red de prueba local. El marco Hardhat se utilizará en esta guía para desplegar una dApp de blackjack en su red de prueba local.

Para configurar su entorno de desarrollo de dApp, clone el repositorio que contiene nuestra dApp de muestra e instale sus dependencias, ejecute:

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

La carpeta smart-contract-example (opens in a new tab) utilizada aquí contiene la configuración típica para un desarrollador de dApp que utiliza el marco Hardhat (opens in a new tab):

Configurar Hardhat para usar la red de prueba local

Con su entorno de desarrollo de dApp configurado, ahora conectará Hardhat para usar la red de prueba local de Ethereum generada usando Kurtosis. Para lograr esto, reemplace <$YOUR_PORT> en la estructura localnet en su archivo de configuración hardhat.config.ts con el puerto de la salida del URI rpc de cualquier servicio el-client-<num>. En este caso de muestra, el puerto sería 64248. Su puerto será diferente.

Ejemplo en hardhat.config.ts:

Una vez que guarde el archivo, ¡su entorno de desarrollo de dApps Hardhat estará conectado a su red de prueba local de Ethereum! Puede verificar que su red de prueba funciona ejecutando:

npx hardhat balances --network localnet

La salida debería parecerse a esto:

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

Esto confirma que Hardhat está usando su red de prueba local y detecta las cuentas prefinanciadas creadas por el eth-network-package.

Despliegue y pruebe su dApp localmente

Con el entorno de desarrollo de dApp totalmente conectado a la red de prueba local de Ethereum, ahora puede ejecutar flujos de trabajo de desarrollo y prueba en su dApp utilizando la red de prueba local.

Para compilar y desplegar el contrato inteligente ChipToken.sol para prototipos y desarrollo local, ejecute:

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

La salida debería ser algo como:

ChipToken desplegado en: 0xAb2A01BC351770D09611Ac80f1DE076D56E0487d

Ahora intente ejecutar la prueba simple.js en su dApp local para confirmar que a cada jugador de nuestra dApp de Blackjack se le hayan acuñado 1000:

La salida debería parecerse a esto:

npx hardhat test --network localnet

La salida debería parecerse a esto:

ChipToken
    mint
      ✔ debería acuñar 1000 fichas para PLAYER ONE

  1 aprobada (654ms)

Revisión

En este punto, ya ha configurado un entorno de desarrollo de dApp, lo ha conectado a una red local de Ethereum creada por Kurtosis, y ha compilado, desplegado y ejecutado una prueba simple en su dApp.

Ahora exploremos cómo puede configurar la red subyacente para probar nuestras dApps bajo diversas configuraciones de red.

Configuración de la red de prueba local de Ethereum

Cambio de las configuraciones del cliente y el número de nodos

Su red de prueba local de Ethereum puede configurarse para usar diferentes pares de clientes EL y CL, así como un número variable de nodos, dependiendo del escenario y la configuración de red específica que desee desarrollar o probar. Esto significa que, una vez configurada, puede poner en marcha una red de prueba local personalizada y utilizarla para ejecutar los mismos flujos de trabajo (despliegue, pruebas, etc.) bajo varias configuraciones de red para garantizar que todo funcione como se espera. Para obtener más información sobre los otros parámetros que puede modificar, visite este enlace.

¡Pruébelo! Puede pasar varias opciones de configuración al eth-network-package a través de un archivo JSON. Este archivo JSON de parámetros de red proporciona las configuraciones específicas que Kurtosis utilizará para configurar la red local de Ethereum.

Tome el archivo de configuración predeterminado y edítelo para poner en marcha dos nodos con diferentes pares EL/CL:

  • Nodo 1 con geth/lighthouse
  • Nodo 2 con geth/lodestar
  • Nodo 3 con geth/teku

Esta configuración crea una red heterogénea de implementaciones de nodos de Ethereum para probar su dApp. Su archivo de configuración debería tener este aspecto:

Cada estructura de participants se corresponde con un nodo de la red, por lo que 3 estructuras de participants le indicarán a Kurtosis que ponga en marcha 3 nodos en su red. Cada estructura de participants le permitirá especificar el par EL y CL utilizado para ese nodo específico.

La estructura network_params configura los ajustes de red que se utilizan para crear los archivos de génesis para cada nodo, así como otros ajustes como los segundos por ranura de la red.

Guarde el archivo de parámetros editado en el directorio que desee (en el siguiente ejemplo, se guarda en el escritorio) y, a continuación, utilícelo para ejecutar su paquete Kurtosis ejecutando:

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

Nota: el comando kurtosis clean -a se utiliza aquí para indicar a Kurtosis que destruya la antigua red de prueba y su contenido antes de iniciar una nueva.

De nuevo, Kurtosis funcionará durante un rato e imprimirá los pasos individuales que se están llevando a cabo. Finalmente, la salida debería ser algo como:

¡Felicitaciones! Ha configurado correctamente su red de prueba local para que tenga 3 nodos en lugar de 1. Para ejecutar los mismos flujos de trabajo que antes en su dApp (despliegue y prueba), realice las mismas operaciones que hicimos antes reemplazando <$YOUR_PORT> en la estructura localnet en su archivo de configuración hardhat.config.ts con el puerto de la salida del URI rpc de cualquier servicio el-client-<num> en su nueva red de prueba local de 3 nodos.

Conclusión

¡Y eso es todo! Para recapitular esta breve guía, usted:

  • Creó una red de prueba local de Ethereum sobre Docker usando Kurtosis
  • Conectó su entorno de desarrollo de dApp local a la red local de Ethereum
  • Desplegó una dApp y ejecutó una prueba simple en ella en la red local de Ethereum
  • Configuró la red subyacente de Ethereum para tener 3 nodos

Nos encantaría saber qué le ha parecido, qué se podría mejorar o responder a cualquiera de sus preguntas. No dude en ponerse en contacto con nosotros a través de GitHub (opens in a new tab) o envíenos un correo electrónico (opens email client).

Otros ejemplos y guías

Le animamos a que consulte nuestro inicio rápido (opens in a new tab) (donde creará una base de datos Postgres y una API sobre ella) y nuestros otros ejemplos en nuestro repositorio awesome-kurtosis (opens in a new tab) donde encontrará algunos ejemplos geniales, incluyendo paquetes para:

  • Poner en marcha la misma red de prueba local de Ethereum, pero con servicios adicionales conectados como un generador de spam de transacciones (para simular transacciones), un monitor de bifurcaciones y una instancia conectada de Grafana y Prometheus
  • Realizar una prueba de subredes (opens in a new tab) en la misma red local de Ethereum

Última actualización de la página: 3 de marzo de 2026

¿Te resultó útil este tutorial?