在展开这个话题之前,咱们先来看看绝大多数情况下,测试人员是如何进行接口测试的?
第一步:编写测试案例,然后上传测试案例管理系统;
第二步:准备测试案例数据,执行测试案例;
第三步:提取接口响应报文、上送报文等信息,然后更新测试案例管理系统测试案例的状态;
第四步:提交缺陷;
既然咱们要聊的是如何提高接口测试效率,那么就得分析上面哪些步骤是可以通过工具来辅助完成。换个角度想一下,如果测试人员执行完测试案例后,案例执行结果可以自动同步测试案例管理系统,不通过的测试案例可以自动提交缺陷,是不是节省了测试人员不少工作量。
下面以Testlink+Jmeter+Jira为例展开说明:
谈起开源的测试框架Jmeter,很多人的第一印象是性能测试。其实Jmeter也常常用来做接口测试。依赖于Jmeter提供的CSV Data Set Config配置元件+变量参数化,测试人员可以很容易的完成一个数据驱动的测试案例脚本。但是对于测试案例量大的脚本,Jmeter所提供的断言和监听器并不能很友好地为测试人员展现脚本执行结果。为了解决该问题,笔者在文章《Jmeter排忧解难—生成excel结果文件》提到了一种方法,下面咱们在此基础上聊聊如何把脚本执行结果同步Testlink及如何自动提交Jira缺陷。
同样作为开源工具的Testlink,相信不少童鞋也接触过。Testlink的优点在于免费,同时也提供了十分完整的测试报告,这就是测试管理人员热衷Testlink的主要原因。关于Testlink的使用笔者将在另外一篇文章做详述,咱先回到前面的话题“如何将Jmeter脚本执行结果同步Testlink”。
Testlink对外提供了Testlink java api,通过调用里面的reportTCResult方法即可更新Testlink的测试案例。那接下来我们要做的事就是读取Jmeter脚本执行结果(excel格式文件),然后再调用reportTCResult方法同步Testlink,这下子是不是觉得好简单了。
我们把读取Jmeter脚本执行结果并同步Testlink的java类导出jar包并放到Jmeter的lib/ext目录下,后续就可以在Jmeter的BeanShell Sampler直接写代码调用方法同步Testlink了。至此,同步Testlink的功能咱们算是实现了。
跟Testlink一样,Jira也对外提供了rest api(请自行百度),通过调用接口,咱们也可以很方便地把测试不通过案例自动提交Jira缺陷,并把缺陷编号关联Testlink,后续再依赖Testlink强大的测试报告功能进行缺陷密度分析。
由于可能存在误提缺陷的情况,所以增加了确认功能,确认缺陷后才进行提交。缺陷的信息包含测试要点、预期结果、实际结果、上送报文、响应报文、附件及其他描述信息。
本着让测试人员简单愉快地测试,笔者已将上述理念运用于测试管理中,不但提升了测试效率,一定程度上也简化了测试管理的工作。对于Testlink和Jira外部api的技术或非技术问题,有兴趣的同行可以私信笔者。另外,各位测试同行如果有其他想法,欢迎留言交流。