[英]follow jest docs to mock axios but not working
我將笑話文檔傳送到模擬模塊“ axios”
像這樣
// httpCall.js
import axios from 'axios'
export default function httpCall () {
return axios.get('url/to/the/end/point').then(res => res.data)
}
和我的測試文件
import axios from 'axios'
import httpCall from './index'
jest.mock('axios')
test('mock module axios', () => {
const resp = { data: { id: 1, name: 'John Doe' } }
axios.mockResolvedValue(resp)
return httpCall().then(res => expect(res).toEqual(resp.data))
})
然后得到這個錯誤
TypeError: _axios.default.mockResolvedValue is not a function
所以我嘗試用Google搜索它,然后嘗試模擬內部axios.create()
創建嘲弄 /axios-mock.js
const mockAxios = jest.genMockFromModule('axios')
mockAxios.create = jest.fn(() => mockAxios)
export default mockAxios
然后將我的測試文件更新為此
import mockAxios from './__mocks__/axios-mock'
import httpCall from './index'
test('mock module axios', () => {
const resp = { data: { id: 1, name: 'John Doe' } }
mockAxios.get.mockResolvedValue(resp)
return httpCall().then(res => expect(res).toEqual(resp.data))
})
但仍然出現如下錯誤
Request failed with status code 404
我對此一無所知...但是最終我使它起作用了。
這是我的模擬文件
// __mocks__/axios-mock.js
import axios from 'axios'
const mockAxios = jest.genMockFromModule('axios')
export default axios
// or even like this
import axios from 'axios'
jest.mock('axios')
export default axios
這是我的測試文件
import httpCall from './index'
import mockAxios from './__mocks__/axios-mock'
describe('mock module', () => {
it('axios should be mocked', () => {
const resp = { data: { id: 1, name: 'John Doe' } }
mockAxios.get = jest.fn().mockResolvedValue(resp)
return httpCall().then(res => expect(res).toEqual(resp.data))
})
})
之后,我嘗試將axios-mock代碼移動到以下測試文件中
import axios from 'axios'
import httpCall from './index'
const mockAxios = jest.genMockFromModule('axios')
describe('mock module', () => {
it('axios should be mocked', () => {
const resp = { data: { id: 1, name: 'John Doe' } }
mockAxios.get = jest.fn().mockResolvedValue(resp)
return httpCall().then(res => expect(res).toEqual(resp.data))
})
})
我又收到這個錯誤
Request failed with status code 404
這是我的envinfo
System:
OS: macOS 10.14
CPU: (4) x64 Intel(R) Core(TM) i5-7360U CPU @ 2.30GHz
Binaries:
Node: 10.13.0 - ~/.nvm/versions/node/v10.13.0/bin/node
Yarn: 1.7.0 - /usr/local/bin/yarn
npm: 6.4.1 - ~/.nvm/versions/node/v10.13.0/bin/npm
npmPackages:
jest: ^23.6.0 => 23.6.0
我的.babelrc
{
"presets": [
[
"@babel/env",
{
"modules": "umd"
}
]
]
}
我的jest.config.js
module.exports = {
}
我希望有人能解釋為什么會這樣
開玩笑的模擬模塊文檔真的有效嗎?
現在可以正常工作了,問題是我的.babelrc文件
應該這樣
{
"presets": [
[
"@babel/env"
]
]
}
要么
{
"presets": [
[
"@babel/env",
{
"modules": "umd"
}
]
],
"env": {
"test": {
"presets": [
[
"@babel/env"
]
]
}
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.