Thanks for your interest in contributing to Ponder! Please take a moment to review this document before submitting a pull request.
If you want to contribute, but aren't sure where to start, reach out in Ponder's public telegram group or create a new discussion.
This guide is intended to help you get started with contributing. By following these steps, you will understand the development process and workflow.
- Fork the repository
- Install Node.js and pnpm
- Install Foundry
- Install dependencies
- Build packages
- Run the test suite
- Write documentation
- Submit a pull request
- Versioning and releases
- That's it!
To start contributing to the project, create a fork and clone it to your machine using git clone
.
Or, use the GitHub CLI to create a fork and clone it in one command:
gh repo fork ponder-sh/ponder --clone
Ponder uses pnpm workspaces to manage multiple projects. You need to install Node.js v18 or higher and pnpm v9 or higher.
You can run the following commands in your terminal to check your local Node.js and pnpm versions:
node -v
pnpm -v
If the versions are not correct or you don't have Node.js or pnpm installed, download and follow their setup instructions:
- Install Node.js using nvm, fnm, or from the official website
- Install pnpm
Ponder uses Foundry for testing. The test suite uses local Anvil instances via Anvil.js to run isolated, concurrent tests against forks of Ethereum mainnet.
Install Foundry (and Anvil) using the following command:
curl -L https://foundry.paradigm.xyz | bash
In the root directory, run the following command to install the project's dependencies:
pnpm install
In the root directory, run the build command:
pnpm build
After the build completes, pnpm links packages across the project for development. This means that if you run any of the projects in the examples/
directory, they will use the local version of ponder
.
The test suite uses vitest in concurrent mode as a test runner.
Herea are some commands to get you started.
# Run all tests in watch mode
pnpm test
# Run a single test file
pnpm test /path/to/file.test.ts
When adding new features or fixing bugs, it's important to add test cases to cover any new or updated behavior.
By default, the test suite runs against in-memory PGlite databases which mimic Ponder development environments. Unless you are specifically testing Postgres behavior, you don't need to run tests against Postgres locally and can instead rely on CI to catch any regressions.
To run the test suite against Postgres, set the DATABASE_URL
env var in packages/core/.env.local
.
DATABASE_URL=postgres://{username}@localhost:5432/{username}
Any test-friendly Postgres server will do. MacOS users can download Postgres.app, a simple way to get a Postgres server running on your local machine.
Ponder uses Nextra and Markdown for the documentation website (located at docs
). To start the docs website in dev mode, run:
cd docs
pnpm dev
When you're ready to submit a pull request, follow these naming conventions:
- Pull request titles use the imperative mood (e.g.,
Add something
,Fix something
). - Changesets use past tense verbs (e.g.,
Added something
,Fixed something
).
When you submit a pull request, a GitHub Action will automatically lint, build, and test your changes. If you see an ❌, it's most likely a problem with your code. Inspect the logs through the GitHub Actions UI to find the cause.
Ponder uses changesets to manage package versioning and NPM releases.
Ponder is still in alpha, so all changes should be marked as a patch.
- Write a PR that includes a public API change or bug fix.
- Create a changeset using
pnpm changeset
. The changesets CLI will ask you which package is affected (ponder
orcreate-ponder
) and if the change is a patch, minor, or major release. - The changesets CLI will generate a Markdown file in
.changeset/
that includes the details you provided. Commit this file to your PR branch (e.g.git commit -m "chore: changeset"
). - When you push this commit to remote, a GitHub bot will detect the changeset and add a comment to your PR with a preview of the changelog.
- Merge your PR. The changesets Github Action workflow will open (or update) a PR with the title
"chore: version packages"
. The changes in your PR will not be released until this PR is merged.
When you're ready to release, merge the "chore: version packages"
PR into main
. This will trigger the changesets Github Action workflow to build packages, publish to NPM, and create a new GitHub release.
If you still have questions, please reach out in Ponder's public telegram group or create a new discussion.
This guide was adapted from viem's contribution guide. ❤️