市值: $2.812T -5.85%
成交额(24h): $186.0816B 66.46%
恐惧与贪婪指数:

38 - 恐惧

  • 市值: $2.812T -5.85%
  • 成交额(24h): $186.0816B 66.46%
  • 恐惧与贪婪指数:
  • 市值: $2.812T -5.85%
加密货币
话题
百科
资讯
加密话题
视频
热门加密百科

选择语种

选择语种

选择货币

加密货币
话题
百科
资讯
加密话题
视频

如何使用 Hardhat 测试您的 Solidity 合约?

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

2026/01/20 12:20

设置安全帽环境

1. 安装 Node.js 和 npm 以确保与 Hardhat 工具链的兼容性。

2. 运行npm init -y初始化新的 Node.js 项目。

3. 执行npm install --save-dev Hardhat将 Hardhat 添加为开发依赖项。

4. 使用npx Hardhat启动 Hardhat 设置向导,然后选择“创建空的 Hardhat.config.js”。

5. 创建一个contracts/目录并将您的Solidity源文件(例如Token.sol )放入其中。

使用 JavaScript 或 TypeScript 编写测试脚本

1. 生成test/文件夹并添加测试文件,例如Token.test.js

2. 导入 Hardhat 的测试实用程序: const { Expect } = require('@nomicfoundation/hardhat-c​​hai-matchers');

3. 使用describe()it()块逻辑地构建测试用例。

4. 通过await ethers.deployContract('Token')在测试中部署合约,而不是手动字节码处理。

5. 使用await token.transfer(address, amount)与合约方法交互,并使用Chai 匹配器断言结果。

在本地分叉网络上运行测试

1. 通过使用 RPC URL 指定以太坊主网或 Sepolia 等网络,在Hardhat.config.js中配置分叉。

2. 启动 Hardhat 网络并启用分叉: npx hardhat node --fork https://eth-mainnet.g.alchemy.com/v2/YOUR_API_KEY

3. 编写与已部署的主网合约(例如 Uniswap V3 池)交互的测试,方法是获取其 ABI 并通过ethers.getContractAt()附加到它们。

4. 使用 Hardhat Network 的内置助手模拟现实世界的条件,包括 Gas 价格波动和区块时间戳操作。

5. 通过使用wait network.provider.request({ method: 'hardhat_impersonateAccount', params: [address] })模拟从 Etherscan 等浏览器检索到的 EOA 地址来验证许可访问模式。

使用 Hardhat 的内置工具进行调试

1. 直接在 Solidity 代码中插入console.log()语句,并在启用控制台日志插件的情况下进行编译。

2. 运行npx hardhat test --no-compile以在仅测试逻辑更改时跳过重新编译。

3. 使用hardhat-tracer检查每个事务期间执行的低级EVM 操作码。

4. 利用hardhat-gas-reporter测量函数调用之间的gas 消耗并检测效率低下的情况。

5. 通过在 Hardhat 配置的 mocha 部分中设置throwOnTransactionFailures: true来启用还原事务的堆栈跟踪。

常见问题解答

问:我可以使用 Hardhat 测试合约发出的事件吗?答:是的。使用await Expect(tx).to.emit(contract, 'Transfer').withArgs(owner,recipient,amount)来验证事件参数。

问:如何测试重入漏洞?答:在测试中部署恶意攻击者合约,触发易受攻击的功能,并断言余额不一致或状态损坏。

问:是否可以测试与时间相关的逻辑,例如归属计划?答:是的。使用await network.provider.send('evm_increaseTime', [seconds]) ,然后使用await network.provider.send('evm_mine')来推进块。

问:如果我的合约使用 OpenZeppelin 的 AccessControl 怎么办?答:在调用受限函数之前,使用await accessControl.grantRole(ROLE_HASH, address)在测试中分配角色。

免责声明:info@kdj.com

所提供的信息并非交易建议。根据本文提供的信息进行的任何投资,kdj.com不承担任何责任。加密货币具有高波动性,强烈建议您深入研究后,谨慎投资!

如您认为本网站上使用的内容侵犯了您的版权,请立即联系我们(info@kdj.com),我们将及时删除。

相关百科

如何使用LayerZero合约执行跨链消息?

如何使用LayerZero合约执行跨链消息?

2026-01-18 13:19:39

了解 LayerZero 架构1. LayerZero 作为一种轻量级、无需许可的互操作性协议运行,无需依赖可信中介或包装资产即可实现区块链之间的通信。 2. 它利用部署在每条链上的超轻节点(ULN)来验证消息的完整性和一致性,而无需存储完整的区块链状态。 3. 核心组件包括处理消息路由的 Endp...

如何实施EIP-712进行安全签名验证?

如何实施EIP-712进行安全签名验证?

2026-01-20 22:20:26

EIP-712 概述和核心目的1. EIP-712 定义了以太坊应用程序中类型化结构化数据哈希和签名的标准。 2. 它使钱包能够在签名请求期间显示人类可读的域和消息字段,而不是原始的十六进制字符串。 3. 该规范通过域分隔符哈希引入域分离,防止跨不同 dApp 或链的签名重放。 4. 每个签名的有效...

如何通过新合约交互获得空投资格?

如何通过新合约交互获得空投资格?

2026-01-24 21:00:23

了解合约交互要求1. 大多数空投活动都要求与部署在受支持的区块链(例如以太坊、Arbitrum 或 Base)上的智能合约进行直接交互。 2. 交互通常涉及使用连接到 dApp 接口的钱包执行诸如approve() 、 stake()或mint()之类的函数。 3. 某些协议需要多种交易类型,例如将...

如何监控智能合约的安全警报?

如何监控智能合约的安全警报?

2026-01-21 07:59:57

链上监控工具1. Etherscan和Blockscout等区块链浏览器允许实时检查合约字节码、交易日志和内部调用。 2. 在信任任何链上数据之前必须确认合约验证状态——未经验证的合约存在高风险。 3. 事件日志解析可以检测异常状态变化,例如意外的代币转移或所有权修改。 4. 可以针对特定事件签名设...

如何建立自动支付合同并为其提供资金?

如何建立自动支付合同并为其提供资金?

2026-01-26 08:59:35

了解智能合约部署1. 开发者必须根据gas效率和安全性要求选择兼容的区块链平台,例如以太坊、Polygon或Arbitrum。 2. Solidity 仍然是编写支付自动化逻辑的主要语言,特别是对于定期或有条件的转账。 3. 在主网部署之前,使用 Hardhat 或 Foundry 等本地开发环境来...

如何使用 OpenZeppelin 合约构建安全的 dApp?

如何使用 OpenZeppelin 合约构建安全的 dApp?

2026-01-18 11:19:49

了解 OpenZeppelin 合约基础知识1. OpenZeppelin Contracts 是一个可重用、经过社区审核的智能合约组件库,专为以太坊和 EVM 兼容的区块链而构建。 2. 库中的每个合约都遵循严格的安全实践,包括遵守“检查-效果-交互”模式以及广泛使用访问控制修饰符。 3. 该库提...

如何使用LayerZero合约执行跨链消息?

如何使用LayerZero合约执行跨链消息?

2026-01-18 13:19:39

了解 LayerZero 架构1. LayerZero 作为一种轻量级、无需许可的互操作性协议运行,无需依赖可信中介或包装资产即可实现区块链之间的通信。 2. 它利用部署在每条链上的超轻节点(ULN)来验证消息的完整性和一致性,而无需存储完整的区块链状态。 3. 核心组件包括处理消息路由的 Endp...

如何实施EIP-712进行安全签名验证?

如何实施EIP-712进行安全签名验证?

2026-01-20 22:20:26

EIP-712 概述和核心目的1. EIP-712 定义了以太坊应用程序中类型化结构化数据哈希和签名的标准。 2. 它使钱包能够在签名请求期间显示人类可读的域和消息字段,而不是原始的十六进制字符串。 3. 该规范通过域分隔符哈希引入域分离,防止跨不同 dApp 或链的签名重放。 4. 每个签名的有效...

如何通过新合约交互获得空投资格?

如何通过新合约交互获得空投资格?

2026-01-24 21:00:23

了解合约交互要求1. 大多数空投活动都要求与部署在受支持的区块链(例如以太坊、Arbitrum 或 Base)上的智能合约进行直接交互。 2. 交互通常涉及使用连接到 dApp 接口的钱包执行诸如approve() 、 stake()或mint()之类的函数。 3. 某些协议需要多种交易类型,例如将...

如何监控智能合约的安全警报?

如何监控智能合约的安全警报?

2026-01-21 07:59:57

链上监控工具1. Etherscan和Blockscout等区块链浏览器允许实时检查合约字节码、交易日志和内部调用。 2. 在信任任何链上数据之前必须确认合约验证状态——未经验证的合约存在高风险。 3. 事件日志解析可以检测异常状态变化,例如意外的代币转移或所有权修改。 4. 可以针对特定事件签名设...

如何建立自动支付合同并为其提供资金?

如何建立自动支付合同并为其提供资金?

2026-01-26 08:59:35

了解智能合约部署1. 开发者必须根据gas效率和安全性要求选择兼容的区块链平台,例如以太坊、Polygon或Arbitrum。 2. Solidity 仍然是编写支付自动化逻辑的主要语言,特别是对于定期或有条件的转账。 3. 在主网部署之前,使用 Hardhat 或 Foundry 等本地开发环境来...

如何使用 OpenZeppelin 合约构建安全的 dApp?

如何使用 OpenZeppelin 合约构建安全的 dApp?

2026-01-18 11:19:49

了解 OpenZeppelin 合约基础知识1. OpenZeppelin Contracts 是一个可重用、经过社区审核的智能合约组件库,专为以太坊和 EVM 兼容的区块链而构建。 2. 库中的每个合约都遵循严格的安全实践,包括遵守“检查-效果-交互”模式以及广泛使用访问控制修饰符。 3. 该库提...

查看所有文章

User not found or password invalid

Your input is correct