This document guides you to start with fhEVM by using our Hardhat template.
This template allows you to launch an fhEVM Docker image and run your smart contract on it. For more information, refer to the README.
The Hardhat template comes pre-configured with tools and libraries to streamline the development process:
Default configurations: Includes sensible default configurations for tools like Prettier, Solhint, and ESLint.
GitHub actions: Pre-configured for CI/CD pipelines to lint and test contracts on every push or pull request.
Install pnpm for dependency management.
Set up a mnemonic: Create a .env
file by copying .env.example
:
Generate a mnemonic using this tool if needed.
Install dependencies: Ensure you’re using Node.js v20 or later:
Here’s a list of essential commands to work with the Hardhat template:
Command
Description
pnpm compile
Compiles the smart contracts.
pnpm typechain
Compiles contracts and generates TypeChain bindings.
pnpm test
Runs tests locally in mocked mode, simulating FHE operations.
pnpm lint:sol
Lints Solidity code.
pnpm lint:ts
Lints TypeScript code.
pnpm clean
Cleans contract artifacts, cache, and coverage reports.
pnpm coverage
Analyzes test coverage (mocked mode only).
Mocked mode allows faster testing by simulating FHE operations. This mode runs tests on a local Hardhat network without requiring a real fhEVM node. Use the following commands:
Run tests:
Analyze coverage:
Note: Mocked mode approximates gas consumption for FHE operations but may slightly differ from actual fhEVM behavior.
Non-mocked mode uses a real fhEVM node, such as the coprocessor on the Sepolia test network.
Run tests on Sepolia:
Requirements:
Fund test accounts on Sepolia.
Pass the correct FHEVMConfig
struct in your smart contract’s constructor.
Note: Refer to the fhEVM documentation for configuring
FHEVMConfig
.
For Solidity syntax highlighting, use the Hardhat Solidity extension for VSCode.
Due to limitations in the solidity-coverage
package, coverage computation in fhEVM does not support tests involving the evm_snapshot
Hardhat testing method. However, this method is still supported when running tests in mocked mode. If you are using Hardhat snapshots, we recommend to end your your test description with the [skip-on-coverage]
tag to to avoid coverage issues. Here is an example:
In this snippet, the first test will always run, whether in "real" non-mocked mode (pnpm test
), testing mocked mode (pnpm test
) or coverage (mocked) mode (pnpm coverage
). On the other hand, the second test will be run only in testing mocked mode(pnpm test
), because snapshots only works in that specific case. Actually, the second test will be skipped if run in coverage mode, since its description string ends with [skip-on-coverage]
and similarly, we avoid the test to fail in non-mocked mode since we check that the network name is hardhat
.
Due to intrinsic limitations of the original EVM, the mocked version differ in few corner cases from the real fhEVM, mainly in gas prices for the FHE operations. This means that before deploying to production, developers still need to run the tests with the original fhEVM node, as a final check in non-mocked mode, with pnpm test
or npx hardhat test
.
By using this Hardhat template, you can streamline your fhEVM development workflow and focus on building robust, privacy-preserving smart contracts. For additional details, visit the fhevm-hardhat-template README.
Zama 5-Question Developer Survey
We want to hear from you! Take 1 minute to share your thoughts and helping us enhance our documentation and libraries. 👉 Click here to participate.