接口自动化( 一 Postman)

如需有需要了解接口测试面试的话,我的博客中有写到,接口测试面试题

(一)介绍

简介

postman 是一款强大网页调试工具的客户端,postman为用户提供强大的 Web API & HTTP 请求调试功能。postman能够发送任何类型的HTTP 请求 (GET, HEAD, POST, PUT…),附带任何数量的参数+ headers,是一款非常实用的调试工具

自动化测试分类

  1. 按测试目的分类:
    功能自动化测试
    性能自动化测试
    按测试对象分类
  2. 按测试对象分类
    Web应用测试
    APP测试
    接口测试
    单元测试

为什么需要自动化测试

可以替代大量的手工机械重复性操作,测试工程师可以把更多的时间花在用例设计和新功能的测试上

可以大幅度提升回归测试的效率,非常适合敏捷开发过程

可以更好地利用无人值守时间,去更频繁地执行测试

可以高效实现某些手工测试无法完成或代价巨大的测试类型,例如:7*24小时持续运行的系统稳定性测试和高并发场景的压力测试

可以保证每次执行的操作具有一致性和可重复性,不会受人的感情因素影响

postman的特点

  • 支持各种的请求类型: get、post、put、patch、delete 等
  • 支持在线存储数据,通过账号就可以进行迁移数据
  • 很方便的支持请求 header 和请求参数的设置
  • 支持不同的认证机制,包括 Basic Auth,Digest Auth,OAuth 1.0,OAuth 2.0 等
  • 响应数据是自动按照语法格式高亮的,包括 HTML,JSON 和 XML

postman软件功能

1、模拟各种HTTPrequests

从常用的GET、POST到RESTful的PUT、DELETE…等等。甚至还可以发送文件、送出额外的header

2、Collection功能(测试集合)

通过collection的归类,我们可以良好的分类测试软件所提供的API.而且Collection还可以Import或是Share出来,让团队里面的所有人共享你建立起来的Collection

3、人性化的Response整理

一般在用其他工具来测试的时候,response的内容通常都是纯文字的raw,但如果是JSON,就是塞成一整行的JSON。这会造成阅读的障碍,而Postman可以针对response内容的格式自动美化。JSON、XML或是HTML都会整理成我们可以阅读的格式

4、内置测试脚本语言

支持编写测试脚本,可以快速的检查request的结果,并返回测试结果

5、设定变量与环境

Postman可以自由设定变量与Environment,一般我们在编辑request,校验response的时候,总会需要重复输入某些字符,比如url,允许我们设定变量来保存这些值。并且把变量保存在不同的环境中

(二)postman接口测试

postman怎么测试接口

接口测试请求分为多种情况,这里介绍get、post、带cookie、带Header、上传文件五种请求的测试。

1、get请求

get请求是最简单的请求方式,输入URL就能完成

1、新建一个tab页面

2、输入URL ,选择请求方式为GET

3、点击“send”按钮

4、查看返回码是否异常。

2、post请求

post请求跟get的区别除了请求方式不同之外,还需要添加请求体,请求体内容多半为json格式

1、新建一个tab页面

2、输入URL ,选择请求方式为POST

3、输入请求体内容

4、点击“send”按钮

5、查看返回码,返回信息等

3、带cookie的请求

该请求需要在Heards里面添加Cookie

1、新建一个tab页面

2、输入URL ,选择请求方式为POST

3、输入请求体内容

4、在Heard里面添加Cookie信息

5、点击“send”按钮

6、查看返回码,返回信息等

4、带Header的请求

该请求需要在Heards里面添加Cookie

1、新建一个tab页面

2、输入URL ,选择请求方式为POST

3、输入请求体内容

4、在Heard里面对应的内容

5、点击“send”按钮

6、查看返回码,返回信息等

5、文件上传的请求

发送请求前需要先上传文件

1、新建一个tab页面

2、输入URL ,选择请求方式为POST

3、输入请求体内容,文件内容选择file, 选择本地的文件上传

4、点击“send”按钮

5、查看返回码,返回信息等

6、如何发送json参数

1、在地址栏里输入请求url

2、接着选择“POST”方式。

3、在“headers”添加key:Content-Type , value:application/json

4、然后点击"body",’‘raw’'并设定为JSON。

5、接着添加:{“userid”: 1}

6、最后点击send发送即可

(三)postman接口自动化

postman说明

平时可能大家只是简单用postman来看一些请求返回的数据。其实它还具有很强大的接口自动化测试功能,它其实自己就提供了一个框架,它是采用js脚本编写的,这几天我看视频学习,现在整理一下,关于如何使用postman进行接口测试

postman如何实现接口自动化测试

1、新建一个接口,百度搜了一个歌名查询的,https://api.apiopen.top/searchMusic?name=XXX

在postman中运行
在这里插入图片描述
2、VALUE使用参数化,方法:{{参数化的名称}},后面test.txt中的name
在这里插入图片描述
3、新建一个文件夹test,将接口保存进去
在这里插入图片描述
在这里插入图片描述
4、新建一个test.txt,存在D盘下,中间以英文逗号隔开,格式如图
在这里插入图片描述
5、点击postman左上角的runner,并选中测试的接口
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述6、批量执行测试,查看执行结果
在这里插入图片描述
在这里插入图片描述7、如何添加检查点
关掉collection,回到Postman主界面,进入Tests界面,右侧提供了很多检查函数
在这里插入图片描述
在这里插入图片描述
调试通过后,把所有的值都参数化
在这里插入图片描述
再次打开runner并根据上面的方法执行

(四)变量

定义变量

定义全局变量和环境变量
点击右上角的小齿轮,弹出如下界面,就可以根据需求定义全局变量或者环境变量了。
在这里插入图片描述
已经定义的全局变量和环境变量,可以进行快速查看
在这里插入图片描述
定义变量除了以上方式,还有另外一种方式

在URL,Params , Authorization , Headers , Body中定义:手工创建一个空的变量名在图中位置把想要的值选中右击,选中Set:环境|全局 ,选中一个变量名,点击后就会保存到这个变量中
在这里插入图片描述

在Tests,Pre-requests Script:
定义全局变量:pm.collectionVariables.set("变量名",变量值)
定义环境变量:pm.environment.set("变量名",变量值)
定义集合变量:pm.variables.set("变量名",变量值)

获取变量

定义好变量,接下来就可以使用变量了

如果在请求参数中获取变量,无论是获取全局变量,还是环境变量,还是集合变量,获取的方式都是一样的编写规则:{{变量名}} 。

请求参数指的是:URL,Params , Authorization , Headers , Body
如果是在编写代码的位置(Tests,Pre-requests Script)获取变量,获取不同类型的变量,编写的代码都不相同,具体如下:

获取环境变量:pm.environment.get(‘变量名’)
获取全局变量:pm.globals.get('变量名')
获取集合变量:pm.pm.collectionVariables.get.get('变量名')

在这里插入图片描述

登录中的{{username}} 、{{password}} 赋值操作

现在登录的账号和密码参数都是写死的,也就是不管执行多少次,都是拿一个账号去测试。 先简单讲一下在 Postman 中使用如何“变量”
在这里插入图片描述
引用一个变量的语法:{{变量名}}, 将账户和密码字段的参数值都设置为变量:{{username}} 、{{password}} 。在 Pre-request Script 面板中进行赋值操作:

Pre-request Script 与 Tests 类似,区别在于:

Pre-request Script 中的脚本是在执行请求之前运行
而Tests 中的脚本则是在请求完成之后执行
所以,可以在 Pre-request Script 功能区中用脚本先个上面两个变量进行赋值,如:

//设置全局变量
postman.setGlobalVariable("username", "test1");
postman.setGlobalVariable("password", "12345689");

==但是用 Pre-request Script 进行赋值操作仍然不能解决我们的问题,因为按照这种写法,不论运行多少次其实都还是用固定(写死)的数据进行测试,这个问题后续再讲

登录常遇到的sql注入

4、登录时,用户名输入:admin’#
密码任意输入:abc
登录成功,说明存在sql注入漏洞。
在这里插入图片描述

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

测试小姐姐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值