test-utils icon indicating copy to clipboard operation
test-utils copied to clipboard

Expose mocks directly with `mockNuxtImport`

Open rinux55 opened this issue 2 years ago • 1 comments

Currently, it's possible to mock a Nuxt import:

mockNuxtImport('useStorage', () => {
    return vi.fn()
})

When we want to access this mock in our test, to run an assertion or to change the implementation, we can use vi.hoisted:

const { useStorageMock } = vi.hoisted(() => {
  return {
    useStorageMock: vi.fn()
  }
})

mockNuxtImport('useStorage', () => {
  return useStorageMock
})

// now we can change the implementation of useStorageMock between tests

This is a lot of code just to define and expose a single mock. Would it be possible to make mocking Nuxt imports easier by returning the mocks directly in mockNuxtImport?

I propose something like this:

const useStorageMock = mockNuxtImport('useStorage', () => {
    return vi.fn()
})

// now we can change the implementation of useStorageMock between tests

I'm down to have a look at this if this is possible.

rinux55 avatar Aug 18 '23 12:08 rinux55

It seems this should be possible to implement in the same plugin that processes/handles mockNuxtImport.

danielroe avatar Aug 18 '23 13:08 danielroe