ZKSync Specifics
This section covers the specific parts of ZKSync foundry, how it works, insight into compilation, and custom cheatcodes to help work with contracts specifically in ZKSync.
Context
Foundry-ZKsync tests are initially executed in the EVM context (the traditional execution environment for Ethereum smart contracts). This is done to maintain compatibility with Ethereum tooling and to leverage Foundry features like Cheatcodes.
Lifetime Execution
A forge test begins execution in the EVM context but can switch to the EraVM context during the test for ZKsync-specific features. Selecting the EraVM context ensures all calls and deployments are executed within ZKsync. There are mainly three steps
Step 1) Aggregate: Dual compiling contracts
Step 2) Intercept: Overriding CALL
s and CREATE
s (see limitations for more details)
Step 3): Assimilate: One-shot zkEVM execution (see Standard Library for more details)
Additional Information.
It is essential before deep diving in to the details of how to run the tool. You significantly understand how ZKsync works.
Don’t hesitate to ask if you have specific questions regarding the tool or feature requests.
Having issues?
If you have issues with the tool or don’t know where to start, we strongly suggest you look at our repo and closed issues, where we usually get deep dive into implementation details.