2

我在使用nock测试我的 Redux 动作创建者时遇到了问题。当我离线时,我不断收到失败的承诺,这意味着使用 Axios 的 HTTP 请求不成功。但是,当我上网时,它可以工作。

那么 nock 只有在有 Internet 连接的情况下才有效吗?

Action Creator(使用 axios 0.15.3)

export const fetchSomething = (id) => {
  return dispatch => {
    dispatch({
      type: FETCH_SOMETHING_LOADING
    });

    return axios.get(`${SOMEWHERE}/something?id=${id}`)
      .then(response => {
        return dispatch({
          type: FETCH_SOMETHING_SUCCESS,
          payload: response.data
        });
      })
      .catch(error => {
        return dispatch({
          type: FETCH_SOMETHING_FAILURE
        });
      });
  };
};

动作创建者的笑话测试(nock v9.0.2)

test('should dispatch success action type if data is fetched successfully', () => {
  // Need this in order for axios to work with nock
  axios.defaults.adapter = require('axios/lib/adapters/http');

  nock(SOMEWHERE)
    .get('/something?id=123')
    .reply(200, someFakeObject);

  thunk = fetchSomething(123);

  return thunk(dispatch)
    .then(() => {
      expect(dispatch.mock.calls[1][0].type).toBe('FETCH_SOMETHING_SUCCESS');
    });
});
4

2 回答 2

1

据我所知,nocknpm 模块只能在 Node 中使用,而不能在浏览器中使用。您是在测试套件中使用 nock,还是在开发时作为 API 的填充物?如果是后者,我认为 nock 中间件是行不通的。当您连接到 Internet 时,您可能会看到来自真实 API 而不是模拟 API 的响应,并且 nock 没有拦截任何内容。

如果您想尝试在节点和浏览器中都可以使用的类似适配器,请查看axios-mock-adapter

于 2017-02-17T00:32:16.700 回答
0

使用 nock 测试 axios 发出的请求似乎存在一些问题。nock 的存储库中存在一个讨论该问题的问题。

我发现@supnate对那个问题的评论解决了我的问题。此外,我在我的代码中调用了nock.cleanAll();一个内部beforeEach()构造,该构造是问题的主要原因

解决方案是删除它。不要使用nock.cleanAll()!所以现在一切都可以很好地测试 axios 发出的请求:

import axios from 'axios';
import httpAdapter from 'axios/lib/adapters/http';

axios.defaults.host = SOMEWHERE; // e.g. http://www.somewhere.com
axios.defaults.adapter = httpAdapter;

describe('Your Test', () => {
  test('should do something', () => {
    nock(SOMEWHERE)
      .get('/some/thing/3')
      .reply(200, { some: 'thing', bla: 123 });  

    // then test your stuff here
  );
});
于 2017-03-21T17:13:47.047 回答