2.0.8 • Published 10 months ago

@nomicfoundation/hardhat-chai-matchers v2.0.8

Weekly downloads
-
License
MIT
Repository
github
Last release
10 months ago

npm

Hardhat Chai Matchers

This plugin adds Ethereum-specific capabilities to the Chai assertion library, making your smart contract tests easy to write and read.

Check its documentation to learn more.

Installation

We recommend using npm 7 or later. If you do that, then you just need to install the plugin itself:

npm install --save-dev @nomicfoundation/hardhat-chai-matchers

If you are using an older version of npm, you'll also need to install all the packages used by the plugin.

npm install --save-dev @nomicfoundation/hardhat-chai-matchers chai@4 @nomicfoundation/hardhat-ethers ethers

That's also the case if you are using yarn:

yarn add --dev @nomicfoundation/hardhat-chai-matchers chai@4 @nomicfoundation/hardhat-ethers ethers

Usage

After installing it, add the plugin to your Hardhat config:

require("@nomicfoundation/hardhat-chai-matchers");

Then you'll be able to use the matchers in your tests:

expect(await token.totalSupply()).to.equal(1_000_000);

await expect(token.transfer(token, 1000)).to.be.revertedWith(
  "Cannot transfer to the contract itself"
);

await expect(token.transfer(recipient, 1000))
  .to.emit(token, "Transfer")
  .withArgs(owner, recipient, 1000);

Known issues

Chaining Async Matchers

Currently, the following matchers do not support chaining:

  • reverted
  • revertedWith
  • revertedWithCustomError
  • revertedWithoutReason
  • revertedWithPanic
  • changeEtherBalance
  • changeEtherBalances
  • changeTokenBalance
  • changeTokenBalances
  • emit (with the only exception of chaining multiple emit matchers)

Which means you can't do:

await expect(contract.f(...))
  .to.changeEtherBalance(...)
  .and.to.changeTokenBalance(...)

To work around this limitation, write separate assertions for each matcher:

const tx = contract.f(...);
await expect(tx).to.changeEtherBalance(...)
await expect(tx).to.changeTokenBalance(...)

If you are interested in seeing an implementation of chaining for async matchers, please visit the GitHub issue #4235 and leave an upvote or comment.

vitacontracts@furucombo/composable-router-test-helperslot-ref@meetusvr/smart-contracts@infinitebrahmanuniverse/nolb-_nom@everything-registry/sub-chunk-663@yuetloo/maci-contractstenderly-wizardwesigvault-mantle-contractstemp-emojitemp-poolz-helper-v2temp-project-avault-contract-sdk@clrfund/maci-contracts@bluedex/governance@bluedex/v2-protocol@routerprotocol/router-crosstalk-utils@poseidon-zkp/poseidon-zk-contractsbaluni-core@yield-sync/v1-sdk@amxx/hre@aiw3/stack-bridge@bees-group/bees-ventures-contract@0xzebra/core@0xpropel/core@consensys/linea-ccip-gateway@congson1907/sunswap-corevaulth-contracts@ferum/aave-deploy-v3@hyconus/smart-contracts@fluidtrends/fitroot@gemunion/contracts-erc721-enumerable@gemunion/contracts-erc721ec@gemunion/contracts-misc@gemunion/contracts-mocha@gemunion/contracts-access-list@nhimcoii/procurement-platform@node-guardians/ng-quests-helpers@entangle_protocol/oracle-sdk@ensdomains/evm-verifier@eniblock/contracts@falconsdk/test-helpers@matterlabs/hardhat-zksync-toolbox@jpmorganchase/onyx-ssi-sdk@protocolink/test-helpers@openoscom/contracts@poolzfinance/poolz-helper-v2@optopia/stakemymultisig-contractmeti-asset-contractoz-customprophet-batching-randomness-soliditysmart-contract-jojosmart-contracts-addresseshardhat-celoinfinitymint@weav3npm/periphery@wen-protocol/propel@theros/core-v4-sdk@yield-sync/erc20-eth-value-provider@yield-sync/erc20-handler@yield-sync/governance@yield-sync/sdk@yield-sync/utilities@yield-sync/utility@yield-sync/v1-emp@zerolendxyz/governance@zk-shuffle/contracts@zkshuffle/contractsaa-schnorr-multisigauditoauditifycdkbridgeclick-zk-contractscustom-solblocklock-solidityberuwala-smart-contractsdumb-contractsgaia-tools@streamr/hub-contracts
2.0.8

10 months ago

2.0.7

1 year ago

2.0.6

1 year ago

2.0.5

1 year ago

2.0.4

1 year ago

2.0.3

2 years ago

2.0.2

2 years ago

2.0.1

2 years ago

2.0.0

2 years ago

1.0.7-dev.0

2 years ago

2.0.0-beta.0

2 years ago

1.0.6

2 years ago

1.0.5

3 years ago

1.0.4

3 years ago

1.0.2

3 years ago

1.0.1

3 years ago

1.0.0

3 years ago

1.0.0-beta.3

3 years ago

1.0.3

3 years ago

1.0.0-beta.2

3 years ago

1.0.0-beta.1

3 years ago

0.0.1

3 years ago

1.0.0-beta.0

3 years ago