docs: update Testing Components with GraphQL #31221
Replies: 6 comments
-
I burnt a bit of time on this as well - after finding this issue and reading the linked page, I sorted out that I could add the This is what my
Thoughts on this approach? |
Beta Was this translation helpful? Give feedback.
-
Hiya! This issue has gone quiet. Spooky quiet. 👻 We get a lot of issues, so we currently close issues after 30 days of inactivity. It’s been at least 20 days since the last update here. Thanks for being a part of the Gatsby community! 💪💜 |
Beta Was this translation helpful? Give feedback.
-
@robinmetral I'm not so sure about that Mocking example you linked. The author is setting up spies and doesn't provide a complete example. Searching GH I already see 109 instances of that pattern and many seem to be doing it differently. On top of that I don't see the author explaining spies/mocks may need to be reset in a teardown of some sort such as I feel at a minimum the takeaway here is that Gatsby's using-jest example should be updated to show a specific example of testing with EDIT Article updated spies example with feedback. |
Beta Was this translation helpful? Give feedback.
-
I just ran into that issue too. This is really confusing, especially as a beginner to Gatsby. Thankfully this issue exists and pointed me in the right direction. I was able to adjust the test from In case anybody else is running into this issue while learning, I was able to redefine the test like so: /* eslint-env jest */
import React from 'react'
import renderer from 'react-test-renderer'
import { useStaticQuery } from 'gatsby'
import Index from '../index'
beforeEach(() => {
useStaticQuery
.mockImplementationOnce(() => { // Mock for use in Layout
return {
site: {
siteMetadata: {
title: 'Gatsby Default Starter'
}
}
}
})
.mockImplementationOnce(() => { // Mock for use in SEO
return {
site: {
siteMetadata: {
title: 'Gatsby Default Starter',
description: 'Kick off your next, great Gatsby project with this default starter. This barebones starter ships with the main Gatsby configuration files you might need.',
author: '@gatsbyjs'
}
}
}
})
.mockImplementationOnce(() => { // Mock for use in Image
return {
placeholderImage: {
childImageSharp: {
fluid: {
base64: '',
aspectRatio: 1,
src: '/static/6d91c86c0fde632ba4cd01062fd9ccfa/630fb/gatsby-astronaut.png',
srcSet: '/static/6d91c86c0fde632ba4cd01062fd9ccfa/5db04/gatsby-astronaut.png 75w,\n/static/6d91c86c0fde632ba4cd01062fd9ccfa/6d161/gatsby-astronaut.png 150w,\n/static/6d91c86c0fde632ba4cd01062fd9ccfa/630fb/gatsby-astronaut.png 300w,\n/static/6d91c86c0fde632ba4cd01062fd9ccfa/62b1f/gatsby-astronaut.png 450w,\n/static/6d91c86c0fde632ba4cd01062fd9ccfa/2a4de/gatsby-astronaut.png 600w,\n/static/6d91c86c0fde632ba4cd01062fd9ccfa/ee604/gatsby-astronaut.png 800w',
sizes: '(max-width: 300px) 100vw, 300px'
}
}
}
}
})
})
describe('Index', () => {
it('renders correctly', () => {
const tree = renderer.create(<Index />).toJSON()
expect(tree).toMatchSnapshot()
})
}) To get the returned mock data, I went to
This is already suggested on the docs page in question. The fact that I am mocking the same function three times is probably not the most elegant, but it solved my issue without getting into many other issues. The issue is that the function that needs to mocking is used in many place when testing a whole page. I guess a more elegant solution would be to mock the different components that are using the |
Beta Was this translation helpful? Give feedback.
-
I just came across this issue also in evaluating Gatsby as a frontend framework for the agency I work for. It was frustrating to say the least for it be painful getting TDD setup. I would be open to doing some work to implement the fixes you suggest @robinmetral? |
Beta Was this translation helpful? Give feedback.
-
Hey @mathewtrivett, I personally think this would be amazing, but maybe it would make sense to ask for opinions from the Gatsby learning team? I can't assign or tag them anymore, but as far as I can see they haven't been part of this discussion yet. Another way might be to draft a PR for this already, it would make the discussion on specific points easier 🙂 I think we all agree that we need better docs for this |
Beta Was this translation helpful? Give feedback.
-
The Testing Components with GraphQL guide is outdated since the Gatsby Default Starter switched to
useStaticQuery
.Summary
When a learner wants to get started with testing Gatsby, the first step is to go through the Unit Testing guide. The guide is essentially a walk-through of the required setup and config to get started with Jest (custom config, mocks, etc.).
The next step is to learn about Testing Components with GraphQL. This guides builds on the previous one and adds specs to test Gatsby
StaticQuery
queries.The issue is that the example site being tested is the
gatsby-starter-default
, which doesn't have anyStaticQuery
queries since it switched entirely to the neweruseStaticQuery
.Testing
useStaticQuery
is a little bit different from testingStaticQuery
. An example can be found online at Mock Gatsby's useStaticQuery with Jest.Note: a recent PR (#18202) already added a note about testing ùseStaticQuery somewhere further in the guide
Motivation
Updating the guide would further help people learn how to test Gatsby, and remove the frustration of following a guide and getting unexpected errors.
Steps to resolve this issue
It seems that there are two possible paths to solving this issue:
gatsby-starter-default
. In this case, the sections about testingStaticQuery
wouldn't belong in this guide anymoreexamples/using-tests-for-graphql
) that includes bothStaticQuery
anduseStaticQuery
and rewrite the guide to explain how to test both methodsDraft the doc
Open a pull request
Beta Was this translation helpful? Give feedback.
All reactions