How to develop and deploy smart contracts with Foundry & Openzeppelin

Deep Patel
Coinmonks
4 min readNov 25, 2022

--

Foundry is a blazing fast, portable and modular toolkit for Ethereum application development written in Rust.

Foundry is made up of three components:

Forge: Ethereum testing framework (like Truffle, Hardhat, and DappTools).

Cast: CLI for interacting with EVM smart contracts, sending transactions, and getting chain data.

Anvil: local Ethereum node, similar to Ganache or Hardhat Network.

Why should we use it?

  • It’s speedy, no more wasted time while running tests.
  • It allows you to write tests in solidity which minimizes context switching.
  • Many testing features like fuzzing, console.log, and cheat codes give you more power and flexibility.

Topics we are going to cover in this Article

  1. Project setup
  2. How to install dependencies in Foundry (EX. OpenZeppelin)
  3. Integrating Foundry with VSCode
  4. Writing the contract and test cases using Foundry
  5. Understanding Traces in Foundry
  6. Generating Gas report using Foundry
  7. Deploying the contract using Foundry

Installation

Installation of Foundry is well explained in the foundry book, check out the instructions here

https://book.getfoundry.sh/getting-started/installation

Setting up the project

once, the foundry is installed we can create a new project using

forge init foundry-demo // forge-demo is name of the project

once the project is created, use commands to check if everything is working correctly

cd foundry-demo && forge build

Installing dependencies

Forge manages dependencies using git submodules by default, which means that it works with any GitHub repository that contains smart contracts.

To use OpenZeppelin we need to install it as a dependency in our project, to-do so use the command

forge install OpenZeppelin/openzeppelin-contracts
// forge install is command which is used for installing dependencies
// <https://github.com/OpenZeppelin/openzeppelin-contracts>
// use {{username}}/{{repo_name}} from the github url

Integrate Foundry with VSCode

After installing OpenZeppelin as a dependency try importing something from it in the contract (your contract is there under the /src directory), If you are using VSCode an error will popup

Foundry import error

To fix this error, Run this command

forge remappings > remappings.txt

What this command does is it creates a remappings.txt file inside the root directory of the project

At this moment the content in the file might look like this,

ds-test/=lib/forge-std/lib/ds-test/src/
forge-std/=lib/forge-std/src/
openzeppelin-contracts/=lib/openzeppelin-contracts/contracts/

For more details visit here https://book.getfoundry.sh/config/vscode

Writing the contract

Rename the file src/Counter.solsrc/FDemo.sol, the code for our ERC721 smart contract is as below

Testing the contract using Foundry

Let's start by renaming the test file to match the name of our contract Counter.t.solFDemo.t.sol

Forge uses the following keywords in tests:

  • setUp: An optional function invoked before each test case is run
function setUp() public {
testNumber = 42;
}
  • test: Functions prefixed with test are run as a test case
function testNumberIs42() public {     
assertEq(testNumber, 42);
}
  • testFail: The inverse of the test prefix — if the function does not revert, the test fails
function testNumberIs42() public {     
assertEq(testNumber, 42);
}

So, Right now we only have one method mint, so we will be writing a test case for this method

and this is going to be a pretty simple one

Now, to run this test we can use the command forge test

If we want to explore more details/ events/ flow about the test cases, we can use Traces To enable Traces while running test cases use -vvv or -vvvv

The attached screenshot shows the result of test cases with and without traces

Foundry logs

More details on the Traces: https://book.getfoundry.sh/forge/traces

Generating Gas report using Foundry

to generate gas report use — gas-report with the test command

forge test --gas-report
Foundry gas report

More details on the Gas Report here: https://book.getfoundry.sh/forge/gas-reports

Deploying and verifying contracts with Foundry

Forge can deploy smart contracts to a given network with the [forge create](<https://book.getfoundry.sh/reference/forge/forge-create.html>) command.

Forge can deploy smart contracts to a given network with the [forge create](<https://book.getfoundry.sh/reference/forge/forge-create.html>) command.

Some options we can use with forge create while deploying the contract

  • —rpc-url : Rpc URL of the network on which we want to deploy our contract (in our case we will be using the RPC URL of polygon mumbai testnet)
  • -constructor-args : Pass arguments to the constructor
  • -private-key : Private key of deployers wallet

We can optionally pass --verify && --etherscan-api-key if we want to verify our contract

$ forge create --rpc-url <your_rpc_url> \\
--constructor-args "ForgeUSD" "FUSD" 18 1000000000000000000000 \\
--private-key <your_private_key> src/MyToken.sol:MyToken \\
--etherscan-api-key <your_etherscan_api_key> \\
--verify

Let's deploy, now

forge create --rpc-url <https://rpc.ankr.com/polygon_mumbai> 
--private-key <your_private_key> src/FDemo.sol:FDemo
--etherscan-api-key <your_etherscan_api_key>
--verify
Forge create | Foundry deploy

Complete code: GitHub

💡 Follow me on Twitter for more awesome stuff like this @pateldeep_eth
Linkedin

New to trading? Try crypto trading bots or copy trading

--

--