search

Home  >  Q&A  >  body text

How to use mock Service Worker to test vue apollo?

I have set up a mock service worker to test my composition functionality but am getting the error: Default Apollo client with id not found. If you are outside the component setup., use ProvideApolloClient().

I thought I should use provideApolloClient, but pasting it into search brings up nothing.

The documentation shows injecting data in component and simulation mode (that part is not fetched). But instead of testing the component, I'm trying to test a custom composed function (hook) and make sure it interacts correctly with useQuery.

P粉696891871P粉696891871293 days ago440

reply all(1)I'll reply

  • P粉821274260

    P粉8212742602024-03-28 09:02:30

    I think the error message you are getting indicates that Apollo cannot render completely because it cannot find any Apollo clients from the context. This can happen if you call code without an ApolloProvider and with a client as its parent. Even if you are testing the hook, you still have to render the hook wrapped in Apollo's Provider and provide a client instance according to Apollo's documentation. See how your React hook testing library suggests doing this.

    Here is an example of what I recommend using @testing-library/react-hooks:

    import { ApolloProvider } from '@apollo/client'
    import { renderHook } from '@testing-library/react-hooks'
    import { client } from './apollo-client'
    import { myHook } from './myHook'
    
    it('runs the hook as expected', () => {
      renderHook(() => myHook(), {
        wrapper({ children }) {
          return {children}
        }
      })
      // actions and assertions here
    })
    

    I know this won't translate directly to Vue, but I'm sure there is an alternative way to test hooks in Vue. Hope this inspires you in the right direction.

    reply
    0
  • Cancelreply