Please note that we require a signed GraphQL Specification Membership agreement before landing a contribution. This is checked automatically when you open a PR. If you have not signed the membership agreement (it's free), you will be prompted by the EasyCLA bot. For more details, please see the GraphQL WG repo.
- First, you will need the latest
git
,yarn
1.16, &node
12 or greater. macOS, Windows and Linux should all be supported as build environments.
Note: None of the commands below will work with npm
. Please use yarn
in
this repo.
-
Fork this repo by using the "Fork" button in the upper-right
-
Check out your fork
git clone [email protected]:your-name-here/graphiql.git
-
Install or Update all dependencies
yarn
-
Build all interdependencies so the project you are working on can resolve other packages
First you'll need —
yarn run build
— or —
yarn run build:watch
If you are focused on GraphiQL development, you can run —
yarn run start-graphiql
-
Get coding! If you've added code, add tests. If you've changed APIs, update any relevant documentation or tests. Ensure your work is committed within a feature branch.
-
Ensure all tests pass, and build everything
yarn test
If you have prettier
or eslint --fix
-able issues you see in CI, use —
yarn format
If you see typescript
build issues, do a yarn build
locally, and make sure
the whole project references tree builds. Changing interfaces can end up
breaking their implementations.
yarn test graphiql
will run all tests for graphiql. You can also run tests from a workspace, but most tooling is at the root.yarn test --watch
will runjest
with--watch
yarn e2e
at the root will run the end-to-end suiteyarn start-monaco
will launchwebpack
dev server for themonaco
editor example with GitHub API from the root. This is the fastest way to test changes tographql-language-service-interface
, parser, etc.
If you want these commands to watch for changes to dependent packages in the
repo, then run yarn build --watch
alongside either of these.
If you want to develop just for graphiql, you won't need to execute commands
from the package subdirectory at packages/graphiql
.
First, you'll need to yarn build
all the packages from the root.
Then, you can run these commands:
yarn start-graphiql
— which will launchwebpack
dev server for graphiql from the root
- First run
yarn
. - run
yarn tsc --watch
to watchmonaco-graphql
andgraphql-language-service
in one screen session/terminal tab/etc - in another session, run
yarn start-monaco
from anywhere in the repository aside from an individual workspace. - alternatively to the webpack example, or in addition, you can run monaco or
next.js examples, though these examples are simpler. They also require their
own
yarn
ornpm install
as they are excluded from theworkspaces
resolved on globalyarn install