Project Layout
Forge is flexible on how you structure your project. By default, the structure is:
.
├── README.md
├── foundry.toml
├── lib
│   └── forge-std
│       ├── LICENSE-APACHE
│       ├── LICENSE-MIT
│       ├── README.md
│       ├── foundry.toml
│       ├── package.json
│       ├── scripts
│       ├── src
│       └── test
├── script
│   └── Counter.s.sol
├── src
│   └── Counter.sol
└── test
    └── Counter.t.sol
8 directories, 10 files
- You can configure Foundry’s behavior using 
foundry.toml. - Remappings are specified in 
remappings.txt. - The default directory for contracts is 
src/. - The default directory for tests is 
test/, where any contract with a function that starts withtestis considered to be a test. - Dependencies are stored as git submodules in 
lib/. 
You can configure where Forge looks for both dependencies and contracts using the --lib-paths and --contracts flags respectively. Alternatively you can configure it in foundry.toml.
Combined with remappings, this gives you the flexibility needed to support the project structure of other toolchains such as Hardhat and Truffle.
For automatic Hardhat support you can also pass the --hh flag, which sets the following flags: --lib-paths node_modules --contracts contracts.