如何重新安装库是一个测试?

问题描述 投票:0回答:1
jest.mock('../redux/storeConfigure', () => () => ({
  getState: () => ({ auth: { token: 'TEST_TOKEN' } })
}))

import { prepareRequestHeaders } from './fetch'

describe('prepareRequestHeaders', () => {
  it('returns header with Authorization if token is set', () => {
    expect(prepareRequestHeaders()['Authorization']).toBe('Bearer TEST_TOKEN')
  })

  it('returns header without Authorization if token is not set', () => {
    ?????
  })
})

prepareRequestHeaders我导入../redux/storeConfigure

如何用其他实现重新启动../redux/storeConfigure

编辑:

/* fetch.js */
import { store } from '../app'

export const prepareRequestHeaders = () => {
  const headers = {
    Accept: 'application/json',
    'Content-Type': 'application/json'
  }

  const { token } = store.getState().auth
  if (token) {
    headers['Authorization'] = `Bearer ${token}`
  }

  return headers
}

/* app.js */

import storeConfigure from './redux/storeConfigure'

export const store = storeConfigure()

/* Directories strucutre */
- redux
  - storeConfigure.js
- api
  - fetch.js
  - api.test.js
app.js
javascript mocking jestjs
1个回答
1
投票

这样的事情应该成功:

let mockGetState;

jest.mock('../redux/storeConfigure', () => () => {
  mockGetState = jest.fn().mockReturnValue({ auth: { token: 'TEST_TOKEN' } })
  return { getState: mockGetState }
})

import { prepareRequestHeaders } from './fetch'

describe('prepareRequestHeaders', () => {
  it('returns header with Authorization if token is set', () => {
    expect(prepareRequestHeaders()['Authorization']).toBe('Bearer TEST_TOKEN')
  })

  it('returns header without Authorization if token is not set', () => {
    mockGetState.mockReturnValueOnce({auth: {token: 'SOMETHING_ELSE'}})
    // make your assertion
  })
})

当您分配给Jest模拟(jest.fn())时,您可以随时更改其返回值。它的名字必须从mock开始,因为模拟吊装

© www.soinside.com 2019 - 2024. All rights reserved.