在我们测试接口提供的数据,支持的业务功能之前,我们非常有必要再提一下接口本身的规则,即便我们在前面的章节已经隐隐约约的提到过。
如果让我给接口文档下个定义,文档是使用接口的人对于接口的约束
口头协定(对,你没看错,这是我最经常见的)
word/Excel/txt 文件
api管理平台(rap2/yapi等等)
文档应该出现且不限于以下几点内容:
接口访问的地址
接口参数
必须传的参数
非必须传的参数
指定数据类型参数
请求方式
GET请求
POST请求
返回字段的含义
至于为什么是上面几条,不赘述,大家可以想一哈
对于测试人员来讲,遵循接口文档,就是按照文档进行测试。测试也可以分为两种风格:
懒汉式
测试人员并非在文档形成之初,就按照文档进行严格的测试,而是在业务功能基本完成之时,才介入测试。然后当发现调用出错,或者功能出错时,才去翻阅接口文档,反馈给开发修改再测试
饿汉式
文档一形成,测试人员就开始介入,抛开业务需求,变换参数组合,请求方式等对于接口本身进行测试,直至符合文档。后期功能完成后,再把重点放到功能层面
对于接口本身的测试用例,由于测试的主要目标是接口本身而非业务功能,所以我们只要针对接口文档中主要的几点进行编写即可:
使用get请求访问
使用post请求访问
必传参数为空
非必传参数为空
非指定类型参数请求
参数组合
当然,如果我们稍微了解以下后端代码是如何实现接口的,还可以编写一些特定的测试用例,比如如果操作数据库,可以尝试传入部分sql语句,进行安全方面的测试,在这里暂不做过多的说明
仍然以上一篇中的getList为例子:
<?php// 告诉浏览器返回为json类型header('Content-Type:application/json; charset=utf-8');// 获取参数$page = $_GET['page'];$size = $_GET['size'];/** * 在真正的开发过程中,会操作数据库,我们暂时用一个多维数组代替 */$data_list = array( array('id'=>1,'name'=>'成龙'), array('id'=>2,'name'=>'周润发'), array('id'=>3,'name'=>'周星驰'), array('id'=>4,'name'=>'李连杰'), array('id'=>5,'name'=>'梁朝伟'), array('id'=>6,'name'=>'张曼玉'), array('id'=>7,'name'=>'惠英红'), array('id'=>8,'name'=>'林青霞'), array('id'=>9,'name'=>'王祖贤'), array('id'=>10,'name'=>'巩俐'));foreach($data_list as $key=>$value){ if($key >= ($page -1) * $size && $key < $page * $size){ $temp[] = $value; }}// 组织的数据$data = array( 'code' => 200, 'msg' => '请求成功', 'result' => $temp);// PHP数组转json$rst = json_encode($data,JSON_UNESCAPED_UNICODE);// 打印结果echo $rst;
使用get请求访问 =====> 成功,无异常
post请求访问 =====> 失败
[@HymandeMBP:~]$ curl localhost/about_test/getList.php -X POST -d 'page=4&size=2'<br /><b>Notice</b>: Undefined index: page in <b>/Library/WebServer/Documents/about_test/getList.php</b> on line <b>8</b><br /><br /><b>Notice</b>: Undefined index: size in <b>/Library/WebServer/Documents/about_test/getList.php</b> on line <b>9</b><br /><br /><b>Notice</b>: Undefined variable: temp in <b>/Library/WebServer/Documents/about_test/getList.php</b> on line <b>40</b><br />{"code":200,"msg":"请求成功","result":null}
因为这个接口接受的请求方式是GET,没有处理请求方式是POST的情况,其他测试与此类似
下一篇,我们主要介绍关于业务功能的测试,从一个更加的真实的需求出发,说一下考法测试流程
测试文档是约束
测试文档几个要点
作者:茧城寒舍
链接:https://www.jianshu.com/p/31ae4cc54906