Vai al contenuto principale

Come sviluppare e testare una dapp su una testnet locale multi-client

client
nodi
smart contract
componibilità
livello di consenso
livello di esecuzione
test
Intermedio
Tedi Mitiku
11 aprile 2023
11 minuti di lettura

Introduzione

Questa guida ti accompagna nel processo di istanziazione di una testnet Ethereum locale configurabile, nella distribuzione di uno smart contract su di essa e nell'utilizzo della testnet per eseguire test sulla tua applicazione decentralizzata (dapp). Questa guida è pensata per gli sviluppatori di dapp che desiderano sviluppare e testare le proprie dapp localmente su diverse configurazioni di rete prima di distribuirle su una testnet pubblica o sulla Mainnet.

In questa guida:

  • Istanzierai una testnet Ethereum locale con eth-network-package (opens in a new tab) utilizzando Kurtosis (opens in a new tab),
  • Connetterai il tuo ambiente di sviluppo per dapp Hardhat alla testnet locale per compilare, distribuire e testare una dapp, e
  • Configurerai la testnet locale, inclusi parametri come il numero di nodi e gli abbinamenti specifici di client EL/CL, per abilitare i flussi di lavoro di sviluppo e test su varie configurazioni di rete.

Cos'è Kurtosis?

Kurtosis (opens in a new tab) è un sistema di build componibile progettato per configurare ambienti di test multi-container. Consente specificamente agli sviluppatori di creare ambienti riproducibili che richiedono una logica di configurazione dinamica, come le testnet blockchain.

In questa guida, il pacchetto eth-network-package di Kurtosis avvia una testnet Ethereum locale con supporto per il client del livello di esecuzione (EL) geth (opens in a new tab), oltre ai client del livello di consenso (CL) teku (opens in a new tab), lighthouse (opens in a new tab) e lodestar (opens in a new tab). Questo pacchetto funge da alternativa configurabile e componibile alle reti in framework come Hardhat Network, Ganache e Anvil. Kurtosis offre agli sviluppatori un maggiore controllo e flessibilità sulle testnet che utilizzano, il che è uno dei motivi principali per cui la Ethereum Foundation ha utilizzato Kurtosis per testare The Merge (opens in a new tab) e continua a utilizzarlo per testare gli aggiornamenti della rete.

Configurazione di Kurtosis

Prima di procedere, assicurati di aver:

Istanziare una testnet Ethereum locale

Per avviare una testnet Ethereum locale, esegui:

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

Nota: questo comando nomina la tua rete: "local-eth-testnet” utilizzando il flag --enclave.

Kurtosis stamperà i passaggi che sta eseguendo internamente mentre lavora per interpretare, convalidare e quindi eseguire le istruzioni. Alla fine, dovresti vedere un output simile al seguente:

Congratulazioni! Hai utilizzato Kurtosis per istanziare una testnet Ethereum locale, con un client CL (lighthouse) e un client EL (geth), su Docker.

Riepilogo

In questa sezione, hai eseguito un comando che ha indicato a Kurtosis di utilizzare il pacchetto eth-network-package ospitato in remoto su GitHub (opens in a new tab) per avviare una testnet Ethereum locale all'interno di un'Enclave (opens in a new tab) di Kurtosis. All'interno della tua enclave, troverai sia "artefatti di file" che "servizi utente".

Gli Artefatti di file (opens in a new tab) nella tua enclave includono tutti i dati generati e utilizzati per avviare i client EL e CL. I dati sono stati creati utilizzando il servizio prelaunch-data-generator compilato da questa immagine Docker (opens in a new tab)

I servizi utente mostrano tutti i servizi containerizzati operativi nella tua enclave. Noterai che è stato creato un singolo nodo, che presenta sia un client EL che un client CL.

Connettere l'ambiente di sviluppo della dapp alla testnet Ethereum locale

Configurare l'ambiente di sviluppo della dapp

Ora che hai una testnet locale in esecuzione, puoi connettere il tuo ambiente di sviluppo per dapp per utilizzare la tua testnet locale. In questa guida verrà utilizzato il framework Hardhat per distribuire una dapp di blackjack sulla tua testnet locale.

Per configurare il tuo ambiente di sviluppo per dapp, clona il repository che contiene la nostra dapp di esempio e installa le sue dipendenze, esegui:

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

La cartella smart-contract-example (opens in a new tab) utilizzata qui contiene la configurazione tipica per uno sviluppatore di dapp che utilizza il framework Hardhat (opens in a new tab):

Configurare Hardhat per utilizzare la testnet locale

Con il tuo ambiente di sviluppo per dapp configurato, ora connetterai Hardhat per utilizzare la testnet Ethereum locale generata utilizzando Kurtosis. Per farlo, sostituisci <$YOUR_PORT> nella struttura localnet nel tuo file di configurazione hardhat.config.ts con la porta dell'URI RPC in output da qualsiasi servizio el-client-<num>. In questo caso di esempio, la porta sarebbe 64248. La tua porta sarà diversa.

Esempio in hardhat.config.ts:

Una volta salvato il file, il tuo ambiente di sviluppo per dapp Hardhat è ora connesso alla tua testnet Ethereum locale! Puoi verificare che la tua testnet funzioni eseguendo:

npx hardhat balances --network localnet

L'output dovrebbe essere simile a questo:

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

Questo conferma che Hardhat sta utilizzando la tua testnet locale e rileva gli account prefinanziati creati da eth-network-package.

Distribuire e testare la tua dapp localmente

Con l'ambiente di sviluppo per dapp completamente connesso alla testnet Ethereum locale, ora puoi eseguire flussi di lavoro di sviluppo e test sulla tua dapp utilizzando la testnet locale.

Per compilare e distribuire lo smart contract ChipToken.sol per la prototipazione e lo sviluppo locale, esegui:

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

L'output dovrebbe essere simile a:

ChipToken deployed to: 0xAb2A01BC351770D09611Ac80f1DE076D56E0487d

Ora prova a eseguire il test simple.js sulla tua dapp locale per confermare che ogni giocatore nella nostra dapp di Blackjack abbia 1000 token coniati per sé:

L'output dovrebbe essere simile a questo:

npx hardhat test --network localnet

L'output dovrebbe essere simile a questo:

ChipToken
    mint
      ✔ should mint 1000 chips for PLAYER ONE

  1 passing (654ms)

Riepilogo

A questo punto, hai configurato un ambiente di sviluppo per dapp, lo hai connesso a una rete Ethereum locale creata da Kurtosis e hai compilato, distribuito ed eseguito un semplice test sulla tua dapp.

Ora esploriamo come puoi configurare la rete sottostante per testare le nostre dapp in diverse configurazioni di rete.

Configurare la testnet Ethereum locale

Modificare le configurazioni dei client e il numero di nodi

La tua testnet Ethereum locale può essere configurata per utilizzare diverse coppie di client EL e CL, oltre a un numero variabile di nodi, a seconda dello scenario e della configurazione di rete specifica che desideri sviluppare o testare. Ciò significa che, una volta configurata, puoi avviare una testnet locale personalizzata e utilizzarla per eseguire gli stessi flussi di lavoro (distribuzione, test, ecc.) in varie configurazioni di rete per assicurarti che tutto funzioni come previsto. Per saperne di più sugli altri parametri che puoi modificare, visita questo link.

Fai una prova! Puoi passare varie opzioni di configurazione a eth-network-package tramite un file JSON. Questo file JSON dei parametri di rete fornisce le configurazioni specifiche che Kurtosis utilizzerà per configurare la rete Ethereum locale.

Prendi il file di configurazione predefinito e modificalo per avviare due nodi con diverse coppie EL/CL:

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

Questa configurazione crea una rete eterogenea di implementazioni di nodi Ethereum per testare la tua dapp. Il tuo file di configurazione dovrebbe ora apparire così:

Ogni struttura participants è mappata a un nodo nella rete, quindi 3 strutture participants indicheranno a Kurtosis di avviare 3 nodi nella tua rete. Ogni struttura participants ti consentirà di specificare la coppia EL e CL utilizzata per quel nodo specifico.

La struttura network_params configura le impostazioni di rete che vengono utilizzate per creare i file di genesi per ogni nodo, oltre ad altre impostazioni come i secondi per slot della rete.

Salva il file dei parametri modificato in qualsiasi directory desideri (nell'esempio seguente, è salvato sul desktop) e quindi utilizzalo per eseguire il tuo pacchetto Kurtosis eseguendo:

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

Nota: il comando kurtosis clean -a viene utilizzato qui per indicare a Kurtosis di distruggere la vecchia testnet e i suoi contenuti prima di avviarne una nuova.

Ancora una volta, Kurtosis lavorerà per un po' e stamperà i singoli passaggi in corso. Alla fine, l'output dovrebbe essere simile a:

Congratulazioni! Hai configurato con successo la tua testnet locale per avere 3 nodi invece di 1. Per eseguire gli stessi flussi di lavoro di prima sulla tua dapp (distribuzione e test), esegui le stesse operazioni di prima sostituendo <$YOUR_PORT> nella struttura localnet nel tuo file di configurazione hardhat.config.ts con la porta dell'URI RPC in output da qualsiasi servizio el-client-<num> nella tua nuova testnet locale a 3 nodi.

Conclusione

E questo è tutto! Per riassumere questa breve guida, hai:

  • Creato una testnet Ethereum locale su Docker utilizzando Kurtosis
  • Connesso il tuo ambiente di sviluppo per dapp locale alla rete Ethereum locale
  • Distribuito una dapp ed eseguito un semplice test su di essa sulla rete Ethereum locale
  • Configurato la rete Ethereum sottostante per avere 3 nodi

Ci piacerebbe sapere da te cosa è andato bene, cosa potrebbe essere migliorato o rispondere a qualsiasi tua domanda. Non esitare a contattarci tramite GitHub (opens in a new tab) o inviaci un'e-mail (opens email client)!

Altri esempi e guide

Ti invitiamo a dare un'occhiata alla nostra guida rapida (opens in a new tab) (dove costruirai un database Postgres e un'API su di esso) e agli altri nostri esempi nel nostro repository awesome-kurtosis (opens in a new tab) dove troverai alcuni ottimi esempi, inclusi pacchetti per:

Ultimo aggiornamento della pagina: 3 marzo 2026