zoukankan      html  css  js  c++  java
  • 使用Postman工具做接口测试(四)——参数化、执行用例与生成测试报告(完结篇)

      引言

      前面已经介绍了postman断言和参数提取,这个是针对接口运行后的操作,那么接口运行之前,我们需要做哪些了?毋庸置疑的就是参数化,它可以帮我们提前造测试数据,针对一些加密和认证的接口,我们需要提前做这些,带着这些参数去请求,接口才会通。下面我讲讲实际测试中的参数化,批量执行测试用例以及生成测试报告。

      参数化

      在之前介绍《使用Postman工具做接口测试(二)——环境变量与请求参数格式》文中讲过环境变量的设置,其实就是参数化,现在,我介绍参数化其他几种形式。

    第一种:自己定义的参数。

    下面用户签名接口为例,下面代码是本地开发的接口。

    # 用户签名
    # 鉴权: 签名+时间戳
    def user_sign(request):
        if request.method == 'POST':
            client_time = request.POST.get('time','')
            client_sign = request.POST.get('sign','')
            address = request.POST.get('address','')
            print(client_sign,222)
            print(address,333)
    
        else:
            return '错误'
    
        if client_time == '' or client_sign == '':
            return '签名为空'
    
        # 服务器时间
        now_time = time.time()
        server_time = str(now_time).split('.')[0]
        # 时间差
        time_diff = int(server_time) - int(client_time)
        if time_diff >= 60:
            return '请求超时'
    
        # 签名
        md5 = hashlib.md5()
        sign_str = client_time + '&guest-test'
        # 转换成encode
        sign_bytes_utf8 = sign_str.encode(encoding = 'utf-8')
        md5.update(sign_bytes_utf8)
        server_sign = md5.hexdigest()
    
        if server_sign != client_sign:
            return '签名失败'
        else:
            return '签名成功'
    

     

      从上面可以看出,加密方式:client_time + '&guest-test'。

    如果要请求被加密接口,必须提前对请求参数中需要加密的信息进行参数化,如下:

    代码:

    //设置当前时间戳(10位)
    postman.setGlobalVariable("time",Math.round(new Date()/1000));
    time = postman.getGlobalVariable('time');
    
    //设置KEY_WORD为全局变量
    postman.setGlobalVariable("Key","&guest-test");
    KEY_WORD = postman.getGlobalVariable("Key");
    
    //字符串进行md5加密
    var str = time+KEY_WORD;
    var strmd5= CryptoJS.MD5(str).toString();
    //signs设置成全局变量,signs
    postman.setGlobalVariable("signs",strmd5);
    //signss = pm.variables.get('signs')
    console.log(time);
    console.log(strmd5);
    

    如果要设置13位时间戳,可以这样写:

    //设置当前时间戳(13位)
    // postman.setGlobalVariable("time",Math.round(new Date().getTime()));
    // time2 = postman.getGlobalVariable('time');
    

      

     接口请求前的处理,都放在Pre-request Script。

    打开日志,看看是否获取到值:

    使用{{}}可以引用参数,看看效果:

    第二种:使用postman自带的函数来参数化。

    其实这种跟上面是一样的,只是使用一些内置函数。

    {{$randomInt}}:添加0和1000之间的随机整数

    {{$timestamp}}:将当前的时间戳,精确到秒,精确到毫秒时,后面增加000即可

    {{$randomDateRecent}}: 生成一个标准的中国时间,格式:Thu Mar 12 2020 08:15:08 GMT+0800 (中国标准时间)

    使用如下:

    看看后台的请求结果:

    这个randomDateRecent时间传进来我是做了转化,显示格式:%Y-%m-%d %H:%M:%S

    可以看出,内置函数比较死板,无法得到想要的随机数,所以我们还是可以自己写脚本。

    如:

    // 随机字符串
    postman.setGlobalVariable("random_username", ("0000" + (Math.random()*Math.pow(36,4) << 0).toString(36)).slice(-4));
    console.log(("0000" + (Math.random()*Math.pow(36,4) << 0).toString(36)).slice(-4))
    // 0~9999的随机整数
    postman.setGlobalVariable("random_number",Math.round(Math.random()*9999));
    console.log(Math.round(Math.random()*9999))
    

    查看后台结果:

    id是0~9999的随机整数,name是4位的随机字符串。

    第三种:使用文件参数化,postman跟jmeter一样都支持文档参数化,当前支持文件格式有:Json文档,txt文档,CSV文档。

    前提条件: 本文以txt文档为例,在txt里面创建测试数据,存入eid和name两个字段。多个数据之间用逗号分隔(逗号是英文的)

    上传文件后,查看是否一样:

    引用参数化变量eid和name

     

    运行参数说明:

    • Environment:选择运行的环境,环境主要决定环境变量的;
    • Iterations: 用例迭代的次数,也就是当前选中的这些请求需要运行几次;
    • Delay:延迟,用来设置每个请求之间的运行时间(以毫米为单位),如果设置了,则一个请求运行完后会等待相应的时间才运行下一个请求;
    • Log Responses:记录响应日志,这是一种限制性的设置,默认是记录所有请求的日志,也可以限制为只记录错误日志或者完全不记录;
    • Data:选中数据文件,这是 Postman 提供的数据驱动的方式,数据针对当前 Collection 中请求中使用的变量。支持 Csv 和 Json 格式的文件;
    • Keep variable values:保持变量值。如果 Collection 中有脚本重新设置环境变量或者全局变量的值,默认情况下只对当次运行有效。如果勾选了此选项,那么在脚本中重设的变量值会保存下来,也就是会直接修改 Postman 中预设的变量值;
    • Run collection without using stored cookies:如果勾选此选项,运行 Collection 的时候则不会使用 Postman 的 cookie 管理器;
    • Save cookies after collection run:运行后,储存运行过程中的 cookies,此选项默认勾选。

    查看结果:

     

       运行测试用例

    选择collection后,右侧的菜单中运行Run

     

     查看结果:

      测试报告工具安装

      在做完接口测试之后,输出的测试结果需要以报告的形式展示,postman也提供了报告,但不同的是需要安装一些必要的工具——Newman。

    Newman是一款基于nodejs开发的可以运行postman脚本的工具,使用Newman,可以直接从命令运行和测试postman集合。

      安装nodejs

    下载地址:https://nodejs.org/en/download/

     

     查看是否安装成功,打开cmd输入node -v

     

      安装newman

    注意:newman必须要跟nodejs处于一个文件当中,才可以安装成功,否则会报错的

      安装html报告模块

    首先从postman中导出测试用例

    创建一个文件夹,把导出来的用例直接存放到创建的文件夹当中,方便测试

      生产测试报告

    打开cmd,找到存放用例的路径。执行下面的一些命令

    方式1-执行导出的测试用例:

    newman run E:postman_reportAPI文档.postman_collection.json
    

      

    从图中可以看出执行详情,迭代1次,请求5个,失败0个。

    方法2-生成html测试报告:

    newman run E:postman_reportAPI文档.postman_collection.json -r html
    

     如果出现这种情况,说明导出的json测试用例不支持newman命令,所以重新导一份。

     再次执行上面命令:

     进入E:postman_report 发现没有html报告,经过一系列的挣扎,自己最后怀疑是文件名有中文引起的,改了英文后,果然成功。

    如图:

     

     如果你不指定报告存放路径,它会默认生成一个文件夹newman.

    如果你想放到其他目录,可以这样:

    E:postman_report>newman run api.postman_collection.json --reporters html --reporter-html-export E:postman_report
    

      

    查看报告内容:

    这个报告是不是太简陋了?下面看看使用其他工具生成漂亮报告。

      高级版html报告

    使用htmlextra套件生成比较高级的html报告
    使用方法和html的相同,需要安装htmlextra,命令行中输入:

    npm install -g newman-reporter-htmlextra
    

    使用命令生成报告:

    E:postman_report>newman run api.postman_collection.json -r htmlextra --reporter-html-export
    

    查看报告:

    通过头部的Summary、Total Requests 、Failed Tests 、Skipped Tests 查看统计数据、所有的请求、失败的用例、跳过的用例等。

      如下图,所有的用例:

     点击每个请求可以查看详细,如下图:

    失败用例:

    其他:

    设置重复执行次数
    例:重复执行10次

    newman run APITest.postman_collection.json -n 10

    查看其他可用的参数

    newman run -h

    postman接口测试全套内容基本上就是这些,当然还可以和Jenkins工具做持续集成。

    小编码字不易,转载请注明。欢迎加入自动化测试开发学习交流群:696400122,关注小编,满满干货,持续更新中。一起学习成长~

  • 相关阅读:
    element ui el-date-picker 判断所选时间是否交叉
    MDN中的箭头函数!!!
    es6 解构
    element ui 实现可编辑表格
    节流 防抖。。。。深入理解
    element ui 表格对齐方式,表头对齐方式
    纯html + css 导航栏
    PHP 1
    apache 建立虚拟主机
    Can't connect to local MySQL server through socket '/tmp/mysql.sock'
  • 原文地址:https://www.cnblogs.com/liudinglong/p/12466510.html
Copyright © 2011-2022 走看看