Capitalisation boursière: $2.7991T -6.33%
Volume(24h): $182.2077B 63.84%
Indice de peur et de cupidité:

38 - Peur

  • Capitalisation boursière: $2.7991T -6.33%
  • Volume(24h): $182.2077B 63.84%
  • Indice de peur et de cupidité:
  • Capitalisation boursière: $2.7991T -6.33%
Cryptos
Les sujets
Cryptospedia
Nouvelles
Cryptosopique
Vidéos
Top Cryptospedia

Choisir la langue

Choisir la langue

Sélectionnez la devise

Cryptos
Les sujets
Cryptospedia
Nouvelles
Cryptosopique
Vidéos

Comment tester votre contrat de solidité avec Hardhat ?

Hardhat enables robust smart contract development with local testing, forking, debugging tools like console.log in Solidity, gas reporting, and precise event/time manipulation.

Jan 20, 2026 at 12:20 pm

Configuration de l'environnement du casque de sécurité

1. Installez Node.js et npm pour garantir la compatibilité avec la chaîne d'outils de Hardhat.

2. Exécutez npm init -y pour initialiser un nouveau projet Node.js.

3. Exécutez npm install --save-dev hardhat pour ajouter Hardhat comme dépendance de développement.

4. Lancez l'assistant de configuration Hardhat à l'aide de npx hardhat et sélectionnez « Créer un hardhat.config.js vide ».

5. Créez un répertoire contracts/ et placez votre fichier source Solidity (par exemple, Token.sol ) à l'intérieur.

Rédaction de scripts de test en JavaScript ou TypeScript

1. Générez un dossier test/ et ajoutez un fichier de test tel que Token.test.js .

2. Importez les utilitaires de test de Hardhat : const {expect } = require('@nomicfoundation/hardhat-chai-matchers');

3. Utilisez les blocs décrire() et it() pour structurer logiquement les cas de test.

4. Déployez les contrats dans les tests via wait ethers.deployContract('Token') au lieu de la gestion manuelle du bytecode.

5. Interagissez avec les méthodes contractuelles en utilisant wait token.transfer (adresse, montant) et affirmez les résultats avec les correspondants Chai.

Exécution de tests sur un réseau local

1. Configurez un fork dans hardhat.config.js en spécifiant un réseau comme le réseau principal Ethereum ou Sepolia à l'aide de son URL RPC.

2. Lancez Hardhat Network avec le forking activé : npx hardhat node --fork https://eth-mainnet.g.alchemy.com/v2/YOUR_API_KEY .

3. Écrivez des tests qui interagissent avec les contrats du réseau principal déployés, tels que les pools Uniswap V3, en récupérant leur ABI et en les attachant via ethers.getContractAt() .

4. Simulez des conditions réelles, notamment les fluctuations du prix du gaz et la manipulation de l'horodatage des blocs, à l'aide des assistants intégrés de Hardhat Network.

5. Validez les modèles d'accès autorisés en empruntant l'identité des adresses EOA récupérées à partir d'explorateurs comme Etherscan à l'aide de wait network.provider.request({ method: 'hardhat_impersonateAccount', params: [address] }) .

Utilisation des outils intégrés de Hardhat pour le débogage

1. Insérez les instructions console.log() directement dans le code Solidity et compilez avec le plugin de journal de console activé.

2. Exécutez npx hardhat test --no-compile pour ignorer la recompilation lorsque seule la logique du test change.

3. Utilisez hardhat-tracer pour inspecter les opcodes EVM de bas niveau exécutés lors de chaque transaction.

4. Tirez parti de hardhat-gas-reporter pour mesurer la consommation de gaz lors des appels de fonction et détecter les inefficacités.

5. Activez les traces de pile pour les transactions annulées en définissant throwOnTransactionFailures: true dans la section moka de la configuration Hardhat.

Foire aux questions

Q : Puis-je tester les événements émis par mon contrat en utilisant Hardhat ? R : Oui. Utilisez wait expect(tx).to.emit(contract, 'Transfer').withArgs(owner, destinataire, montant) pour vérifier les paramètres de l'événement.

Q : Comment tester les vulnérabilités de réentrance ? R : Déployez un contrat d'attaquant malveillant dans le cadre du test, déclenchez des fonctions vulnérables et affirmez des incohérences d'équilibre ou une corruption d'état.

Q : Est-il possible de tester une logique dépendant du temps, comme les calendriers d’acquisition ? R : Oui. Utilisez wait network.provider.send('evm_increaseTime', [seconds]) suivi de wait network.provider.send('evm_mine') pour avancer les blocs.

Q : Que se passe-t-il si mon contrat utilise AccessControl d'OpenZeppelin ? R : Attribuez des rôles dans les tests à l'aide de wait accessControl.grantRole(ROLE_HASH, adresse) avant d'appeler des fonctions restreintes.

Clause de non-responsabilité:info@kdj.com

Les informations fournies ne constituent pas des conseils commerciaux. kdj.com n’assume aucune responsabilité pour les investissements effectués sur la base des informations fournies dans cet article. Les crypto-monnaies sont très volatiles et il est fortement recommandé d’investir avec prudence après une recherche approfondie!

Si vous pensez que le contenu utilisé sur ce site Web porte atteinte à vos droits d’auteur, veuillez nous contacter immédiatement (info@kdj.com) et nous le supprimerons dans les plus brefs délais.

Connaissances connexes

Comment exécuter un message inter-chaînes avec un contrat LayerZero ?

Comment exécuter un message inter-chaînes avec un contrat LayerZero ?

Jan 18,2026 at 01:19pm

Comprendre l'architecture LayerZero 1. LayerZero fonctionne comme un protocole d'interopérabilité léger et sans autorisation qui permet la com...

Comment mettre en œuvre EIP-712 pour la vérification sécurisée des signatures ?

Comment mettre en œuvre EIP-712 pour la vérification sécurisée des signatures ?

Jan 20,2026 at 10:20pm

Présentation de l'EIP-712 et objectif principal 1. EIP-712 définit une norme pour le hachage et la signature de données structurées typées dans le...

Comment se qualifier pour les parachutages en interagissant avec de nouveaux contrats ?

Comment se qualifier pour les parachutages en interagissant avec de nouveaux contrats ?

Jan 24,2026 at 09:00pm

Comprendre les exigences d'interaction contractuelle 1. La plupart des campagnes de largage nécessitent une interaction directe avec des contrats ...

Comment surveiller un contrat intelligent pour les alertes de sécurité ?

Comment surveiller un contrat intelligent pour les alertes de sécurité ?

Jan 21,2026 at 07:59am

Outils de surveillance en chaîne 1. Les explorateurs de blockchain comme Etherscan et Blockscout permettent une inspection en temps réel du bytecode d...

Comment mettre en place et financer un contrat de paiements automatisés ?

Comment mettre en place et financer un contrat de paiements automatisés ?

Jan 26,2026 at 08:59am

Comprendre le déploiement de contrats intelligents 1. Les développeurs doivent sélectionner une plate-forme blockchain compatible telle que Ethereum, ...

Comment utiliser les contrats OpenZeppelin pour créer des dApps sécurisées ?

Comment utiliser les contrats OpenZeppelin pour créer des dApps sécurisées ?

Jan 18,2026 at 11:19am

Comprendre les principes fondamentaux des contrats OpenZeppelin 1. OpenZeppelin Contracts est une bibliothèque de composants de contrats intelligents ...

Comment exécuter un message inter-chaînes avec un contrat LayerZero ?

Comment exécuter un message inter-chaînes avec un contrat LayerZero ?

Jan 18,2026 at 01:19pm

Comprendre l'architecture LayerZero 1. LayerZero fonctionne comme un protocole d'interopérabilité léger et sans autorisation qui permet la com...

Comment mettre en œuvre EIP-712 pour la vérification sécurisée des signatures ?

Comment mettre en œuvre EIP-712 pour la vérification sécurisée des signatures ?

Jan 20,2026 at 10:20pm

Présentation de l'EIP-712 et objectif principal 1. EIP-712 définit une norme pour le hachage et la signature de données structurées typées dans le...

Comment se qualifier pour les parachutages en interagissant avec de nouveaux contrats ?

Comment se qualifier pour les parachutages en interagissant avec de nouveaux contrats ?

Jan 24,2026 at 09:00pm

Comprendre les exigences d'interaction contractuelle 1. La plupart des campagnes de largage nécessitent une interaction directe avec des contrats ...

Comment surveiller un contrat intelligent pour les alertes de sécurité ?

Comment surveiller un contrat intelligent pour les alertes de sécurité ?

Jan 21,2026 at 07:59am

Outils de surveillance en chaîne 1. Les explorateurs de blockchain comme Etherscan et Blockscout permettent une inspection en temps réel du bytecode d...

Comment mettre en place et financer un contrat de paiements automatisés ?

Comment mettre en place et financer un contrat de paiements automatisés ?

Jan 26,2026 at 08:59am

Comprendre le déploiement de contrats intelligents 1. Les développeurs doivent sélectionner une plate-forme blockchain compatible telle que Ethereum, ...

Comment utiliser les contrats OpenZeppelin pour créer des dApps sécurisées ?

Comment utiliser les contrats OpenZeppelin pour créer des dApps sécurisées ?

Jan 18,2026 at 11:19am

Comprendre les principes fondamentaux des contrats OpenZeppelin 1. OpenZeppelin Contracts est une bibliothèque de composants de contrats intelligents ...

Voir tous les articles

User not found or password invalid

Your input is correct