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的,这样的话,后续接口发生变更,想要验证接口是否满足约束,直接运行次检查点案例即可;

 

玩转postman(一)-----基础的更多相关文章

  1. Postman的基础使用

    postman的基础功能,官方文档介绍的是相当啰嗦,所以笔者这里先简单介绍一下主界面,入门功能就都提到了.稍后我们再一一介绍基础功能的使用方法. Collections:在Postman中,Colle ...

  2. 《玩转Bootstrap(基础)》笔记

    基本的HTML模板 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  3. postman 的基础使用篇(一)

    简介 postman 是接口协作开发的优秀平台,可以用来进行接口设计.构建和调试,之前以chrome插件的形式,现在也有原生APP. 安装 Native app 通过链接 download page  ...

  4. postman接口测试基础知识

    接口文档访问地址:http://doc.nnzhp.cn/index.php?s=/6&page_id=8 1.什么是接口:从数据库里面取数据或是插入数据 接口测试:测接口一定要有接口文档-- ...

  5. 玩转Bootstrap(基础) -- (6.导航条基础)

    1.导航条样例 <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" ...

  6. postman 的基础使用

    https://blog.csdn.net/fxbin123/article/details/80428216

  7. 如何学习FPGA?FPGA学习必备的基础知识

    如何学习FPGA?FPGA学习必备的基础知识 时间:2013-08-12 来源:eepw 作者: 关键字:FPGA   基础知识       FPGA已成为现今的技术热点之一,无论学生还是工程师都希望 ...

  8. android基础小结

    (注:此小结文档在全屏模式下观看效果最佳) 2016年3月1日,正式开始了我的android学习之路. 最最开始的,当然是学习怎样搭载环境了,然而苦逼的我在win10各种坑爹的指引下还是安装了一个星期 ...

  9. 使用PostMan进行API自动化测试

    最近在进行一个老项目的升级,第一步是先将node版本从4.x升级到8.x,担心升级会出现问题,所以需要将服务的接口进行验证:如果手动输入各种URL,人肉check,一个两个还行,整个服务..大几十个接 ...

随机推荐

  1. [HTML]HTML隐藏文本框的四种方式

    .<input type="hidden" value=""></input>对所有的文本框都起作用(隐藏域,多用于存数据) .< ...

  2. 无外接键盘安装 raspberry pi 3B+ 安装系统

    从官网介绍看,当前raspbian和以前大家的记录略有不同,老的博客资料基本都是介绍下载raspbian,但现在raspbian已经不再维护镜像, raspbian系统开始由官方 pi foundat ...

  3. js滚动到指定位置

    序言:在网络上百度,关键字:“js div滚动到指定位置”,结果基本上大同小异!各种大神都给我们总结出来了四种滚动到指定位置的办法,可惜再下愚钝,每个都不会用,所以写了一个超级简单的方法来使初学者一看 ...

  4. DRF 认证、权限、限制

    DRF 认证.权限.限制   认证: 定义一个用户表和一个保存用户的Token表 # ======================day96======================= class ...

  5. Webservice 从客户端中检测到有潜在危险的 request.form值[解决方法]

    <system.web> <httpRuntime requestValidationMode="2.0" /> <pages validateReq ...

  6. [持续交付实践] pipeline使用:Shared Libraries

    前言 随着pipeline交付流水线在团队中的推广,使用pipeline脚本的job也迅速增加.虽然我们已经基于公司的技术栈特点做了一个尽可能通用的pipeline脚本样例,让搭建者只需要修改几个赋值 ...

  7. 常见java日志系统的搭配详解:关于slf4j log4j log4j2 logback jul jcl commons-logging jdk-logging

    先看一张图: 是不是有点晕, 晕就对了.这个仅仅是 slf4j 的情况,实际上, 我们不仅要接触到 slf4j ,有时候还会接触其他的日志系统.且看下文分解. 1 直接使用各个日志系统 1.1 直接使 ...

  8. docker swarm 部署服务时,限制服务启动后所在的机器

    借助容器技术,可以方便的在不同环境下部署服务,保证服务环境的一致性.docker swarm这个东西,可以方便的对容器进行编排管理. docker swarm集群中,有manager节点与worker ...

  9. 02-03 CSS快速入门

    css四种引入方式:test.html: p{ color: gold; font-size: 20px; } title.html: <!DOCTYPE html> <html l ...

  10. 性能测试进阶指南——基础篇之磁盘IO

    本文旨在帮助测试人员对性能测试常用指标做一个简单的讲解,主要包括CPU.内存.磁盘和网络带宽等系统资源,本文仅仅局限于Linux系统,Windows Server系统暂不做考虑. 使用iostat分析 ...