浅谈接口测试(二)接口本身

发表于:2020-10-14 10:00

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:茧城寒舍    来源:简书

  在我们测试接口提供的数据,支持的业务功能之前,我们非常有必要再提一下接口本身的规则,即便我们在前面的章节已经隐隐约约的提到过。
  1. 接口文档
  如果让我给接口文档下个定义,文档是使用接口的人对于接口的约束
  口头协定(对,你没看错,这是我最经常见的)
  word/Excel/txt 文件
  api管理平台(rap2/yapi等等)
  文档应该出现且不限于以下几点内容:
  接口访问的地址
  接口参数
  必须传的参数
  非必须传的参数
  指定数据类型参数
  请求方式
  GET请求
  POST请求
  返回字段的含义
  至于为什么是上面几条,不赘述,大家可以想一哈
  2. 遵循接口文档
  对于测试人员来讲,遵循接口文档,就是按照文档进行测试。测试也可以分为两种风格:
  懒汉式
  测试人员并非在文档形成之初,就按照文档进行严格的测试,而是在业务功能基本完成之时,才介入测试。然后当发现调用出错,或者功能出错时,才去翻阅接口文档,反馈给开发修改再测试
  饿汉式
  文档一形成,测试人员就开始介入,抛开业务需求,变换参数组合,请求方式等对于接口本身进行测试,直至符合文档。后期功能完成后,再把重点放到功能层面
  3. 设计测试用例
  对于接口本身的测试用例,由于测试的主要目标是接口本身而非业务功能,所以我们只要针对接口文档中主要的几点进行编写即可:
  使用get请求访问
  使用post请求访问
  必传参数为空
  非必传参数为空
  非指定类型参数请求
  参数组合
  当然,如果我们稍微了解以下后端代码是如何实现接口的,还可以编写一些特定的测试用例,比如如果操作数据库,可以尝试传入部分sql语句,进行安全方面的测试,在这里暂不做过多的说明
  4. 举个例子
  仍然以上一篇中的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的情况,其他测试与此类似
  下一篇,我们主要介绍关于业务功能的测试,从一个更加的真实的需求出发,说一下考法测试流程
  5. 总结
  测试文档是约束
  测试文档几个要点

  本文内容不用于商业目的,如涉及知识产权问题,请权利人联系51Testing小编(021-64471599-8017),我们将立即处理。
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号