Hardhat学习笔记-单元/集成测试

使用Mocha与chai进行测试

存在于hardhat-toolbox中

1. 环境配置

安装 Hardhat-Deploy 插件

用于简化部署脚本管理和多网络部署:

bash 复制代码
npm i -D hardhat-deploy

hardhat.config.js 中引入插件:

javascript 复制代码
require('hardhat-deploy');

测试框架集成
hardhat-toolbox 已内置 Mocha(测试运行器)Chai(断言库) ,无需额外安装。测试文件需放在 test/ 目录下,文件名以 .test.js 结尾。


2. 单元测试(本地环境)

基本原则

• 覆盖所有可能的分支(如 fundwithdrawrefund 等涉及资产转移的关键函数)。 • 使用 describe 分组测试用例,it 定义具体测试逻辑。 • 示例结构:

js 复制代码
  const { expect } = require("chai");
    describe("FundMe", function() {
      beforeEach(async () => {
        // 部署合约并初始化
        const FundMeFactory = await ethers.getContractFactory("FundMe");
        fundMe = await FundMeFactory.deploy();
      });
      it("Reverts if ETH amount is 0", async () => {
        await expect(fundMe.fund()).to.be.revertedWith("Amount must be > 0");
      });
    });

Mock 合约的使用

目的 :模拟外部依赖(如 Chainlink 喂价合约),避免测试依赖真实网络。

方法

  1. 创建 Mock 合约(参考 Chainlink MockV3Aggregator)。

  2. 在测试中部署 Mock 合约并注入到主合约中:

js 复制代码
       const MockAggregator = await ethers.getContractFactory("MockV3Aggregator");
       mockAggregator = await MockAggregator.deploy(8, 2000e8); // 初始价格 2000
       const FundMe = await ethers.getContractFactory("FundMe");
       fundMe = await FundMe.deploy(mockAggregator.address);

3. 集成测试(真实网络)

配置测试网络

.env 中添加网络参数(如 Sepolia 的 RPC URL 和私钥):

ini 复制代码
SEPOLIA_RPC_URL=https://eth-sepolia.g.alchemy.com/v2/YOUR_KEY
PRIVATE_KEY=0x...

hardhat.config.js 中配置网络:

javascript 复制代码
networks: {
  sepolia: {
    url: process.env.SEPOLIA_RPC_URL,
    accounts: [process.env.PRIVATE_KEY],
  },
}

运行测试

使用 --network 指定网络:

bash 复制代码
npx hardhat test --network sepolia

重点验证合约在真实环境下的交互(如 API 调用、Gas 消耗)。


4. 辅助工具

Gas 消耗分析(hardhat-gas-reporter)

• 安装:

js 复制代码
    npm i -D hardhat-gas-reporter
    ```
  • 配置 `hardhat.config.js`:  
    ```javascript
    require("hardhat-gas-reporter");
    module.exports = {
      gasReporter: {
        enabled: true,
        currency: "USD",
        coinmarketcap: "YOUR_API_KEY" // 可选,换算为美元成本
      }
    };

• 运行测试时自动生成 Gas 报告。

测试覆盖率检查(solidity-coverage)

• 运行:
bash npx hardhat coverage • 输出覆盖率报告,显示哪些代码未被测试覆盖。


5. 最佳实践

测试分类

单元测试 :聚焦单个函数逻辑,使用 Mock 隔离依赖。

集成测试 :验证多合约协作或真实网络行为。 • 断言优化

使用 Chai 的 .to.emit() 检查事件触发,或 .to.changeEtherBalance() 验证资产变化。


相关推荐
琹箐2 分钟前
ant-design4.xx实现数字输入框; 某些输入法数字需要连续输入两次才显示
前端·javascript·anti-design-vue
程序员-小李3 分钟前
VuePress完美整合Toast消息提示
前端·javascript·vue.js
Dontla4 小时前
为什么React列表项需要key?(React key)(稳定的唯一标识key有助于React虚拟DOM优化重绘大型列表)
javascript·react.js·ecmascript
德育处主任Pro7 小时前
『React』Fragment的用法及简写形式
前端·javascript·react.js
CodeBlossom7 小时前
javaweb -html -CSS
前端·javascript·html
CodeCraft Studio7 小时前
【案例分享】如何借助JS UI组件库DHTMLX Suite构建高效物联网IIoT平台
javascript·物联网·ui
打小就很皮...8 小时前
HBuilder 发行Android(apk包)全流程指南
前端·javascript·微信小程序
dancing99910 小时前
cocos3.X的oops框架oops-plugin-excel-to-json改进兼容多表单导出功能
前端·javascript·typescript·游戏程序
萌萌哒草头将军11 小时前
🚀🚀🚀Prisma 发布无 Rust 引擎预览版,安装和使用更轻量;支持任何 ORM 连接引擎;支持自动备份...
前端·javascript·vue.js
书语时11 小时前
ES6 Promise 状态机
前端·javascript·es6