『政善治』Postman — 17.接口测试项目综合练习(二)

时间:2021-6-4 作者:qvyue

(三)Postman测试实操

简述整体思路:

  1. 我们需要创建5个请求,鉴权、注册、登陆、查询、注销。
  2. 创建一个Collection测试集管理以上请求。
  3. 创建一个环境变量,对该项目的公共变量进行管理。
  4. 先调用鉴权接口,把获得的token存储环境变量中,方便后续接口使用。
  5. 每个请求都需要编写断言。

1、准备工作

(1)创建一个Collection测试集

因为是新的项目,我们需要为该项目创建一个新的测试集,方便请求的管理。

例如:叫“综合练习”。

(2)创建一个环境变量

创建一个环境变量,方便对该项目的公共变量进行管理。

一般与Collection测试集同名。

2、 创建请求

(1)创建auth鉴权请求

通过前面接口文档可以分析得出:

auth鉴权接口如果不传递token参数,就重新分配一个token并返回。

如果传递有效的token参数,此时不再重新分配token;

所以我们就创建一个不带参数的auth鉴权请求即可。

(只填写请求方式和请求参数即可)

如下图:

『政善治』Postman — 17.接口测试项目综合练习(二)

然后我们编写请求后置脚本Tests

步骤1:编写断言

// 断言鉴权操作成功
// 返回值中msg是否等于success
pm.test("鉴权接口请求成功", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.msg).to.eql("success");
});

步骤2:把返回值中的token数据保存到环境变量中,提后后续接口使用。

// 把鉴权接口返回数据中的token信息,保存到环境变量中
pm.environment.set("authToken", pm.response.json().token);

编写完成后,我们再Send验证一次:

『政善治』Postman — 17.接口测试项目综合练习(二)

可以看到Tests中的脚本是没有问题,我们再来看看“综合练习”环境变量中的内容。

如下图:

『政善治』Postman — 17.接口测试项目综合练习(二)

看到以上信息,说明auth鉴权请求实现完成。

(2)用户注册接口实现

先填写请求方式和请求地址,并填写请求数据,如下图:

『政善治』Postman — 17.接口测试项目综合练习(二)

然后在请求头中填写token信息。

『政善治』Postman — 17.接口测试项目综合练习(二)

最后在编写后置脚本Tests断言

// 断言用户注册操作是否成功
pm.test("注册操作成功", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.msg).to.include("注册成功");
});

发送请求并查看结果,如下图:

『政善治』Postman — 17.接口测试项目综合练习(二)

以上就完成了用户注册接口的实现。

(3)用户登陆接口实现

先填写请求方式和请求地址,并填写请求数据,如下图:

『政善治』Postman — 17.接口测试项目综合练习(二)

然后在请求头中填写token信息。

『政善治』Postman — 17.接口测试项目综合练习(二)

最后在编写后置脚本Tests断言和数据处理

断言:

// 断言用户登陆成功
pm.test("用户登录成功", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.msg).to.include("登录成功");
});

数据处理:

// 把返回用户的userid,添加到环境变量中。
// 方便后续的接口使用。
pm.environment.set("userid", pm.response.json().userid);

发送请求并查看结果,如下图:

『政善治』Postman — 17.接口测试项目综合练习(二)

查看环境变量userid已被添加。

『政善治』Postman — 17.接口测试项目综合练习(二)

以上就完成了用户登录接口的实现。

(4)查询用户信息接口实现

先填写请求方式和请求地址,并填写请求数据,如下图:

『政善治』Postman — 17.接口测试项目综合练习(二)

然后在请求头中填写token信息。

『政善治』Postman — 17.接口测试项目综合练习(二)

最后在编写后置脚本Tests断言

// 断言查询用户信息成功
pm.test("查询用户信息成功", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.msg).to.include("查询成功");
});

发送请求并查看结果,如下图:

『政善治』Postman — 17.接口测试项目综合练习(二)

以上就完成了查询用户信息接口的实现。

(5)用户注销接口实现

先填写请求方式和请求地址,而logout(注销)接口并不需要传递参数,只需要传请求头中有效的token。

『政善治』Postman — 17.接口测试项目综合练习(二)

编写后置脚本Tests断言

// 断言用户注销成功
pm.test("用户退出登录成功", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.msg).to.include("退出登录");
});

发送请求并查看结果,如下图:

『政善治』Postman — 17.接口测试项目综合练习(二)

以上就完成了用户注销接口的实现。

提示:如果再次调用登录接口进行用户登录,就会出现登录失败的现象。需要重新auth鉴权,再进行登录。

以上综合项目中的接口我们都创建完成了。

(四)加入数据驱动

1、准备数据文件

更具上面的5个接口,来编辑数据文件,如下:

usernane password registerMsg loginUser loginPwd loginMsg userMsg
xiaoming3 123456 注册成功 xiaoming3 123456 登录成功 查询成功
xiaoming3 123456 用户已被注册 xiaoming3 12345666 用户名密码错误 您还未登陆
xiaoming3@ 123456 参数错误 xiaoming3@ 123456 参数错误 您还未登陆
xiaoming3aaaaaaaaaaaaaa 123456 参数错误 xiaoming3aaaaaaaaaaaaaa 123456 参数错误 您还未登陆

当我们用到数据驱动的时候,首先要想清楚,测试的输入数据是哪些,还有预期的返回信息是什么。

提示:

  • 要把Excel文件另存为.cvs文件。
  • 使用Notepad++打开数据文件,然后将数据文件转为UTF-8编码

2、修改请求中的参数

我们以注册接口为例,其他接口同理。

修改请求参数如下:

『政善治』Postman — 17.接口测试项目综合练习(二)

修改请求后置脚本Tests,如下:

『政善治』Postman — 17.接口测试项目综合练习(二)

3、使用测试驱动方式执行测试集

点击测试集,然后进入Collection Runner界面。

执行如下操作:

『政善治』Postman — 17.接口测试项目综合练习(二)

提示:每次上传完数据文件后,需要Preview一下,确保上传的数据信息的准确性。

如下图:

『政善治』Postman — 17.接口测试项目综合练习(二)

最后点击Run综合练习DDT执行测试集。

4、分析测试结果

通过分析测试结果,可以判断接口的是否正确,也可以对测试数据重新进行补充或者修改。

『政善治』Postman — 17.接口测试项目综合练习(二)

最后得出接口测试的结果。

以上就是在工作中我们使用Postman进行接口测试的基础流程。

声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:qvyue@qq.com 进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。