- Foundry
- Bun
- Halmos (optional)
- Linux / MacOS / WSL 2
foundryup -v nightly-f3376a6e45ffacd45125e639e5f50bec0c0900be
<emoji><space><Title>
Type | Emoji |
---|---|
readme/docs | π |
new feature | β¨ |
refactor/cleanup | β»οΈ |
nit | π₯’ |
security fix | π |
optimization | β‘οΈ |
configuration | π·ββοΈ |
events | π |
bug fix | π |
tooling | π§ |
deployments | π |
Initialize
bun install
Make a copy of .env.defaults
to .env
and set the desired parameters. This file is git ignored.
Build and Test.
bun run build
bun run test
Test a specific file
bun run test --match-path test/MyTest.t.sol
Test a specific test
bun run test --match-path test/MyTest.t.sol --match-test testFoobar
To run the symbolic execution tests, you need to have Halmos installed.
Run all symbolic tests.
bun run symtest
Run symbolic test for a specific contract.
bun run symtest --contract FooBarSymTestContract
Run specific symbolic.
bun run symtest --function proveFooBar
When using WALLET_TYPE=keystore
, you need to create a keystore file for the deployer.
cast wallet import deployer -i
More info https://book.getfoundry.sh/reference/cast/cast-wallet-import
This will run each deploy the script MyScript.s.sol
inside script/
folder.
bun run deploy --network <network-name> --script <my-script-name>
For chains that don't support verify on deploy, you can use the verify
task after the deploy.
bun run deploy:no-verify --network <network-name> --script <my-script-name>
bun run task verify --network <network-name> --deployment <deployment-name>
use libs.json
to specify the git dependency lib with the commit hash.
run bun install
again to update them.
This will update to the latest Foundry release
foundryup
Playground is a place to make quick tests. Everything that could be inside a normal test can be used there. Use case can be to test out some gas optimisation, decoding some data, play around with solidity, etc.
bun run playground
bun run task verify --deployment Avalanche_ElevatedMinterBurner_Mock --network avalanche
Use deployments/MyContract.json to get the information needed for the verification
forge verify-contract --chain-id 1 --num-of-optimizations 200 --watch --constructor-args $(cast abi-encode "constructor(address,address[])" "<address>" "[<address>,address]") --compiler-version v0.8.16+commit.07a7930e <contract-address> src/MyContract.sol:MyContract -e <etherscan-api-key>
Where Avalanche_ElevatedMinterBurner_Mock
is the deployment json file inside deployments/
and src/periphery/ElevatedMinterBurner.sol:ElevatedMinterBurner
the <contract-path>:<contract-name>
artifact.
bun run task forge-deploy-multichain --script Create3Factory --broadcast --verify all
bun run task forge-deploy-multichain --script Create3Factory --broadcast --no-confirm --verify mainnet polygon avalanche
- Use create3Factories task to deploy a new version on all chain.
- If you want to add an existing one to another chain:
- need to be deployed from the same msg.sender
- copy hexdata from the create3factory of the one you want to deploy at the same address to another chain
- send hexdata to 0x4e59b44847b379578588920cA78FbF26c0B4956C (create2 factory) using metamask hexdata field, for example.
- copy paste existing deployment from deployments/. Like Arbitrum_Create3Factory.json to the new chain deployment
- change the deployment file name + txHash at the bottom of the file
- verify the contract, for example:
bun run task verify --network base --deployment Base_Create3Factory --artifact src/mixins/Create3Factory.sol:Create3Factory
This isn't the preferred way to deploy and should be the last resort when the RPC can't work properly with forge script
.
forge create --rpc-url <rpc> \
--constructor-args 0x591199E16E006Dec3eDcf79AE0fCea1Dd0F5b69D "magicCurveLP MIM-USDT" "mCurveLP-MIM-USDT" \
--account deployer \
--verify --verifier blockscout --verifier-url https://kavascan.com/api? \
--legacy \
src/tokens/MagicCurveLp.sol:MagicCurveLp
Then create a deployment file with at least the contract address in it.
And to interact:
cast send --rpc-url <rpc> \
--account deployer \
--legacy \
0x729D8855a1D21aB5F84dB80e00759E7149936e30 \
"setStaking(address)" \
0xdC398735150d538B2F18Ccd13A55F6a54488a677
forge create --rpc-url <rpc> \
--constructor-args <arg1> <arg2> <arg3> \
--account deployer \
--verify --verifier blockscout --verifier-url https://kavascan.com/api? \
--legacy \
src/strategies/StargateLPStrategy.sol:StargateLPStrategy
forge verify-contract --chain-id 2222 --num-of-optimizations 800 --watch --constructor-args $(cast abi-encode "constructor(address,address[])" "<address>" "[<address>,address]") --compiler-version v0.8.20+commit.a1b79de6 <address> src/strategies/StargateLPStrategy.sol:StargateLPStrategy --verifier blockscout --verifier-url https://kavascan.com/api?
Installation:
pip3 install slither-analyzer --user
wget https://github.com/crytic/echidna/releases/download/v2.2.3/echidna-2.2.3-x86_64-linux.tar.gz
tar -xzvf echidna-2.2.3-x86_64-linux.tar.gz
Running:
bun run echidna
Beware, while echidna is running the fuzzing suite is moved over
src/
folder, this way is can remains intest/
while it's not used.