postman的GUI界面以及各个组件介绍

主界面如下

 

打开postman的GUI界面以及各个元素组件介绍

分为下三部分:

1、Head navigation bar (头部导航栏):此部分有以下选项内容需要了解:

(1)New(新建按钮):可以用来新建集合、请求、mock服务、监听器、测试环境等(重要);

(2)import(导入按钮):可以用来导入文件 信息、集合、文件夹、以及链接(tab);

(3)Runner(运行按钮):用于运行集合(重要);

(4)新窗口增加按钮:可以用来增加新的postman窗口、运行窗口、以及请求页签(tab);

(5):构建器和团队选项,可以用于团队库和当前视图的转换;

(6)抓取api请求图标:可以通过次按钮抓取api(不常用)

(7) 同步状态图标:同步apid 请求已达到共享;

(8)设置图标:管理postman的应用程序,设置postman主界面;

2、Side navigation bar :次部分包含内容如下:

(1)History:用postman发起过的任何请求,都会保存在历史选项卡里;;

(2)Collections:集合选项卡,可以是每个请求的集合、也可以是URL的集合;

3、work space:工作空间是postman使用的重点,对其务必熟悉;postman通过选项卡的形式在构建器中发送和管理的请求信息;

上部分是请求构建器,下部分是相应构建器;具体说明如下:

面对post请求如何使用postman进行测试:

用postman进行get请求:

如何在postman中进行参数化

 postman支持子啊接口请求中,对某个请求字段,或者url进行参数化。对url进行参数化只需要将其配置成环境变量,然后在url中对其进行引用即可。

对url进行参数化

对接口中的某个请求字段进行参数化

实例接口:

通过postman请求和响应如下:

此时我们想更换100个人,迭代请求apply接口,此时就需要name、certicode、age这三个key值进行参数化。postman本身支持三种参数化的方式。通过.text文档、通过.csv文件以及json文件。对于我而言,推荐大家采用第一种方式即.text方式进行参数化。因为操作简单,json文件的组织比较繁琐,不太适用于多个参数需要参数化的场景,而.csv文件对格式要求过高,会浪费精力。具体实现步骤如下:

1、组织需要的参数化的参数文件,文件内容展示如下:

参数之间需要用英文字符下单逗号间隔,编码需要utf-8,保存的文件后缀为.text即可;

2、在Apply接口的Pre-request Script出写入如下脚本,读取text参数化文件。

var apply="apply.text";   //声明参数化文件

var name=apply.name;  //读取第一个参数name

pm.environment.set("name","name");   //将name的值依次赋给请求中的name

var age=apply.age;

pm.environment.set("age","age");

var certicode=apply.certicode;

pm.environment.set("certicode","certicode");

3、将原请求中的具体值分别进行参数替换:替换后的请求为:

{

  “interfaceType”:"apply",

  "name":{{name}}",

  "age":"{{age}}",

  "certicode":"{{certicode}}"

}

4、打开runner,设置迭代次数且导入参数化文件;

 

5、点击“Run 360足球联赛”可以看到总计数迭代的次数为我设置的10,当然如果各个次数个数为100,就设置为100即可;运行完成后,效果图如下:

6、打开控制台,可以检查下每次请求是否按照参数进行取值;

上图知识截了第一次迭代、第二次迭代的请求,可见取的是参数化文件对应的第二行、第三行的值,不从第1行读取,是因为第一行是参数化列表;

使用runner对定时任务、请求进行迭代配置

配置定时任务的思路其实就是参数化介绍的runner界面控制,选择迭代次数以及每个定时任务之间的间隔时间即可;

用js脚本设置检查点(断言)

以上声明postman支持参数迭代,那么在结合上其身的js脚本,我们还可以用postman做接口的自动化验证,当然其有不足之处,体现在不能实现错误重试、生成测试报告以及错误信息的实时采集。但是满足日常的流程验证(现在也叫契约测试)是绰绰有余的。

在runner下运行准备好的apply 、sign、login三个接口,点击:Run Summary

运行结束后,不难看出,三个接口只是运行了,或者说满足了被调用的条件,但无法通过这个运行判断出接口到底是不是按照要求来做的、也就是响应时间、响应码、响应参数等是否满足约束。为了解决这个问题,我们为其添加断言(或者叫检查点);拿apply接口为例,学习检查点相关内容:

以下介绍常用的脚本:

1、设置环境变量

pm.environment.set("variable_key","variable_value");

2、检查http请求的状态码是否于预期一致

pm.test("Status code is 200",function() {

  pm.response.to.have.status(200);

});

3、检查JSON响应中包含某个字段

pm.test("Your test name",function () {

  var jsonData=pm.response.json();

  pm.expect(jsonData.value).to.eql("字段名称");

});

4、检查响应体中可以解析某个指定字段的值

pm.test("Body matches string",function () {

  pm.expect(pm.response.text ()).to.include("string_you_want_to_search");

});

 5、检查响应时间的长短

pm.test("Response time is less than 200ms",function () {

  pm.expect(pm.response.responseTime).to.be.below(200);

});

下面在apply接口中加入上面的检查点:

此时,可以发现运行结果饱满了很多,不单单是接口的执行,还有相应的检查点判断,如上为apply接口设置的检查点定时pass的,这样的话,后续接口发生变更,想要验证接口是否满足约束,直接运行次检查点案例即可;

 

 

posted on 2018-12-28 22:10  测试冰  阅读(1974)  评论(0编辑  收藏  举报