axios-mock-adapter错误错误:飞行前响应具有无效的HTTP状态代码403

问题描述 投票:0回答:1

我正在尝试通过模拟axios api调用来编写单元测试。这是axios-mock-adapter配置

import MockAdapter from 'axios-mock-adapter';
import axios from 'axios';

const mock = new MockAdapter(axios);

it('Get User details without errors', async () => {
  const mockData =
    '{"userID": 1234, ...}}';

  const url = '/user/id/560/';
//const url = 'https://example.com/searchuser/user/id/560/'; Also tried with this
  mock.onGet(url).reply(200, mockData);

当我触发操作时会调用此API

GET:“ https://example.com/searchuser/user/id/560/

这里是完整的错误日志

 console.error node_modules/jest-environment-jsdom/node_modules/jsdom/lib/jsdom/virtual-console.js:29
    Error: Error: Response for preflight has invalid HTTP status code 403
        at Object.dispatchError (C:\Users\lokeshp\branches\nrrui\node_modules\jest-environment-jsdom\node_modules\jsdom\lib\jsdom\living\xhr-utils.js:65:19)
        at EventEmitter.client.on.err (C:\Users\lokeshp\branches\nrrui\node_modules\jest-environment-jsdom\node_modules\jsdom\lib\jsdom\living\xmlhttprequest.js:676:20)
        at EventEmitter.emit (events.js:187:15)
        at Request.preflightClient.on.resp (C:\Users\lokeshp\branches\nrrui\node_modules\jest-environment-jsdom\node_modules\jsdom\lib\jsdom\living\xhr-utils.js:376:16)
        at Request.emit (events.js:182:13)
        at Request.onRequestResponse (C:\Users\lokeshp\branches\nrrui\node_modules\request\request.js:1066:10)
        at ClientRequest.emit (events.js:182:13)
        at HTTPParser.parserOnIncomingClient [as onIncoming] (_http_client.js:556:21)
        at HTTPParser.parserOnHeadersComplete (_http_common.js:109:17)
        at TLSSocket.socketOnData (_http_client.js:442:20) undefined

有人可以帮我理解我如何模拟飞行前呼叫吗?我需要将jsdom与jest一起使用,因为其他单元测试需要模仿浏览器的行为。搜索了很多,但似乎找不到解决方法。

unit-testing react-testing-library preflight axios-mock-adapter
1个回答
0
投票

我在模仿axios时犯了一个错误。我已经创建了用于进行api调用的axio实例,并尝试在上述问题中模拟axios默认实例。因此没有应用模拟。以下解决问题。

import AxiosAPIInstance from '/api/instance';
const mock = new MockAdapter(AxiosAPIInstance );
.....
© www.soinside.com 2019 - 2024. All rights reserved.