为什么需要参数化?
我在测试时候一个接口请求会用到不同的数据,如果是每次都手工输入就需要耗费大量的精力而且效率低下,我们把接口参数化后,只用把需要的数据放到一个文件中,在Runner这个模块中设置执行循环n次请求,每次循环取不同的参数值,通过读取这个文件再实现所有数据的验证。
参数化步骤:
1、创建数据文件,支持数据格式文件分别为csv和json、txt等,这里我们以创建txt文档为例
这里我们创建了一个data.txt格式的文件,文档的第一行必须是在请求中要使用的变量名,每一行是一条用例,并表示一次迭代,一行的多个数据之间用英文逗号分隔
2、请求中对应位置替换参数变量:请求参数中用{{参数名}}替换,代码中通过:data.参数名来进行替换,注意这里的变量名要和txt文档中的变量名一致
3、通过Runner-Data读取数据文件来运行:选中集合Collection->点击Run->然后选择需要批量运行的接口->选择“Choose files”,从文件选择区加载数据文件,通过点击Data File Type选择文件类型,点击Preview来预览数据,设置对应迭代次数,每次迭代都将使用你的数据文件中的一行,如果迭代次数超过数据文件中的行数,将重复执行最后一行,然后点击运行就可以得到结果,当然,参数化以后为了验证每个数据得到的结果需要在Tests里面进行断言,断言可参考postman断言和接口返回值获取方法
三、postman中引用外部数据文件中的参数的两种方式
第一种:在请求中可以使用{{ keyword }}去引用
第二种:在script脚本中可以使用data. keyword 或者data[”keyword “] 去引用,一般多个接口引用一个外部数据文件中不同的参数时采用
备注:如果一定要在test里取请求参数里填的东西,如参数是JSON字符串,那就用 JSON.parse(request.data).username
如果参数是form格式的就用request.data.username
四、postman内置变量
postman内置了几个变量可以用来直接获取请求的值或者请求的结果:
request :获取请求的参数,包括头和请求体
responseHeaders :返回值的header
responseBody :返回值的body
responseCode :返回值的http code
除此之外,还有几个内置的全局动态环境变量:
{{$guid}}: 生成一个guid
{{$timestamp}}: 获取当前时间戳
{{$randomInt}}: 获取一个动态0-1000随机整数
五、Postman参数化接口测试报错解决办法集合
(一)、Postman接口测试报:
Could not start run: Could not determine format of data file.
解决办法:1、将Headers中的Content-Type删除,系统会添加上默认的请求格式。
2、添加多种请求头格式,添加什么是根据body来选择和参数化导入文档格式决定的。