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.

Features

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

alt text

Step 2) Intercept: Overriding CALLs and CREATEs (see limitations for more details)

alt text

Step 3): Assimilate: One-shot zkEVM execution (see Standard Library for more details)

alt text

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.