一次偶然的机会来到这里,有种恍然大悟的感觉:原来大家都在这里!我说在 CSDN 上很少看到测试相关的文章呢。翻看了几篇,各位谈笑间,水平尽显——进这里就像回到家一样,进了里面去个个都是人才,说话又好听,超喜欢在里面。
我本人是 19 年 6 月份开始在 CSDN 写些博文的,这里也顺势推荐一波,欢迎大家关注、交流。博客地址奉上:https://blog.csdn.net/mu_wind。
发现测试里走 Java 路线的真是少之又少,希望多遇到几个同道中人吧。
言归正传,今天来跟大家分享一个自己的作品 -- 基于Springboot+layui
实现接口自动化平台,如果感兴趣的人多,会考虑开源。回顾这段岁月,甘苦自知。既有遇到难点一筹莫展、食之无味的困窘,也有解决难题调试成功的欣喜,堪称五味杂陈。人言奋斗的岁月最充实,果然如此。
闲言几句:读了几篇文章,颇有几番质疑技术的言论,在我看来,技术是一把刀,越锋利越好,如果这把刀发挥不了功效,那是拿刀的人出了问题,而非刀本身。当然,技术一定要结合业务,否则就成了无柄之刃,再锋利也是徒劳。
好,正式开始。平台采用的技术栈有:
平台数据采用分层设计,即将接口自动化所需的数据分为【项目管理】、【接口列表】、【用例管理】、【测试集合】、【测试结果】五个部分。如下图所示:
平台入口,颜值即正义,尽量弄得漂亮一点,也让人有使用的欲望。
项目管理,定义了公司系统的基本框架。以新浪新闻为例,我将做如下分割:
项目模块层,有以下规范和特点:
当项目模块创建后,就可以在该模块下添加接口了。
接口层有以下规范和特点:
用例管理是对接口的进一步描述,是最核心的部分,也是开发难度最大的一个模块。用例可以直接调用调试:
用例层具有以下规范和特点:
用例详情页有以下几大部分:
1、基本信息:用例的描述性信息,自动读取。其中,所属平台、所属项目、所属模块等信息,读取自用例所属的模块,接口名称、接口路径等读取自用例所属的接口。
2、请求参数,包括请求头和请求体两部分。
3、关联提取:这个功能是为后续【测试集合】准备的,当你准备把一个用例加入测试集合,且测试集合后续的接口的参数依赖该用例响应结果的值,就需要在关联处理做预处理。
比如一个登录用例,需要在响应结果中提取 token 并提供给后续接口使用,就可以按图中示例,添加一条关联提取规则:
4、结果断言:目前包括常规断言和 Beanshell 断言两种形式,其中常规断言包括:包含、相等、JSON 三种方式(已经能覆盖大多数应用场景,后续可以继续丰富)
5、结果示例是接口返回结果的示例:
测试集合可以说是这个接口自动化平台的意义之所在。在接口自动化中,单接口调用参考价值有限,多个接口按照业务逻辑组成一条流程,才是接口自动化意义所在。
当一系列接口用例创建完成后,在【测试集合】页面可以按照业务逻辑将它们组装起来,形成一个任务队列。
下面说明一下如何编辑一条测试集合:
在【测试集合】页面选择执行某条测试集合后,程序将读取其对应的用例队列,并依次执行每个用例,最终生成一条测试集合的测试结果,并持久化保存在数据库中。
点击【详情】按钮,进入测试结果详情页,查看某条测试结果的详情:
双击某行,弹出该行对应的响应结果:
接口测试平台功能大体上就以上,还有很多需要优化的地方,比如