Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update dependency @nomicfoundation/hardhat-toolbox to v5 #114

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Mar 14, 2024

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
@nomicfoundation/hardhat-toolbox (source) ^2.0.2 -> ^5.0.0 age adoption passing confidence

Release Notes

nomicfoundation/hardhat (@​nomicfoundation/hardhat-toolbox)

v5.0.0

Compare Source

This version of Hardhat Toolbox adds Hardhat Ignition as the default deployment system. See the Hardhat Ignition docs for more information.

v4.0.0

Compare Source

This version of Hardhat Toolbox bumps the versions of hardhat-verify and typechain. This is a new major because the new versions of those peer dependencies are not compatible with the previous ones, but you can consider this a low-risk upgrade.

v3.0.0: Hardhat Toolbox v3.0.0: ethers v6, bigints and more!

Compare Source

This new major version of Hardhat Toolbox is based on ethers v6 and uses new versions of the hardhat-ethers, hardhat-chai-matchers and typechain plugins.

Using in a new project

Nothing has changed in how you use the Toolbox for a new project: if you initialize one with the latest version of Hardhat, then this version of the Toolbox will be used. Check our Setting up a project guide for the complete instructions.

Upgrading an existing project

To use this new version of the Toolbox in an existing project, you need to upgrade the Toolbox and its relevant peer dependencies.

If you are using npm 7 or later, you just need to upgrade the Toolbox and npm will handle the rest:

npm install @​nomicfoundation/hardhat-toolbox@3

If you are using yarn or an older version of npm, you’ll need to manually upgrade all the relevant packages and remove the ones that are no longer needed:

### upgrade relevant packages
yarn add @​nomicfoundation/hardhat-toolbox@3 @​nomicfoundation/hardhat-chai-matchers@2 @​nomicfoundation/hardhat-ethers@3 @​nomicfoundation/hardhat-verify @​typechain/ethers-v6 @​typechain/hardhat@8 ethers@6

### remove packages that are no longer needed
yarn remove @​ethersproject/abi @​ethersproject/providers @​nomiclabs/hardhat-ethers @​nomiclabs/hardhat-etherscan @​typechain/ethers-v5

What’s new?

Ethers v6 has several changes with respect to v5. These are some of them, but check their migration guide for the full details.

Native bigints

One of the most important changes in v6 is that now native bigints are used instead of BigNumber objects. For example, checking if an address has a positive amount of tokens is done like this in v5:

const balance = await token.balanceOf(someAddress)

if (balance.gt(0)) {
  // ...
}

While in v6 you would do it this way:

const balance = await token.balanceOf(someAddress)

if (balance > 0n) {
  // ...
}

For more info on native bigints, check the MDN page.

ethers.utils

In ethers v6, ethers.utils doesn’t exist anymore. In many cases, just removing .utils is enough to adapt your code, but other functions were renamed. Again, check ethers’s migration guide to learn more.

Signers and contracts can be used as addresses

Sending ether to a contract was done like this in ethers v5:

await signer.sendTransaction({
  to: contract.address,
  value: ethers.utils.parseEther("0.1")
})

In ethers v6, you can just use the contract instance:

await signer.sendTransaction({
  to: contract,
  value: ethers.parseEther("0.1")
})
Address property of contracts

Contract instances in ethers v5 had a .address property with the address of the contract. In ethers v6 this was replaced by an async .getAddress() function. That is, before you would do this:

console.log("Contract deployed at", contract.address)

Now you have to do this:

console.log("Contract deployed at", await contract.getAddress())

Alternatively, you can use the .target property, but keep in mind that this might not work in some scenarios (for example, if you create a contract instance with an ENS address).

.deployed method

The .deployed() method of contracts is now called .waitForDeployment()

Network helpers re-export

When the Toolbox is installed using npm 7 or later, its peer dependencies are automatically installed. However, these dependencies won't be listed in the package.json. As a result, directly importing the Network Helpers can be problematic for certain tools or IDEs. To address this issue, this new version of the Toolbox re-exports the Hardhat Network Helpers. You can use them like this now:

import helpers from "@​nomicfoundation/hardhat-toolbox/network-helpers";

Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR was generated by Mend Renovate. View the repository job log.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

0 participants