基于Jest Mock API对业务逻辑集成测试附源码

你bf有时候我们需要不发送请求就能完成前端的业务逻辑测试,而许多的业务逻辑都会需要调用到后端的API接口。那如何能mock我们所需要的data就是一个问题。当我们能有一个良好的测试环境之后,只要保证后端的接口没有问题,那我们就可以保证业务逻辑也没有问题。

所以我们对API的集成测试有以下几个要求

1.不发送请求,返回本地假数据

2.发布前通过CI跑unit test,通过则发布上线

如何实现?

首先一般我们在network部分都会进行封装,假设在project中封装了如下的请求工具

既然我们不能发送真实请求,那我们就需要类似能拦截的东西,拦截也可以通过mock代替。于是我们可以通过方法来做。

jest.mock

这个就是的作用。

内容开始

明白了这个后就好办了。项目目录如下:

而我们的fake文件其实主要做的事情就是根据请求url,method,status等,去读取对应的本地假数据。大致如下。

mockData文件夹则就是放我们的假数据,在这我们可以假设定义如下数据结构,来模拟我们的response。

最后看下我们的 unit test 如何写

实现了这个有什么用?

假设接口返回得数据可能是这样

而我们前端service层为UI层提供了一个initUserData的方法,initUserData方法里的操作是当为18,那就要返回19。

所以我们在Jest则可以直接这样测试。

这样我们使用Jest就可以完成对业务逻辑的测试,Unit test在大型项目中非常需要,每当提交一个feature时,可以跑完所有测试,会让你非常有安全感,极大提升了项目的稳定性。

TIP

真正的方法(http),与mock的方法http,文件必须同名,然后放在mocks文件夹下即可。如果不同名使用jest.mock()则会失败。

以上例子源码请自行下载学习:

链接: https://pan.baidu.com/s/1QyI8ayo3EHD3xfwTUkRDlg 密码: 1jq4

关注我们

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180315B0A1GM00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券