-
Notifications
You must be signed in to change notification settings - Fork 1
Home
Welcome to the tutorial accompanying the GraphQL workshop. This purpose of this tutorial is to get you up and running with GraphQL andnd to introduce the most important concepts of using GraphQL.
There are 3 parts to this tutorial:
- Fundamentals: Chapters with assignments to step-by-step build a GraphQL api and web application, including solutions
- Testing: Explains 3 possible testing strategies
- Final Project: A final assignment to build a SpaceX application, including solutions
To get the most out of this workshop we recommend solving the assignments on your own, and using the solutions as comparison or if you're really stuck . The workshop presentation together with the information in the chapters contain everything you need to solve the assignments.
Some programming experience in C-style languages (JS, TS, Java, etc.) is required. In this tutorial we use TypesScript, we try to explain the syntax and keep it simple as we go along. But you might have to lookup a TypeScript API if certain code looks unfamiliar.
If you get stuck or can't solve an assignment, we still encourage you to follow along and learn about GraphQL by reviewing the chapter solutions.
We have also created a "GraphQL Workshop" Teams channel where you can ask questions about the workshop or anything GraphQL related.
Let's start with the tutorial!
You should already have the following:
- Installed NodeJS 10 or 12
- Installed Yarn
- Access to BitBucket
A step-by-step or standalone guide to build a GraphQL API and web application. It's possible to start at any chapter. Each chapter contains assignments that are free to implement however you'd like. As a more guided track you can follow the solutions where we build a favorite list app.
You can also start with the projects and use the fundamentals guide as a reference. Chapter 4 is a project to build a Covid tracking application, and in the final project we build a SpaceX application.
-
My first query
[Frontend, Backend]
Writing our first query using GraphQL -
Calling GraphQL from React
[Frontend]
Consuming our GraphQL API from React -
Server Side Rendering
[Frontend]
Configuring Server Side Rendering -
Project - Covid App
[Frontend, Backend]
Real world example of connecting to a service to build a covid app -
Paging
[Frontend, Backend]
Implement paging -
Lazy Queries
[Frontend]
Conditionally call GraphQL -
Mutations
[Frontend, Backend]
Modifying and updating data -
Fragments
[Frontend]
Re-usable components using Fragments -
Union Types
[Frontend, Backend]
How to use union types -
Dataloader
[Backend]
Make your API efficient -
Advanced GraphQL
[Frontend, Backend]
Caching, Input types, interfaces, scalars, optimistic responses
There are 3 parts to testing GraphQL. In these chapters we take a close look at all the strategies.
-
Unit Testing Client Side
[Frontend, Test]
How to unit test GraphQL powered components -
Unit Testing Server Side
[Backend, Test]
How to unit test GraphQL API's -
Integration Testing
[Test]
How to run integration tests on GraphQL API's
-
SpaceX App
[Frontend, Backend]
In this project we build an app using the SpaceX API.