Hardhat is a flexible Ethereum development environment that allows developers to automate their workflows through custom tasks. Custom tasks are reusable scripts that you can execute from the command line, making it easier to perform repetitive actions like deploying contracts, checking balances, or running tests.

Step-by-Step Guide to Creating a Custom Task

Follow these steps to create a custom task in Hardhat:

  1. Set Up Your Hardhat Project: If you haven't already created a Hardhat project, you can do so by running the following commands:
mkdir my-hardhat-project
cd my-hardhat-project
npx hardhat

Follow the prompts to create a sample project.

1. Create the Tasks Directory

Inside your Hardhat project, create a new directory called tasks if it doesn't already exist:

mkdir tasks

2. Define Your Custom Task

Next, create a new JavaScript file in the tasks directory. For this example, we will create a task that retrieves and prints the balance of a specified Ethereum address. Create a file named getBalance.js in the tasks directory:

// tasks/getBalance.js
const { task } = require("hardhat/config");

task("getBalance", "Prints an account's balance")
.addParam("account", "The account's address")
.setAction(async (taskArgs, hre) => {
const balance = await hre.ethers.provider.getBalance(taskArgs.account);
console.log(`Balance of ${taskArgs.account}: ${hre.ethers.utils.formatEther(balance)} ETH`);
});

module.exports = {};

In this code:

  • We import the task function from hardhat/config.
  • We define a new task named getBalance with a description.
  • We add a parameter called account to the task to specify the Ethereum address whose balance we want to check.
  • We use the setAction method to define the action that will be performed when the task is executed. Here, we retrieve the balance of the specified account and print it in Ether (ETH).

3. Running the Task

To run the custom task, you first need to ensure that you have a local Hardhat network running. In one terminal window, start the Hardhat node:

npx hardhat node

In another terminal window, you can execute your custom task using the following command:

npx hardhat getBalance --account <YOUR_ACCOUNT_ADDRESS> --network localhost

Replace <YOUR_ACCOUNT_ADDRESS> with the Ethereum address you want to check. This command will output the balance of the specified account.

4. Viewing All Available Tasks

To see all available tasks, including your custom tasks and built-in tasks, you can run:

npx hardhat help

This command will display a list of all tasks you can execute in your Hardhat project.

Conclusion

Creating custom tasks in Hardhat is a powerful way to automate your development workflow. By defining reusable scripts, you can simplify repetitive actions and enhance your productivity. Whether you are retrieving balances, deploying contracts, or performing other tasks, custom tasks provide a flexible solution tailored to your needs.