Skip to content

Latest commit

 

History

History
182 lines (128 loc) · 6.42 KB

README.md

File metadata and controls

182 lines (128 loc) · 6.42 KB

Gatsby, Sanity.io and Netlify Build Plugins POC

https://demo-site-for-build-plugins.netlify.app/ or run locally with npm run dev on localhost:8000

Building a simple Gatsby app against a Sanity.io GraphQL API, with watch mode for real-time updates in dev, webhooks to trigger builds on content change, Gatsby incremental builds & Netlify build plugins for Cypress & A11y.

home


about
show page
show page

Additional Features


Setup - Gatsby and Sanity.io

  • set up parent repo

  • ensure you've got up-to-date Gatsby CLI npm install -g gatsby-cli

  • use latest version of Gatsby: yarn add gatsby@latest & create new Gatsby project gatsby new frontend. Cd into it & run gatsby develop to test it's working ok.

  • launches Gatsby app on http://localhost:8000 & GraphQL playground on http://localhost:8000/___graphql

  • add Sanity.io support: yarn add gatsby-source-sanity

  • global install of Sanity CLI & login: npm i -g @sanity/cli && sanity login

  • initialise new Sanity project: sanity init => gives you config options on the command line, including choice of dummy data

  • to delete the imported data, use sanity dataset delete production

  • create a new clean dataset with sanity dataset create <name>

  • deploy Sanity GraphQL API: sanity graphql deploy (https://www.sanity.io/docs/graphql)

  • this will be available on https://<YOUR_ID>.api.sanity.io/v1/graphql/<YOUR_DATASET>

  • this also makes a GraphQL playground available this endpoint

    sanity playground

  • adjust your gatsby config file to reference the correct id and dataset (e.g. production)

  • watchMode will update Gatsby automatically in development

    {
      resolve: "gatsby-source-sanity",
      options: {
        projectId: process.env.SANITY_PROJECT_ID,
        dataset: process.env.SANITY_DATASET,
        watchMode: true,
      },
    },
  • use dotenv with .env.development & .env.production to avoid referencing directly in repo

  • sanity start launches Sanity locally on http://localhost:3333

  • changes here are saved in the cloud on publish (Sanity's Content API)

    sanity dashboard


Troubleshooting

  • 'React hooks' error results if versions are not in sync. Best to delete node_modules and use yarn

Cypress

{
  "baseUrl": "http://localhost:8000/"
}
  • test scripts:
  "cy:run": "cypress run",
  "cy:open": "cypress open",
  "test:e2e": "start-server-and-test develop http://localhost:8000 cy:open"
  • npm run test:e2e launches Cypress w Chrome

Netlify Build with Plugins

  • add netlify.toml file at root level and point it to the gatsby build output:
[build]
base = "frontend/"
command = "npm run build"
publish = "public"
[[plugins]]
package = "netlify-plugin-gatsby-cache"

  • note the including of the cache:

    Incremental builds rely on Gatsby’s cache, so we need to enable netlify-plugin-gatsby-cache, which will persist Gatsby’s public and .cache directories between builds. (https://www.netlify.com/blog/2020/04/23/enable-gatsby-incremental-builds-on-netlify/)

  • deploy Gatsby site to Netlify using GitHub (master branch default) - remembering to change the publish directory to the frontend/public one rather than the default public

  • adjust build script: "build": "GATSBY_EXPERIMENTAL_PAGE_BUILD_ON_DATA_CHANGES=true gatsby build --log-pages"

  • Now any changes to your source data (here in Sanity) will trigger a build where Gatsby will only rebuild affected pages! => Gatsby Incremental Builds!

Plugins

How does it work? When Netlify Build runs, it "knows" the output folder name and calls the netlify-plugin-cypress after the build has finished with that folder. Then the plugin runs Cypress tests using its NPM module API. If the tests pass, the plugin finishes and the Netlify deploy starts.

cypress plugin

[[plugins]]
package = "netlify-plugin-a11y"

  # all inputs are optional, we just show you the defaults below
  [plugins.inputs]

  # required config
  checkPaths = ['/'] # you can give an array of directories or paths to html files, that you want to run a11y checks on

  ## Another checkPaths Example
  checkPaths = [
    '/blog',
    '/about.html',
    '/super/specific/route/index.html',
  ]

  # # optional config
  # ignoreDirectories = ['/admin']  # explicitly ignore these directories

  # resultMode = "warn" # is "error" by default

  # # Developer only
  # debugMode = true # extra logging for plugin developers

netlify build

Troubleshooting

  • Test the Netlify build process locally:

  • Ensure that you have the netlify build command available (in future this will be provided via the CLI) npm install @netlify/build -g

  • In the project working directory, run the build as netlify would with the build bot netlify-build

Webhooks

  • For production, for Gatsby to pick up changes in the Sanity dataset, add a webhook to trigger a new build
  • In Netlify, add a webhook in the Build & Deploy section & copy the url
  • On the command line, run sanity hook create pointing to this unique url
  • Now any published changes on localhost:3333 will trigger a build!

netlify webhooks sanity webhooks netlify build