注意: appid和secret使用自己的,此文是乱写的
Params : get请求传参
authorization:鉴权
headers:请求头
Body : post请求传参
form-data :既可以传键值对参数也可以传文件。
x-www-from-urencoded:只能够传键值对参数
raw : json , text , xml , html, javascript
binary :把文件以二进制的方式传参。
pre-request-script: 请求之前的脚本。
tests :请求之后的断言.
cookies :用于管理cookie信息。
Body:接口返回的数据。
Pretty:以Json,html , XML...不同的格式直看返回的数据。
Raw:以文本的方式直看返回的数据。
PreView:以网页的方式查看返回的数据。
Cookies:响应的Cookie信息
Headers:响应头
Test Results:断言的结果。
200 状态码
OK 状态信息
681MS 响应的时间
343B 响应的字节数。
第一个接口:
//使用json提取器提取access_token值
//把返回的字符串格式的数据转换成对象的形式
var result = JSON. parse(responseBody);
//把access token设置为全局变量
pm. globals.set("access_token" ,result.access_token);
第二个接口:
{{access_token}}
第一个接口:
//使用正则表达式提取器实现接口关联, match匹配。
var result = responseBody.match(new RegExp('"access_token":"(.*?)"
console.log(result[1]);
//设置为全局变量
pm.globals.set("access_token" ,result[1]);
第二个接口:
{{acgess_token}}
postman内置动态参数:
{{$timestamp}}生成当前时间的时间戮。
{{$randomInt}生成0~1000之间的随机数
{$guid}} 生成速记GUID字符串。
自定义动态参数
//写在pre-request-script
//手动的获得时间戳
var times = Date.now();
//设置为全局变量
pm.globals.set("times" , times);
使用时使用:{{times}}
常规六种断言
Status code:Code is 200检查返回的状态码是否为200
Response body:Contains string检查响应中包括指定字符串
Response body:Json value check检查响应中其中json的值
Response body : is equal to a string检查响应等于一个字符串
Response headers : Content-Tye...检查是否包含响应头Content-Type
Response time is less than 200ms :检查请求耗时小于200ms
在断言中获取自定义动态参数(全局变量)的方式: .
pm.globals.get("tmes")
globals["times"]
globals.times
grant_type, appid, secret, assert_value
client_credential,wx6b11b3efd1cdc290,104jk43522m34j2j4k43j4k5j3k45j3kj49d, access_token
,wx112h23j4244133da,104jk43522m34j2j4k43j4k5j3k45j3kj49d,40002
client_credential, , 104jk43522m34j2j4k43j4k5j3k45j3kj49d,41002
client_credential, wx112h23j4244133da, ,41004
//判断当返回结果中包括有access_token时才通过正则表达式去取值
if(responseBody.search("access_token")!=-1){
//使用正则表达式提取器实现接口关联,match匹配。
var result=responseBody.match(new RegExp("access_token":"(.*?)"));
console.log(result[1]);
//设置为全局变量
pm.globals.set("access_token" ,result[1]);
//断言
//业务断言
pm.test("检查响应中包括access_token", function () {
//这里include里面需要使用"data."去获取data.csv里面设的变量名
pm.expect(pm.response.text())to.include(data.assert_value);
});
[
{"grant_type":"client_credential", "appid" : "wx112h23j4244133da", "secret": "104jk43522m34j2j4k43j4k5j3k45j3kj49d", "assert_value":"access_token"},
{"grant_type" :"", "appid" : "wx112h23j4244133da", "secret" : "104jk43522m34j2j4k43j4k5j3k45j3kj49d", "assert_value": 40002},
{"grant_type":"client_credential", "appid":"", "secret" :"104jk43522m34j2j4k43j4k5j3k45j3kj49d","assert_value": 41002},
{"grant_type":"client_credential", "appid" : "wx112h23j4244133da", "secret":"", "assert_value": 41004}
]
Content-Type | 请求内容的格式 |
Accept | 客户端接收到的数据格式 |
X-Requested-With | 异步请求 |
User-Agent | 客户端的用户类型 |
Cookie | Cookie信息 |
Host | 请求的主机地址 |
Connection | 连接方式 |
Referer | 来源 |
后端的接口还没有开发完成,前端的业务需要调用后端的接口。
什么是cookie ?
cookie是一小段文本。格式key=value
cookie鉴权的原理:
1.当客户端第一次访问服务器的时候,那么服务器就会生成Cookie信息,
并且在响应头的set-cookie里面把生成的cookle信息发送给客户端。
2.当客户端第2-N次访问服务器的时候,那么客户端就会在请求头的cookie带上cookie信息,从而实现鉴权。
cookie的分类
会话cookie:保存在内存。当浏览器关闭之后就会自动化清除cookie。
持久cookie:保存在硬盘。浏览器关闭后不会清除,只有当失效时间到了才会自动清除。
postman是专为接口测试而生。newman (新男人)是专为postman而生。newman可以让我们的postman的脚本通过非GUI (命令行)的方式。
运行命令: newman run
常用参数:
-e 引用环境变量
-g 引用全局变量
-d 引用数据文件
-n 指定测试用例迭代的次数
-r cli,html,json,junit --reporter-html-export 指定生成HTML的报告。
1、在本地新建一个文件夹postman;
2、将postman运行的用例导入到postman文件中;
3、导出环境
4、全局变量
5、如果有数据文件的话还需要拷贝数据文件
6、使用cmd命令,在E盘下的postman文件夹下运行以下命令
newman run testcase.json -e environment.json -g globals.json -d data.json -r cli,html,json,junit --reporter-html-export report.html
任务名为newman,选择Freestyle project
创建好之后,点击“配置”,也可以进入配置页面
**第一步:**选择Execute Windows batch command;
**第二步:**添加以下命令
newman run testcase.json -e environment.json -g globals.json -d data.json -r cli,html,json,junit --reporter-html-export report.html
**第三步:**点击“增加构建步骤”,选择Execute system Groovy script;
**第四步:**因为执行系统的Groovy脚本时,html报告样式会丢失,所以加下面一段代码。
System.setProperty("hudson.model.DirectoryBrowserSupport.CSP","")
第一步:点击“增加构建后操作步骤”,选择Publish HTML reports