2--Postman脚本介绍
Postman是访问各种API的客户端。它的强大之处在于其允许在对某一个request访问的之前和之后分别运行自定义的一段Javascript脚本,可以将数条request连结成一个流程完成一体化测试。
脚本执行流程:
pre-request
脚本:API请求之前的脚本,一般用于动态生成参数、JSON数据包、链接地址等。test
脚本:完成API访问并得到其response之后运行的脚本,一般用于获取response的内容,用于之后对于别的资源的请求,如获取页面标题和内容等。
需要注意,pre-request
脚本,在里面直接写代码就可以了,但是test
脚本需要在某个指定的函数pm.test(...)
中执行才会被识别,且作为test
脚本运行。如下图:
pm.test()
中第一个参数是测试描述(会在测试结果栏显示,应和其它测试描述做以区分),第二个参数是一个函数,具体执行代码都在这个函数中运行。
另外,pm
对象是Postman的主要对象,所有的内置函数,数据调用等,都需要通过它来实现。
常用测试脚本
官方文档解释的各种函数调用链接在这里:https://www.getpostman.com/docs/v6/postman/scripts/postman_sandbox
// 获取response返回内容
var rsb = responseBody; // 是字符串格式 // 获取环境变量
var v = pm.environment.get("变量名称"); // 设置环境变量 只能存储字符串,如果是对象的话则无法在下次运行时获取到内容
// 如需要存储JSON数据,可以用JSON.stringify(..)存储,再用JSON.parse(..)转化为对象使用
pm.environment.set("变量名称", 变量内容); // 清除某个环境变量
pm.environment.unset("环境变量名"); // 获取全局变量和普通变量
var gb = pm.globals.get("全局变量名");
var nm = pm.variables.get("普通变量名"); // Javascript 获取变量类型
console.log( typeof pm.enviroment ); 作者:solomonxie
链接:https://www.jianshu.com/p/4a66746fb521
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
脚本调试
如果要看已经设置的Enviroment变量的话,可以点开右上方小眼睛看到,如下图
调试时要打印的话,一般都是用console.log(...)
,这样就能在console中看到:如下如所示脚本和console日志。注意,再执行测试之前打开console,会记录API和打印的日志。
测试结果
除了具体功能代码外,经常还需要返回一个结果,告诉Postman这个测试结果是Pass还是Fail,默认是pass。
这里返回值就不是简单的return语句可以,必须要通过Postman自带的对象或方法才可以,一般是通过pm.expect()
或tests[]
这两个地方返回测试结果。
pm.expect()--期待什么,才能通过测试。
pm.to.be()--要求它必须是什么,才能通过测试。
pm.to.have()--要求它必须是什么
,才能通过测试。pm
对象,而是内置tests
对象,常用操作如下:# 反应时间必须少于200毫秒
tests["Response time is less than 200ms"] = responseTime < 200; # 判断反应代号是否等于某一个指定的代号
tests["Status code name has string"] = responseCode.name.has("Created");
看这个用法,猜测tests
是一个JSON格式的对象,tests[...]
括号内的字符串是测试的描述, =
后面是判断语句,然后将True或False赋予为tests[..]
的值,然后postman轮训所有tests
对象里的参数,并返回pass与否的结果。
这里是官方总结的常用测试脚本方法:
https://www.getpostman.com/docs/v6/postman/scripts/test_examples
# “期待”返回结果必须包含某一段内容
pm.expect(从response里获取的字符串).to.include("必须包含的内容"); # 返回body值必须完全等于某一段内容
pm.response.to.have.body("必须等于的内容"); # 反应时间必须少于200毫秒
pm.expect(pm.response.responseTime).to.be.below(200); # 必须返回某一个状态 如"Created"
pm.response.to.have.status("状态名");
作者:solomonxie
链接:https://www.jianshu.com/p/4a66746fb521
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
2--Postman脚本介绍的更多相关文章
- Postman—脚本介绍
前言 Postman包含一个基于Node.js的强大的运行时环境,它允许我们为请求和集合添加动态行为.这使的我们可以编写测试用例,构建可包含动态参数的请求,在请求之间传递数据等等. 我们可以在流程中以 ...
- postman(八):使用newman来执行postman脚本
通过之前的了解,我们知道postman是基于javascript语言编写的,而导出的json格式的postman脚本也无法直接在服务器运行,它需要在newman中执行(可以把newman看做postm ...
- 测试那些事儿—postman入门介绍
1.postman入门介绍 一款功能强大的网页调试与发送网页HTTP请求的工具. 1)模拟各种HTTP请求,如get,post,put,delete 2)测试集合Collection Colle ...
- postman—使用newman来执行postman脚本
我们知道postman是基于javascript语言编写的,而导出的json格式的postman脚本也无法直接在服务器运行,它需要在newman中执行(可以把newman看做postman脚本的运行环 ...
- 4-1 Postman脚本的应用
前面我们讲解了在接口发送每个请求,得到响应.这是接口本身的问题.但是"请求前后"的动作,是怎么处理的?比如在发送一个请求前,需要获取当前的时间戳,或者对我们的变量进行参数化,设置变 ...
- Linux Shell 高级编程技巧3----运行级别脚本介绍
3.运行级别脚本介绍 3.1.运行级别 运行级别介绍: 0 关机 1 单用户模式 2 多用户模式 ...
- shell脚本介绍、shell脚本结构和执行、date命令用法、shell脚本中的变量
7月11日任务 20.1 shell脚本介绍20.2 shell脚本结构和执行20.3 date命令用法20.4 shell脚本中的变量 20.1 shell脚本介绍 1.shell脚本语言是linu ...
- Linux centosVMware shell脚本介绍、shell脚本结构和执行、date命令用法、shell脚本中的变量
一. shell脚本介绍 shell是一种脚本语言 aming_linux blog.lishiming.net 可以使用逻辑判断.循环等语法 可以自定义函数 shell是系统命令的集合 shell脚 ...
- postman(介绍)
Postman 界面介绍 一. 安装后首次打开 postman,会提示你是否需要登录,登录的话可以云端保存你的收藏及历史记录,不登陆不影响使用. 二. 进入后就是如下图所示的界面了.看到这么多按钮 ...
- 【转载】]基于RedHatEnterpriseLinux V7(RHEL7)下SPEC CPU 2006环境搭建以及测试流程 介绍、安装准备、安装、config文件以及运行脚本介绍
https://www.codetd.com/article/1137423 <版权声明:本文为博主原创文章,未经博主允许不得转载> 本次利用SPECCPU2006测试工具来进行Intel ...
随机推荐
- 高度自适应不能触发transition的解决方法
1. 前言 在我们不能确定一个元素的高度的时候,要使用transition过渡,是不会触发的,比如一个p标签 内容行数不固定 我们可能就要初始 height: 0 ; 过渡到 height: au ...
- Celery 实现异步任务-one
celery异步任务: 环境准备 安装celery ,django-celery. 就是一个专注于实时处理和任务调度的分布式队列. 可以异步执行的任务交给后台处理,以防网络阻塞,减小响应时间 cele ...
- UI自动化(十)selenium定位
浏览器操作 1 2 3 4 5 6 7 8 # 刷新 driver.refresh() # 前进 driver.forward() # 后退 driver.back() 获取标签元素 ...
- TabBar + TabBarView导航风格
import 'package:flutter/material.dart'; import 'News.dart'; import 'Video.dart'; import 'Chat.dart'; ...
- CSS中正确理解浮动以及clear:both的关系
要注意以下几点: 1. 浮动元素会被自动设置成块级元素,相当于给元素设置了display:block(块级元素能设置宽和高,而行内元素则不可以). 2. 浮动元素后边的非浮动元素显示问题. 3. 多个 ...
- 智能合约 helloworld
windows 平台 所以直接使用Remix在线编译环境 新建hello.sol文件 编辑如下 Remix 右边侧栏 setting 选择合适的编译器版本 这里选择 0.4.19 文件中输入如下内容 ...
- ubuntu18.04中python虚拟环境的安装
一:下载虚拟环境安装包 sudo apt install virtualenv sudo apt install virtualenvwrapper pwd 查看当前目录 ls -all 查看是否有 ...
- Linux下修改用户的UID、GID
01.用户的UID和GID不能被占用 [root@26 ~]# id mvpuid=503(mvp) gid=503(mvp) groups=503(mvp) ###假定我需要设置mvp的uid/gi ...
- Android View 阴影的总结
关于 Android 阴影,大家肯定不陌生的.但是Android 中到底有多少种方式可以实现阴影效果以及各种方式之间有什么区别和优缺点,这就是我想总结的.下面我们一个一个来说: 一.各种实现阴影的方式 ...
- 力扣(LeetCode)605. 种花问题
假设你有一个很长的花坛,一部分地块种植了花,另一部分却没有.可是,花卉不能种植在相邻的地块上,它们会争夺水源,两者都会死去. 给定一个花坛(表示为一个数组包含0和1,其中0表示没种植花,1表示种植了花 ...