Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/foundry-rs/foundry
Foundry is a blazing fast, portable and modular toolkit for Ethereum application development written in Rust.
https://github.com/foundry-rs/foundry
blockchain dapp dapptools eth ethereum evm framework fuzzing mainnet-fork rust seth solidity testing tooling
Last synced: about 13 hours ago
JSON representation
Foundry is a blazing fast, portable and modular toolkit for Ethereum application development written in Rust.
- Host: GitHub
- URL: https://github.com/foundry-rs/foundry
- Owner: foundry-rs
- License: apache-2.0
- Created: 2021-09-08T11:23:11.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2025-02-10T00:59:58.000Z (1 day ago)
- Last Synced: 2025-02-10T03:28:40.737Z (1 day ago)
- Topics: blockchain, dapp, dapptools, eth, ethereum, evm, framework, fuzzing, mainnet-fork, rust, seth, solidity, testing, tooling
- Language: Rust
- Homepage: https://getfoundry.sh
- Size: 52.7 MB
- Stars: 8,559
- Watchers: 80
- Forks: 1,832
- Open Issues: 483
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE-APACHE
- Codeowners: .github/CODEOWNERS
- Security: SECURITY.md
Awesome Lists containing this project
- awesome - foundry
- awesome-blazingly-fast - foundry - Foundry is a blazing fast, portable and modular toolkit for Ethereum application development written in Rust. (Rust)
- awesome-rust - Foundry - Foundry is a blazing fast, portable and modular toolkit for Ethereum application development. ![Build Status](https://img.shields.io/github/workflow/status/foundry-rs/foundry/test?style=flat-square) (Applications / Blockchain)
- awesome-rust-cn - Foundry - (应用程序 Applications / 加密货币 Cryptocurrencies)
- awesome-testing - Foundry - Blazing fast, portable and modular toolkit for Ethereum application development written in Rust. (Software / Web3 and Blockchain)
- awesome-klaytn - Foundry
- awesome-solidity - foundry-rs/foundry - Blazing fast, portable and modular toolkit for Ethereum application development written in Rust. (Tools)
- awesome-smart-contract-development - Foundry
- awesome-rust - Foundry - Foundry is a blazing fast, portable and modular toolkit for Ethereum application development. ![Build Status](https://img.shields.io/github/workflow/status/foundry-rs/foundry/test?style=flat-square) (Applications / Blockchain)
- StarryDivineSky - foundry-rs/foundry
- awesome-kaia - Foundry
- fucking-awesome-rust - Foundry - Foundry is a blazing fast, portable and modular toolkit for Ethereum application development. ![Build Status](https://img.shields.io/github/workflow/status/foundry-rs/foundry/test?style=flat-square) (Applications / Blockchain)
- fucking-awesome-rust - Foundry - Foundry is a blazing fast, portable and modular toolkit for Ethereum application development. ![Build Status](https://img.shields.io/github/workflow/status/foundry-rs/foundry/test?style=flat-square) (Applications / Blockchain)
README
![]()
[![Github Actions][gha-badge]][gha-url] [![Telegram Chat][tg-badge]][tg-url] [![Telegram Support][tg-support-badge]][tg-support-url]
![Foundry](https://img.shields.io/badge/Foundry-grey?style=flat&logo=%3D&link=https%3A%2F%2Fbook.getfoundry.sh%2F)[gha-badge]: https://img.shields.io/github/actions/workflow/status/foundry-rs/foundry/test.yml?branch=master
[gha-url]: https://github.com/foundry-rs/foundry/actions
[tg-badge]: https://img.shields.io/endpoint?color=neon&logo=telegram&label=chat&style=flat-square&url=https%3A%2F%2Ftg.sumanjay.workers.dev%2Ffoundry_rs
[tg-url]: https://t.me/foundry_rs
[tg-support-badge]: https://img.shields.io/endpoint?color=neon&logo=telegram&label=support&style=flat-square&url=https%3A%2F%2Ftg.sumanjay.workers.dev%2Ffoundry_support
[tg-support-url]: https://t.me/foundry_support**[Install](https://book.getfoundry.sh/getting-started/installation)**
| [User Book][foundry-book]
| [Developer Docs](./docs/dev/README.md)
| [Contributing](./CONTRIBUTING.md)---
### Foundry is a blazing fast, portable and modular toolkit for Ethereum application development written in Rust.
Foundry consists of:
- [**Forge**](#forge): Build, test, fuzz, debug and deploy [Solidity][solidity] contracts, like Hardhat, Brownie, Ape.
- [**Cast**](#cast): A Swiss Army knife for interacting with EVM smart contracts, sending transactions and getting chain data.
- [**Anvil**](#anvil): Fast local Ethereum development node, akin to Hardhat Network, Tenderly.
- [**Chisel**](#chisel): Fast, utilitarian, and verbose Solidity REPL.**Need help getting started with Foundry? Read the [📖 Foundry Book][foundry-book]!**
![Demo](.github/assets/demo.gif)
## Features
- **High-Performance Compilation**
- **Fast and Flexible**: Automatically detects and installs the required Solidity compiler version.
- **Solidity and Vyper Support**: Fully supports both Solidity and Vyper out-of-the-box.
- **Incremental Compilation**: Re-compiles only changed files, saving time.
- **Parallelized Pipeline**: Leverages multi-core systems for ultra-fast builds.
- **Broad Compatibility**: Supports non-standard directory structures, including [Hardhat repos](https://twitter.com/gakonst/status/1461289225337421829).- **Advanced Testing**
- **No Context Switching**: Write tests directly in Solidity.
- **Fuzz Testing**: Quickly identify edge cases with input shrinking and counter-example generation.
- **Invariant Testing**: Ensure complex system properties hold across a wide range of inputs.
- **Debugging Made Easy**: Use [forge-std](https://github.com/foundry-rs/forge-std)'s `console.sol` for flexible debug logging.
- **Interactive Debugger**: Step through your Solidity code with Foundry's interactive debugger, making it easy to pinpoint issues.- **Powerful Runtime Features**
- **RPC Forking**: Fast and efficient remote RPC forking backed by [Alloy][alloy].
- **Lightweight & Portable**: No dependency on Nix or other package managers for installation.- **Streamlined CI/CD**
- **Optimized CI**: Accelerate builds, run tests and execute scripts using [Foundry's GitHub action][foundry-gha].
## Installation
Getting started is very easy:
Install `foundryup`:
```
curl -L https://foundry.paradigm.xyz | bash
```Next, run `foundryup`.
It will automatically install the latest version of the precompiled binaries: [`forge`](#forge), [`cast`](#cast), [`anvil`](#anvil), and [`chisel`](#chisel).
```
foundryup
```**Done!**
For additional details see the [installation guide](https://book.getfoundry.sh/getting-started/installation) in the [Foundry Book][foundry-book].
If you're experiencing any issues while installing, check out [Getting Help](#getting-help) and the [FAQ](https://book.getfoundry.sh/faq).
## How Fast?
Forge is quite fast at both compiling (leveraging `solc` with [foundry-compilers]) and testing.
See the benchmarks below. Older benchmarks against [DappTools][dapptools] can be found in the [v0.2.0 announcement post][benchmark-post] and in the [Convex Shutdown Simulation][convex] repository.
### Testing Benchmarks
| Project | Type | [Forge 1.0][foundry-1.0] | [Forge 0.2][foundry-0.2] | DappTools | Speedup |
| --------------------------------------------- | -------------------- | ------------------------ | ------------------------ | --------- | -------------- |
| [vectorized/solady][solady] | Unit / Fuzz | 0.9s | 2.3s | - | 2.6x |
| [morpho-org/morpho-blue][morpho-blue] | Invariant | 0.7s | 1m43s | - | 147.1x |
| [morpho-org/morpho-blue-oracles][morpho-blue] | Integration (Cold) | 6.1s | 6.3s | - | 1.04x |
| [morpho-org/morpho-blue-oracles][morpho-blue] | Integration (Cached) | 0.6s | 0.9s | - | 1.50x |
| [transmissions11/solmate][solmate] | Unit / Fuzz | 2.7s | 2.8s | 6m34s | 1.03x / 140.0x |
| [reflexer-labs/geb][geb] | Unit / Fuzz | 0.2s | 0.4s | 23s | 2.0x / 57.5x |_In the above benchmarks, compilation was always skipped_
**Takeaway: Forge dramatically outperforms the competition, delivering blazing-fast execution speeds while continuously expanding its robust feature set.**
### Compilation Benchmarks
![]()
![]()
**Takeaway: Forge compilation is consistently faster than Hardhat by a factor of `2.1x` to `5.2x`, depending on the amount of caching involved.**
## Forge
Forge helps you build, test, fuzz, debug and deploy Solidity contracts.
The best way to understand Forge is to simply try it (in less than 30 seconds!).
First, let's initialize a new `counter` example repository:
```sh
forge init counter
```Next `cd` into `counter` and build :
```sh
forge build
``````console
[⠊] Compiling...
[⠔] Compiling 27 files with Solc 0.8.28
[⠒] Solc 0.8.28 finished in 452.13ms
Compiler run successful!
```Let's [test](https://book.getfoundry.sh/forge/tests#tests) our contracts:
```sh
forge test
``````console
[⠊] Compiling...
No files changed, compilation skippedRan 2 tests for test/Counter.t.sol:CounterTest
[PASS] testFuzz_SetNumber(uint256) (runs: 256, μ: 31121, ~: 31277)
[PASS] test_Increment() (gas: 31293)
Suite result: ok. 2 passed; 0 failed; 0 skipped; finished in 5.35ms (4.86ms CPU time)Ran 1 test suite in 5.91ms (5.35ms CPU time): 2 tests passed, 0 failed, 0 skipped (2 total tests)
```Finally, let's run our deployment script:
```sh
forge script script/Counter.s.sol
``````console
[⠊] Compiling...
No files changed, compilation skipped
Script ran successfully.
Gas used: 109037If you wish to simulate on-chain transactions pass a RPC URL.
```Run `forge --help` to explore the full list of available subcommands and their usage.
More documentation can be found in the [forge][foundry-book-forge] section of the Foundry Book.
## Cast
Cast is a Swiss Army knife for interacting with Ethereum applications from the command line.
Here are a few examples of what you can do:
**Check the latest block on Ethereum Mainnet**:
```sh
cast block-number --rpc-url https://eth.merkle.io
```**Check the Ether balance of `vitalik.eth`**
```sh
cast balance vitalik.eth --ether --rpc-url https://eth.merkle.io
```**Replay and trace a transaction**
```sh
cast run 0x9c32042f5e997e27e67f82583839548eb19dc78c4769ad6218657c17f2a5ed31 --rpc-url https://eth.merkle.io
```Optionally, pass `--etherscan-api-key ` to decode transaction traces using verified source maps, providing more detailed and human-readable information.
---
Run `cast --help` to explore the full list of available subcommands and their usage.
More documentation can be found in the [cast][foundry-book-cast] section of the Foundry Book.
## Anvil
Anvil is a fast local Ethereum development node.
Let's fork Ethereum mainnet at the latest block:
```sh
anvil --fork-url https://eth.merkle.io
```You can use those same `cast` subcommands against your `anvil` instance:
```sh
cast block-number
```---
Run `anvil --help` to explore the full list of available features and their usage.
More documentation can be found in the [anvil][foundry-book-anvil] section of the Foundry Book.
## Chisel
Chisel is a fast, utilitarian, and verbose Solidity REPL.
To use Chisel, simply type `chisel`.
```sh
chisel
```From here, start writing Solidity code! Chisel will offer verbose feedback on each input.
Create a variable `a` and query it:
```console
➜ uint256 a = 123;
➜ a
Type: uint256
├ Hex: 0x7b
├ Hex (full word): 0x000000000000000000000000000000000000000000000000000000000000007b
└ Decimal: 123
```Finally, run `!source` to see `a` was applied:
```solidity
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.28;import {Vm} from "forge-std/Vm.sol";
contract REPL {
Vm internal constant vm = Vm(address(uint160(uint256(keccak256("hevm cheat code")))));/// @notice REPL contract entry point
function run() public {
uint256 a = 123;
}
}
```---
Run `chisel --help` to explore the full list of available features and their usage.
More documentation can be found in the [chisel][foundry-book-chisel] section of the Foundry Book.
## Configuration
Foundry is highly configurable, allowing you to tailor it to your needs. Configuration is managed via a file called [`foundry.toml`](./crates/config) located in the root of your project or any parent directory. For a full list of configuration options, refer to the [config package documentation](./crates/config/README.md#all-options).
**Profiles and Namespaces**
- Configuration can be organized into **profiles**, which are arbitrarily namespaced for flexibility.
- The default profile is named `default`. Learn more in the [Default Profile section](./crates/config/README.md#default-profile).
- To select a different profile, set the `FOUNDRY_PROFILE` environment variable.
- Override specific settings using environment variables prefixed with `FOUNDRY_` (e.g., `FOUNDRY_SRC`).---
You can find additional [setup and configurations guides][foundry-book-config] in the [Foundry Book][foundry-book] and in the [config crate](./crates/config/README.md):
- [Configuring with `foundry.toml`](https://book.getfoundry.sh/config/)
- [Setting up VSCode][vscode-setup]
- [Shell autocompletions][shell-setup]## Contributing
See our [contributing guidelines](./CONTRIBUTING.md).
## Getting Help
First, see if the answer to your question can be found in the [Foundy Book][foundry-book], or in the relevant crate.
If the answer is not there:
- Join the [support Telegram][tg-support-url] to get help, or
- Open a [discussion](https://github.com/foundry-rs/foundry/discussions/new) with your question, or
- Open an issue with [the bug](https://github.com/foundry-rs/foundry/issues/new)If you want to contribute, or follow along with contributor discussion, you can use our [main telegram](https://t.me/foundry_rs) to chat with us about the development of Foundry!
## License
Licensed under either of [Apache License](./LICENSE-APACHE), Version
2.0 or [MIT License](./LICENSE-MIT) at your option.Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in these crates by you, as defined in the Apache-2.0 license,
shall be dual licensed as above, without any additional terms or conditions.## Acknowledgements
- Foundry is a clean-room rewrite of the testing framework [DappTools][dapptools]. None of this would have been possible without the DappHub team's work over the years.
- [Matthias Seitz](https://twitter.com/mattsse_): Created [ethers-solc] (now [foundry-compilers]) which is the backbone of our compilation pipeline, as well as countless contributions to ethers, in particular the `abigen` macros.
- [Rohit Narurkar](https://twitter.com/rohitnarurkar): Created the Rust Solidity version manager [svm-rs](https://github.com/roynalnaruto/svm-rs) which we use to auto-detect and manage multiple Solidity versions.
- [Brock Elmore](https://twitter.com/brockjelmore): For extending the VM's cheatcodes and implementing [structured call tracing](https://github.com/foundry-rs/foundry/pull/192), a critical feature for debugging smart contract calls.
- All the other [contributors](https://github.com/foundry-rs/foundry/graphs/contributors) to the [ethers-rs](https://github.com/gakonst/ethers-rs), [alloy][alloy] & [foundry](https://github.com/foundry-rs/foundry) repositories and chatrooms.[solidity]: https://soliditylang.org/
[foundry-book]: https://book.getfoundry.sh
[foundry-book-config]: https://book.getfoundry.sh/config/
[foundry-book-forge]: https://book.getfoundry.sh/reference/forge/
[foundry-book-anvil]: https://book.getfoundry.sh/reference/anvil/
[foundry-book-cast]: https://book.getfoundry.sh/reference/cast/
[foundry-book-chisel]: https://book.getfoundry.sh/reference/chisel/
[foundry-gha]: https://github.com/foundry-rs/foundry-toolchain
[foundry-compilers]: https://github.com/foundry-rs/compilers
[ethers-solc]: https://github.com/gakonst/ethers-rs/tree/master/ethers-solc/
[solady]: https://github.com/Vectorized/solady
[openzeppelin]: https://github.com/OpenZeppelin/openzeppelin-contracts/tree/release-v5.1
[morpho-blue]: https://github.com/morpho-org/morpho-blue
[foundry-compilers]: https://github.com/foundry-rs/compilers
[solmate]: https://github.com/transmissions11/solmate/
[geb]: https://github.com/reflexer-labs/geb
[benchmark-post]: https://www.paradigm.xyz/2022/03/foundry-02#blazing-fast-compilation--testing
[convex]: https://github.com/mds1/convex-shutdown-simulation
[vscode-setup]: https://book.getfoundry.sh/config/vscode.html
[shell-setup]: https://book.getfoundry.sh/config/shell-autocompletion.html
[foundry-0.2]: https://github.com/foundry-rs/foundry/releases/tag/nightly-5b7e4cb3c882b28f3c32ba580de27ce7381f415a
[foundry-1.0]: https://github.com/foundry-rs/foundry/releases/tag/nightly-59f354c179f4e7f6d7292acb3d068815c79286d1
[dapptools]: https://github.com/dapphub/dapptools
[alloy]: https://github.com/alloy-rs/alloy