美文网首页
浅谈接口测试(二)接口本身

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

作者: 茧城寒舍 | 来源:发表于2020-04-25 09:21 被阅读0次

    在我们测试接口提供的数据,支持的业务功能之前,我们非常有必要再提一下接口本身的规则,即便我们在前面的章节已经隐隐约约的提到过。

    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. 总结

    1. 测试文档是约束
    2. 测试文档几个要点

    相关文章

      网友评论

          本文标题:浅谈接口测试(二)接口本身

          本文链接:https://www.haomeiwen.com/subject/matqwhtx.html