Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

➖ remove make as the automation tool #9

Merged
merged 2 commits into from
Jan 10, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .github/workflows/quality-checks.yml
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ jobs:
run: npm ci

- name: Run the linter and the formatter in check mode
run: make quality
run: forge fmt --check && npx solhint "{script,src,test}/**/*.sol"

- name: Add lint summary
run: |
Expand All @@ -51,7 +51,7 @@ jobs:
uses: foundry-rs/foundry-toolchain@v1

- name: Compile the contracts and print their size
run: make compile-s
run: forge compile --sizes

- name: Add compile summary
run: |
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/release-package.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ jobs:
uses: foundry-rs/foundry-toolchain@v1

- name: Build the documentation
run: make doc
run: forge doc && forge doc --build

- name: Deploy the documentation
uses: JamesIves/github-pages-deploy-action@v4
Expand Down
3 changes: 0 additions & 3 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,6 @@ broadcast/*/31337/
# coverage generated by genhtml
report

# makefile generated files
.make.*

# autogenerated documentation
docs

Expand Down
228 changes: 0 additions & 228 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,231 +22,3 @@
[license]: ./LICENSE.md
[license-badge]: https://img.shields.io/badge/License-MIT-blue.svg

A Foundry-based template for developing Solidity smart contracts, with sensible defaults. Based on
[@PaulRBerg](https://github.com/PaulRBerg) [template](https://github.com/PaulRBerg/foundry-template).

## What's Inside

- [Forge](https://github.com/foundry-rs/foundry/blob/master/forge): compile, test, fuzz, format, and deploy smart
contracts
- [Forge Std](https://github.com/foundry-rs/forge-std): collection of helpful contracts and cheatcodes for testing
- [PRBTest](https://github.com/PaulRBerg/prb-test): modern collection of testing assertions and logging utilities
- [Prettier](https://github.com/prettier/prettier): code formatter for non-Solidity files
- [Solhint Community](https://github.com/solhint-community/solhint-community): linter for Solidity code
- [Make](https://www.gnu.org/software/make/manual/make.html): build automation tool that allows developers to automate
repetitive tasks
- [Lefthook](https://github.com/evilmartians/lefthook): Fast and powerful Git hooks manager for any type of projects

## Getting Started

### Prerequisites

This repository uses [`make`](https://www.gnu.org/software/make/manual/make.html) to automate repetitive tasks.

`make` is a build automation tool that employs a file known as a makefile to automate the construction of executable
programs and libraries. The makefile details the process of deriving the target program from the source files and other
dependencies. This allows developers to automate repetitive tasks and manage complex build processes efficiently. `make`
is our primary tool in a multi-environment repository. It enables us to centralize all commands into a single file
([the makefile](./makefile)), eliminating the need to deal with `npm` scripts defined in a package.json or remembering
the various commands provided by the `foundry` cli. If you're unfamiliar with `make`, you can read more about it
[here](https://www.gnu.org/software/make/manual/make.html).

> 💡 Running make at the root of the project will display a list of all the available commands. This can be useful to
> know what you can do with the project.

#### Make of Linux

`make` is automatically included in all modern Linux distributions. If you're using Linux, you should be able to use
`make` without any additional steps. If not, you can likely find it in the package tool you usually use.

#### Make on MacOS

MacOS users can install `make` using [Homebrew](https://formulae.brew.sh/formula/make) with the following command:

```sh
brew install make
```

### Installation

Click the [`Use this template`](https://github.com/0x90d2b2b7fb7599eebb6e7a32980857d8/template-foundry/generate) button at the top of the page to
create a new repository with this repo as the initial state.

Or, if you prefer to install the template manually:

```sh
forge init my-project --template https://github.com/0x90d2b2b7fb7599eebb6e7a32980857d8/template-foundry
cd my-project
make install # install the forge dependencies and the npm dependencies
```

If this is your first time with Foundry, check out the
[installation](https://github.com/foundry-rs/foundry#installation) instructions.

> ℹ️ As part of the initialization process, a one-time script, which can be found
> [here](./.github/workflows/setup-template.yml), is utilized to tailor the template to your specific project. This
> script will automatically update the [package.json](./package.json) file with details like your project's name, the
> author's name, the homepage, the repository URL, etc. Additionally, it will remove unnecessary files, such as the
> FUNDING.yml file and the initialization script itself.

### Git hooks

This project uses `Lefthook` to manage Git hooks, which are scripts that run automatically when certain Git events
occur, such as committing code or pushing changes to a remote repository. `Lefthook` simplifies the management and
execution of these scripts.

After installing the dependencies, you can configure the Git hooks by running the following command in the project
directory:

```sh
make hooks-i
```

This command installs a Git hook that runs Lefthook before pushing code to a remote repository. If Lefthook fails, the
push is aborted.

If you wish to run Lefthook manually, you can use the following command:

```sh
make hooks
```

Executing this will activate all the Git hooks specified in the [lefthook](./lefthook.yml) file, including commands for
linting, formatting, testing, and compiling.

#### Skipping git hooks

If you need to intentionally skip Lefthook, you can pass the `--no-verify` flag to the git push command. For example to
bypass Lefthook when pushing code, use the following command:

```sh
git push origin --no-verify
```

## Features

This template builds upon the frameworks and libraries mentioned above, so for details about their specific features,
please consult their respective documentation.

For example, if you're interested in exploring Foundry in more detail, you should look at the
[Foundry Book](https://book.getfoundry.sh/). In particular, you may be interested in reading the
[Writing Tests](https://book.getfoundry.sh/forge/writing-tests.html) tutorial.

### Sensible Defaults

This template comes with a set of sensible default configurations for you to use. These defaults can be found in the
following files:

```text
├── .gitignore
├── .prettierignore
├── .prettierrc.yml
├── .solhint.json
├── .nvmrc
├── lefthook.yml
├── makefile
├── slither.config.json
└── foundry.toml
```

### GitHub Actions

This template comes with GitHub Actions pre-configured.

- [quality-checks.yml](./.github/workflows/quality-checks.yml): runs the compilation command, the linter and the
formatter on every push and pull request made to the `main` branch. The size of the contracts is printed in the logs.
- [static-analysis.yml](./.github/workflows/static-analysis.yml): runs the static analysis tool on every push and pull
request made to the `main` branch. This action uses [slither](https://github.com/crytic/slither) and is only triggered
when specific files are modified.
- [tests.yml](./.github/workflows/tests.yml): runs the tests on every push and pull request made to the `main` branch. This action also compare the gas cost between the `main` branch and the pull request branch and post the difference as a comment on the pull request. Finally this action check the code coverage and post the result as a comment on the pull request. A threshold can be configured by unchecking the concerned line in the workflow file. This workflow uses [lcov](https://github.com/linux-test-project/lcov) for the coverage.
- [release-package.yml](./.github/workflows/release-package.yml): creates a new release every time you push a new tag to
the repository. This action is only triggered on tags starting with `v`. Once the release is created, the action is
also in charge of deploying the documentation to the `gh-pages` branch. **THIS ACTION NEEDS AN ACTION FROM YOUR SIDE
TO WORK**

You can edit the CI scripts in the [workflows directory](./.github/workflows).

#### Configure the release action

The release action is in charge of deploying the documentation to the `gh-pages` branch. To do so, it needs to have a
personal access token with the right permissions. To create this token, go to the
[settings of your Github account](https://github.com/settings/tokens?type=beta). Make sure to select the permissions
listed below. Once create, copy the token, go to the Github repository of this project and create a secret named
`RELEASE_TOKEN` with the value of the token you just created. Here are the **repositories** permissions required by the
token:

- Actions: Read and write
- Contents: Read and write
- Commit statuses: Read-only
- Metadata: Read-only
- Pull requests: Read-only

## Writing Tests

To write a new test contract, you start by importing [PRBTest](https://github.com/PaulRBerg/prb-test) and inherit from
it in your test contract. PRBTest comes with a pre-instantiated [cheatcodes](https://book.getfoundry.sh/cheatcodes/)
environment accessible via the `vm` property. If you would like to view the logs in the terminal output you can run the
dedicated verbose command and use
[console.log](https://book.getfoundry.sh/faq?highlight=console.log#how-do-i-use-consolelog).

This template comes with an example test contract [Foo.t.sol](./test/Foo.t.sol)

## Usage

You can access a list of all available commands by running `make` in the project's root directory.

```sh
make
```

These commands are outlined in the [makefile](./Makefile).

## Scripts

### Deploy

This script is located in the [script](./script) directory. It deploys the contract to a network. For example, to deploy
to [Anvil](https://book.getfoundry.sh/anvil/), you can run the following command:

```sh
forge script script/Deploy.s.sol --broadcast --fork-url http://localhost:8545
```

For this script to work, you need to have a `MNEMONIC` environment variable set to a valid
[BIP39 mnemonic](https://iancoleman.io/bip39/).

For instructions on how to deploy to a testnet or mainnet, check out the
[Solidity Scripting](https://book.getfoundry.sh/tutorials/solidity-scripting.html) tutorial.

## Notes

1. Foundry uses [git submodules](https://git-scm.com/book/en/v2/Git-Tools-Submodules) to manage dependencies. For
detailed instructions on working with dependencies, please refer to the
[guide](https://book.getfoundry.sh/projects/dependencies.html) in the book
2. You don't have to create a `.env` file, but filling in the environment variables may be useful when debugging and
testing against a fork.
3. This template uses [npm](https://www.npmjs.com/) to manage JavaScript dependencies.
4. This template only uses [slither](https://github.com/crytic/slither) in the CI pipeline. If you want to run it
locally, you need to install it for yourself by following the instructions in the
[documentation](https://github.com/crytic/slither#how-to-install).
5. This template includes a opiniated [contributing guide](./.github/CONTRIBUTING.md) you free to update.
6. Remappings are configured in the [foundry.toml file](./foundry.toml) file in order to centralize the configuration.
Feel free to update them.

## Related Efforts

- [abigger87/femplate](https://github.com/abigger87/femplate)
- [cleanunicorn/ethereum-smartcontract-template](https://github.com/cleanunicorn/ethereum-smartcontract-template)
- [foundry-rs/forge-template](https://github.com/foundry-rs/forge-template)
- [FrankieIsLost/forge-template](https://github.com/FrankieIsLost/forge-template)
- [PaulRBerg/foundry-template](https://github.com/PaulRBerg/foundry-template)

## License

This project is licensed under MIT.

## Acknowledgements

This template has been boostrapped using [@PaulRBerg](https://github.com/PaulRBerg)
[template](https://github.com/PaulRBerg/foundry-template). This version is a bit more opinionated (`make`...) and comes
with a few more features. Thanks to him for his valuable contributions to the community.
8 changes: 4 additions & 4 deletions lefthook.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,11 @@ pre-push:
commands:
lint:
tags: quality
run: make lint
run: forge fmt --check && npx solhint "{script,src,test}/**/*.sol"
format:
tags: quality
run: make format
run: npx prettier --check "**/*.{json,md,yml}"
test:
run: make test
run: forge test
build:
run: make compile
run: forge compile
Loading
Loading