Forked Networks¶
What is Forking¶
Forking is the process of creating a local copy of a network at a specific block height. There is a bit of “magic” to it, because we don’t really download the whole blockchain locally, but as long as you have a connection to a node (like for example, via an RPC) you can fork a network.
It’s incredibly helpful for testing, because it allows you to simulate what could/would happen on a live network when you run a script or send a transaction.
Note
However, you don’t want to blindly trust simulations or the outcome of forked tests. In the real world, people can send transactions to the network while your script is in flight and mess with your scripting!
Forking¶
In testing, forking is an essential part of the development process. Any script that you want to run on a live network you should be running on a forked network first! In moccasin, forking is a first class citizen.
[networks.sepolia]
url = "https://ethereum-sepolia-rpc.publicnode.com"
chain_id = 11155111
is_fork = true
Running a script with this setup will run your script locally, but pretending to be on the sepolia
network, with contracts and everything!
It essentially does some “lazy loading”, where it’ll only download information from the blockchain if/when you need. For example, if you want to get the balance of an account, it’ll only download the balance of that account when your script calls for it.
You can also take any non-forked network and run a forked test just by adding the --fork
flag to the command line.
[networks.sepolia]
url = "https://ethereum-sepolia-rpc.publicnode.com"
chain_id = 11155111
is_fork = false
Forked network defaults¶
is_zksync = "true"
prompt_live = "false"
save_to_db = "false"
live_or_staging = "false"
db_path = "None"