doc/development/graphql_guide/reviewing.md
The GitLab GraphQL API has a fair degree of complexity so it's important that merge requests containing GraphQL changes be reviewed by someone familiar with GraphQL.
You can ping one via the @gitlab-org/graphql-experts group in a MR or in the #f_graphql channel in Slack (available to GitLab team members only).
GraphQL queries need to be reviewed for:
This is not an exhaustive list.
Ensure that the description includes a sample query with setup instructions. Try running the query in GraphiQL on your local GDK instance.
Check the MR for any breaking changes.
If a feature is marked as an experiment, you can make breaking changes immediately, with no deprecation period.
For more information, see deprecation and removal process.
Ensure that multi-version compatibility is guaranteed. This generally means frontend and backend code for the same GraphQL feature can't be shipped in the same release.
For details, see multiple version compatibility.
Changes to the generated API docs require a technical writer review.
Public-facing changes that are not marked as an experiment require a changelog entry.
GraphQL is a framework with many moving parts. It's important that the framework is followed.
MyResolver.single (see deriving resolvers).ready? method for more complex argument logic (see correct use of resolver#ready).prepare method for more complex argument validation (see Preprocessing).For details, see resolver guide.
Ensure proper authorization is followed and that authorize :some_ability is tested in the specs.
For details, see authorization guide.
Ensure:
For example:
TimeType for Ruby Time and DateTime objects.id fieldsFor details, see types.
Query complexity is a way of quantifying how expensive a query is likely to be. Query complexity limits are defined as constants in the schema. When a resolver or type is expensive to call we need to ensure that the query complexity reflects that.
For details, see max complexity, field complexity and query limits.
resolve method and a request spec is the only way to ensure they behave properly.For details, see testing guide.