Thanks for contributing! We want to ensure that @0no-co/graphql-web
evolves
and fulfills its idea of making client-side GraphQL smaller and faster!
We follow fairly standard but lenient rules around pull requests and issues. Please pick a title that describes your change briefly, optionally in the imperative mood if possible.
If you have an idea for a feature or want to fix a bug, consider opening an issue first. We're also happy to discuss and help you open a PR and get your changes in!
- If you have a question, try creating a GitHub Discussions thread.
- If you think you've found a bug, open a new issue.
- or, if you found a bug you'd like to fix, open a PR.
- If you'd like to propose a change open an RFC issue. You can read more about the RFC process below.
There are no strict conventions, but we do have two templates in place that will fit most issues, since questions and other discussion start on GitHub Discussions. The bug template is fairly standard and the rule of thumb is to try to explain what you expected and what you got instead. Following this makes it very clear whether it's a known behavior, an unexpected issue, or an undocumented quirk.
We follow an RFC proposal process. This allows anyone to propose a new feature or a change, and allows us to communicate our current planned features or changes, so any technical discussion, progress, or upcoming changes are always documented transparently. You can find the RFC template in our issue creator.
This also comes with no strict conventions. We only ask you to follow the PR template we have in place more strictly here than the templates for issues, since it asks you to list a summary (maybe even with a short explanation) and a list of technical changes.
If you're resolving an issue please don't forget to add Resolve #123
to the description so that
it's automatically linked, so that there's no ambiguity and which issue is being addressed (if any)
You'll find that a comment by the "Changeset" bot may pop up. If you don't know what a changeset is and why it's asking you to document your changes, read on at "How do I document a change for the changelog"
We also typically name our PRs with a slightly descriptive title, e.g. feat: Title
.
Luckily it's not hard to get started. You can install dependencie
using pnpm
.
Please don't use npm
or yarn
to respect the lockfile.
pnpm install
There are multiple commands you can run in the root folder to test your changes:
# TypeScript checks:
pnpm run check
# Linting (prettier & eslint):
pnpm run lint
# Unit Tests:
pnpm run test
# Builds:
pnpm run build
It's always good practice to run the tests when making changes. If you're unsure which packages
may be affected by your new tests or changes you may run pnpm test
in the root of
the repository.
If your editor is not set up with type checks you may also want to run pnpm run check
on your
changes.
Additionally you can head to any example in the examples/
folder
and run them. There you'll also need to install their dependencies as they're isolated projects,
without a lockfile and without linking to packages in the monorepos.
All examples are started using the package.json
's start
script.
We ensure consistency in this codebase using eslint
and prettier
.
They are run on a precommit
hook, so if something's off they'll try
to automatically fix up your code, or display an error.
If you have them set up in your editor, even better!
This project uses changesets. This means that for every PR there must be documentation for what has been changed and which package is affected.
You can document a change by running changeset
, which will ask you which packages
have changed and whether the change is major/minor/patch. It will then ask you to write
a change entry as markdown.
# In the root of the urql repository call:
pnpm changeset
This will create a new "changeset file" in the .changeset
folder, which you should commit and
push, so that it's added to your PR.
This will eventually end up in the package's CHANGELOG.md
file when we do a release.
You won't need to add a changeset if you're simply making "non-visible" changes to the docs or other files that aren't published to the npm registry.
Read more about adding a changeset
here.
Hold up, that's automated! Since we use changeset
to document our changes, which determines what
goes into the changelog and what kind of version bump a change should make, you can also use the
tool to check what's currently posed to change after a release batch using: pnpm changeset status
.
We have a GitHub Actions workflow which is triggered whenever new changes are merged. It will always open a "Version Packages" PR which is kept up-to-date. This PR documents all changes that are made and will show in its description what all new changelogs are going to contain for their new entries.
Once a "Version Packages" PR is approved by a contributor and merged, the action will automatically take care of creating the release, publishing all updated packages to the npm registry, and creating appropriate tags on GitHub too.
This process is automated, but the changelog should be checked for errors.
As to when to merge the automated PR and publish? Maybe not after every change. Typically there are two release batches: hotfixes and release batches. We expect that a hotfix for a single package should go out as quickly as possible if it negatively affects users. For release batches however, it's common to assume that if one change is made to a package that more will follow in the same week. So waiting for a day or two when other changes are expected will make sense to keep the fatigue as low as possible for downstream maintainers.
It may be a good idea to keep all dependencies on this repository up-to-date every now and
then. Typically we do this by running pnpm update --interactive --latest
and checking one-by-one
which dependencies will need to be bumped. In case of any security issues it may make sense to
just run pnpm update [package]
.
While this is rare with pnpm
, upgrading some transitive dependencies may accidentally duplicate
them if two packages depend on different compatible version ranges. This can be fixed by running:
pnpm dedupe
pnpm install
It's common to then create a PR (with a changeset documenting the packages that need to reflect
new changes if any dependencies
have changed) with the name of
"(chore) - Upgrade direct and transitive dependencies" or something similar.