怎么做接口测试/概念及常用方法小结,接口测试怎么做数据回滚

4747 311 2022-07-12


   1.接口的概念从IT的角度出发,主要是子模块或者子系统间交互并相互作用的部分。从形式上来看各种应用程序的API(最著名的 Windows 系统的API),硬件的驱动程序,数据库系统的访问接口,再到后来的Webservice接口,http rest接口。虽然接口的形式各有不同,但是从 测试角度来说,需要测试的内容大致是相同的,功能,性能,安全。
  我们常说的api就是接口的意思,现在常用的 web项目,app项目的接口都是基于http请求的,有些系统内部之间调用的接口一般不需要我们测试,这些很多是基于jar包那种类型的接口,只了解到这就差不多了。
  接口类型常见的有get,post,put...类型。get类型的接口一般是指获取信息的接口,比如列表查询的功能,点击查询按钮就调用一个get接口,然后把信息返回出来。就是指把内容从服务器拉下来。
  post类型一般是提交表单的功能,比如注册、上传、发布帖子之类的就是post接口。就是指把内容推到服务器上去。
   接口测试的策略:接口测试属于 功能测试,也可以看做是需要了解部分代码的灰盒测试。测试流程是:1测试接口文档。2.根据接口文档编写 测试用例(用例编写方法完全可以按照 黑盒测试的用例编写规则来编写,如:边界值、正交表等等设计方法)。3.执行测试,查看接口返回的接口数据是否正确,主要检查返回的接口是否和接口文档中定义的一样,还有要检查返回的数据是否和 数据库中的保持一致。
   eg1.https://api.douban.com/v2/book/search?q='', 这是一个豆瓣的查询书籍信息的开放的api,是一个get型接口。q='',单引号里就是查询的参数,这里给参数为《百年孤独》,然后在 浏览器中访问下面地址:https://api.douban.com/v2/book/search?q='百年孤独', 返回的就是接口信息。返回信息如下:

  内容很多,是一个json字符串。可以把所有东西复制下来,用在线解析的站点:json.cn这个网站中解析出来就很好看了。如图:

image.png

  右边就是解析出来的格式,就是一个json字符串中嵌套了一个名叫books的数组。我们测试的时候就是根据接口文档,查看返回的这些数据是否是我们预期,判断这些数据是否是预期一般还需要了解项目的数据库,然后根据条件查询数据库,看接口返回的数据和数据库中查出来的是否一致。
   eg2.get型的接口可以直接通过浏览器访问,参数就带在地址的后面以‘?’连接。但是post的就不行了,要用专门的工具来测试,常用的推荐jmeter和soapUI。

image.png

  首先查看接口文档:
  根据接口文档可知,该接口实现一个更新用户昵称的功能,由此可以开始设计测试用例。userId和ickName均不为空,测试输入类型,测试更新成功后再数据库中是否同步更新。jemter中操作如下图:

image.png

  第一张图片的设置content-type为application/json是因为接口文档中要求如此。如果没要求,可以不用添加HTTP信息头管理器。因为要求的是json格式的传参,所以post的参数要在(图二)body Data中以json格式书写。
  eg3复杂格式的post接口:实际项目中,经常会遇到上传文件,发布图片等接口,测这种接口时上传的参数往往是一个文件或者图片,所以在jmeter中传参就要用另一种方式。
  由图三的接口文档查看需要请求的参数,在定义接口文档时开发人员会给出该接口的请求格式是什么,即content-type。此处为content-type:multipart/form-data。 这种格式的不用在HTTP信息头中单独定义content-type。直接把参数放在Parameters中,要上传的参数放在下面“通请求一起发送文件”里面浏览上传符合格式要求的文件。

   eg3.还有一些需要特殊处理得接口,比如一个增加积分的接口,由于业务需要,每次请求都要生成不同的签名作为请求参数。这种接口可以用beanshell来处理生成签名的逻辑,将生成的签名定义成一个变量,然后在http请求中调用这个变量,如下图,具体实现在《参数不断变化的接口做性能测试》一文会提到。

解决思路如下:

1.创建事务

2.先更新本地状态(失败则回滚)

3.再调用第三方接口

4.根据接口返回值决定事务提交还是回滚

这样首先保证了本地数据能够更新,再根据接口返回值判断是否更新。

这种方法只是针对单一操作,如果是大量的批量操作,建议使用队列进行异步处理。

问题一:

在事务中去请求第三方接口,容易导致事务时间过长,对方接口超时多久,你的数据库事务也会卡多久

问题二
如果我们是接口提供方还是接口调用方,都需要考虑程序异常,网络超时问题、服务器重启、并发等问题。
为了保证提供方数据一致性,我们需要接口提供方具有的特性:

  • 回调

  • 幂等性

  • 回滚数据

  • 提供结果查询

为了保证自身数据一致性,我们需要接口调用方的特性有:

  • 幂等性

  • 重新执行(有一个事务补偿机制,可以选择把失败的事务操作放到队列中,异步执行,重新执行失败的操作,如果一直都不成功那就说明,服务器有问题或者那段业务逻辑中的某个环节出现了问题)

  • 或者要有记录数据变化的日志,如果出现异常,通过日志中的记录,把数据还原


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:什么是接口测试,什么是接口测试参数化
下一篇:公关界007:滴滴豪华车年末走心营销,教你如何款待重要的人!
相关文章

 发表评论

暂时没有评论,来抢沙发吧~