0

我在这里学习 TDD React并且不了解以下测试情况:

it('Correctly updates the state after AJAX call in `componentDidMount` was made', (done) => {
  nock('https://api.github.com')
    .get('/users')
    .reply(200, [
      { 'name': 'Reign', 'age': 26 }
    ]);
  // Overwrite, so we can correctly reason about the count number
  // Don't want shared state
  wrapper = mount(<UsersListComponent />);
  setTimeout(function() {
    expect(wrapper.state().usersList).to.be.instanceof(Array);
    expect(wrapper.state().usersList.length).to.equal(1);
    expect(wrapper.state().usersList[0].name).to.equal('Reign');
    expect(wrapper.state().usersList[0].age).to.equal(26);
    nock.cleanAll();
    done();
  }, 1500);
});

nock使用伪造请求的目的是什么?这个请求没有做任何事情,我不确定响应的去向。我认为TDD方法是编写测试(从包装器开始的代码),看到它失败,然后在实际组件中使用真正的ajax调用进行测试。我不明白 nock 在这里做什么。

4

2 回答 2

3

nock代码中调用的目的是伪造 API 请求。Nock 捕获/拦截呼叫,而不是实际响应,它返回带有虚假信息的响应。

测试的标题是Correctly updates the state after AJAX call...这样的,目的是测试状态是否正确更新,而不是实际 API 请求是否已成功执行。

这允许您对不同的场景进行建模和测试,例如,您的应用程序在接收不同数据集时的行为方式。它还允许您在实际 API 可能尚未准备好时完成测试。

于 2016-10-05T08:15:29.463 回答
1

单元测试的目的是只测试你的代码是最孤立的方式。伪造 AJAX 请求并获取其响应是一种非常常见的做法,可以避免端点出现问题(因为这不是您要测试的)并专注于处理该端点响应的代码,您可以选择不同的响应模型来测试不同的场景。

当您调用“ https://api.github.com/users ”时,Nock 只会将响应反馈给您的组件

于 2016-10-05T08:16:00.633 回答