@apollo/react-testing
This tutorial outlines some of the @apollo/react-testing API reference.
Installation
npm install @apollo/react-testing
MockedProvider
import { MockedProvider } from "@apollo/react-testing";
The MockedProvider is a test-utility that allows you to create a mocked version of the ApolloProvider that doesn't send out network requests to your API, but rather allows you to specify the exact response payload for a given request.
The <MockedProvider /> component takes the following props:
PROP | TYPE | DESCRIPTION |
---|---|---|
mocks? | ReadonlyArray | An array containing a request object and the corresponding response. |
addTypename? | boolean | A boolean indicating whether or not __typename are injected into the documents sent to graphql. This defaults to true. |
defaultOptions? | DefaultOptions | An object containing options to pass directly to the ApolloClient instance. |
cache? | ApolloCache | A custom cache object to be used in your test. Defaults to InMemoryCache. Useful when you need to define a custom dataIdFromObject function for automatic cache updates. |
resolvers? | Resolvers | Apollo Client local resolvers |
childProps? | object | Props that should be passed down to the child. |
Here is an example mocks prop shape:
const mocks = [
{
request: {
query: SOME_QUERY,
variables: { first: 4 }
},
result: {
data: {
dog: {
name: "Douglas"
}
}
}
},
{
request: {
query: SOME_QUERY,
variables: { first: 8}
},
error: new Error("Something went wrong")
}
]
The above shows that if the request SOME_QUERY is fired with variables {first:4} that it results in the data in the result object.
If SOME_QUERY is fired with variables {first: 8} then it results in an error.
Example
it("runs the mocked query", () => {
render(
<MockedProvider mocks={mocks}>
<MyQueryComponent />
</MockedProvider>
)
// Run assertions on <MyQueryComponent/>
});
Previous:
@apollo/react-hoc
Next:
Hooks migration guide
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics