『Postman入门万字长文』| 从工具简介、环境部署、脚本应用、Collections使用到接口自动化测试详细过程

简介: 『Postman入门万字长文』| 从工具简介、环境部署、脚本应用、Collections使用到接口自动化测试详细过程

1 Postman工具简介

  • 工具官网信息,请直接搜索即可,这里不赘述:
    在这里插入图片描述
  • Postman是一个比较流行的、功能强大的可完成网页调试和模拟发送HTTP请求的工具或者插件;
  • 主要使用人员比较广,像测试做接口测试,开发进行前后端数据调试等;
  • 一些功能和优点:

①不仅可以用做chrome的插件,而且可以进行独立安装使用;
②只要登陆后,所有的历史请求数据都可以进行自动同步;
③使用本地化安装后的Postman工具比较强大,且基本都是免费的。
④支持跨平台MAC、Windows、Linux等。

2 Postman安装

  • 直接进入postman官网
  • 选择对应的平台下载即可,本位是windows平台:
    在这里插入图片描述
  • 按照步骤一步一步进行安装即可;
  • 安装完会进入登陆页面,这个看个人需要,需要需要记住历史数据,可以登陆,否则直接进入工具即可。

3 Postman界面说明

  • 进入到主界面后,点击【NEW】会有如下界面:
    在这里插入图片描述
  • 可以看到有几个选项卡,说明如下:
选项卡 说明
Create New 请求创建、集合的创建以及环境变量的创建等
Templates 模板配置,不设置即为默认配置
API Network 网络上的公共API可参考

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4 一个简单请求

4.1 请求示例

  • 我们继续使用禅道的一个接口,如下:
    在这里插入图片描述
  • 请求数据为:
# url:http://127.0.0.1/zentao/api.php/v1/对应API接口名称

data = {
   
   "account": "admin", "password": "ZenTao123456"}

4.2 请求过程

  • 创建一个Request请求;
    在这里插入图片描述
  • 填写请求名,请求描述,点击【save】,即可创建一个文件夹:
    在这里插入图片描述
  • 填写请求方式和请求地址:
    在这里插入图片描述
  • 填写请求头部信息(根据实际接口数据填写):
    在这里插入图片描述
  • 填写请求body体,注意数据格式:
    在这里插入图片描述
  • 点击【send】查看返回信息:
    在这里插入图片描述

    5 Postman其他操作

    5.1 import

  • 如图有个import按钮:
    在这里插入图片描述
  • 这个功能主要是导入其它的已经导出的postman的脚本;
    在这里插入图片描述
  • 导出的文件一般都是Json格式的,我们直接点击图中的【Upload Files】导入即可;
  • 如果是导入多个脚本,我们可以从指定的文件夹导入,点击【Folder】即可;
    在这里插入图片描述

  • 如果是从云共享导入,直接点击【Link】,输入对应的URlAPI-KEY授权的URL
    在这里插入图片描述

  • 导入后会在左侧的【Collections】中显示:
    在这里插入图片描述

    5.2 History

  • History其实就是接口请求的历史数据,即使用postman请求过的数据都会在这显示;
    在这里插入图片描述

  • 然后点击左侧列表中的历史接口,详细信息会显示在右侧:
    在这里插入图片描述

    5.3 Environment

  • Environment主要是用来设置当前Request发送时的使用环境;
    在这里插入图片描述

  • 这里的环境设置其实就是一些key-value
  • 我们点击图中的环境管理按钮,即可进入环境的设置界面:
    在这里插入图片描述
    在这里插入图片描述

  • 点击【Add】可以新增一些环境信息;
    在这里插入图片描述

  • 设置后可以在请求中直接引用变量,方法是{ {变量名}}。先需要切换环境,然后在参数中直接引用,如下:

# 环境切换为:login_url
# 请求地址的ip使用如下:http://{
   
   {ip}}/v1/tokens

在这里插入图片描述

5.4 Global

  • 单击图中的图标可以看到选择的Environment以及其他的Global中的变量:
    在这里插入图片描述
    在这里插入图片描述
  • 关于EnvironmentGlobal区别是Environment可以保存多个,而Global只能保存一组数据;保留在Global中的key-value可以被所有的请求使用,但是一个请求只能选择一个Environment
    在这里插入图片描述
  • 我们引用下Global中变量试试:
    在这里插入图片描述

    5.5 其他变量

  • 除了以上两个EnvironmentGlobal变量外,还有local、data、Collection变量;
  • Collection变量在 collection中设置,在当前的Collection中生效;
  • data变量表示的是引用外部文件,比如CSVJSON文件等等,主要用于参数化;
  • local变量是在本地生效;
  • 关于变量的作用域可以这么表示下(手画的~~~):
    在这里插入图片描述

    6 如何在postman中使用脚本?

    6.1 Pre-request Script和Tests

  • 在图中可以看到Pre-request ScriptTests这两个选项是需要设置脚本的;
    在这里插入图片描述
  • Pre-request Script表示请求之前需要执行的脚本;
  • Tests表示请求之后需要执行的脚本;
  • 点击对应的选项,右侧会显示常用的脚本设置,点击后可直接生成对应的脚本;
    在这里插入图片描述

    6.2 pm.info

  • 脚本设计主要是基于pm对象,通过这个对象可获取到正在执行脚本的所有信息;
  • 比如可访问正在发送请求的副本信息、响应信息、变量信息等等;
  • pm.info对象是获取正在执行的脚本的相关信息,具体如下:
方法 说明 类型
pm.info.eventName 脚本是在哪个脚本栏中执行的 字符串
pm.info.iteration 当前运行迭代的次数 数值
pm.info.iterationCount 计划运行的迭代总次数 数值
pm.info.requestName 返回请求名 字符串
pm.info.requestId 返回请求ID 字符串
  • 示例如下:
console.log(pm.info.eventName);
console.log(pm.info.requestName);

在这里插入图片描述

6.3 pm.globals

  • 常用的方法如下:
方法 说明
pm.globals.has 验证是否存在某全局变量
pm.globals.get 获取执行全局变量的值
pm.globals.set 设置全局变量
pm.globals.unset 清除指定的全局变量
pm.globals.toObject 将全局变量以对象的方式输出
pm.globals.clear 清除全局变量
  • 简单看个示例:
console.log(pm.globals.has("account"));
console.log(pm.globals.get("password"));
console.log(pm.globals.toObject());

在这里插入图片描述

6.4 pm.environment

  • pm.environment环境变量对象,可以获取环境变量信息;
  • 常用方法如下:
方法 说明
pm.environment.has 检测环境变量是否包含某个变量
pm.environment.get 获取环境变量的值
pm.environment.set 设置环境变量
pm.environment.unset 清除指定的环境变量
pm.environment.toObject 将环境变量以对象的方式输出
pm.environment.clear 清除环境变量
  • 示例如下:
console.log(pm.environment.has("account"));
console.log(pm.environment.get("password"));
console.log(pm.environment.toObject());

在这里插入图片描述

6.5 pm.variables

  • pm.variables也是变量,不同于全局和环境变量,变量的优先级为迭代数据<环境变量<全局变量;
  • 常用方法是:pm.variables.get获取变量中的某个值;
  • 示例如下:
console.log(pm.variables.get("account"));

在这里插入图片描述

6.6 pm.request

  • pm.request对象获取请求对象;
  • Pre-request Scriptpm.request对象表示将要发送的请求;
  • Tests中的pm.request对象表示上一个发送的请求;
  • 常用方法:
方法 说明
pm.request 获取当前发送请求的全部headers
pm.request.url 获取当前发送请求的url
pm.request.headers 以数组的方式返回当前请求中的headers
  • 示例如下:
console.log(pm.request);
console.log(pm.request.url);
console.log(pm.request.headers);

在这里插入图片描述

6.7 pm.response

  • pm.response对象获取响应信息;
  • 常用方法如下:
方法 说明
pm.response.code 请求返回的状态码
pm.response.reason() 当前请求成功返回OK
pm.response.headers 请求成功后的responseheaders
pm.response.responseTime 获取请求时间
pm.response.text() 以文本的方式获取响应中的body
pm.response.json() 将body中的内容解析为json对象
  • 示例如下:
console.log(pm.response.code);
console.log(pm.response.reason());
console.log(pm.response.headers);
console.log(pm.response.responseTime);
console.log(pm.response.text());

在这里插入图片描述

6.8 pm.response.to-划重点:这个其实就是断言处理

  • pm.response.to对象主要是完成用例的断言操作;
  • 有两种方式:hava对象和be对象;
  • hava对象常用方法如下:
方法 说明
pm.response.to.have.status(code:Number) 根据状态码判断响应是否成功
pm.response.to.have.status(reason:String) 根据返回的状态值判断
pm.response.to.have.header(key:String) 根据response中的headerskey判断
pm.response.to.have.header(key:String,optionalValue:String) 根据response中的headerskeyvalue判断
pm.response.to.have.body() 返回的数据
pm.response.to.have.body(optionalValue:String) 根据响应返回的body内容判断
pm.response.to.have.body(optionalValue:RegExp) 根据响应返回的body进行正则判断
pm.response.to.have.body(optionalValue:JSON) 根据响应返回的body是否为json进行判断
  • be对象常用方法:
方法 说明
pm.response.to.be.info 响应码是否为1XX,是为真,否为假
pm.response.to.be.success 响应码是否为2XX,是为真,否为假
pm.response.to.be.redirection 响应码是否为3XX,是为真,否为假
pm.response.to.be.clientError 响应码是否为4XX,是为真,否为假
pm.response.to.be.serverError 响应码是否为5XX,是为真,否为假
pm.response.to.be.error 响应码是否为4XX或5XX,是为真,否为假
pm.response.to.be.ok 响应码是否为200,是为真,否为假
pm.response.to.be.accepted 响应码是否为202,是为真,否为假
pm.response.to.be.badRequest 响应码是否为400,是为真,否为假
pm.response.to.be.unauthorized 响应码是否为401,是为真,否为假
pm.response.to.be.forbidden 响应码是否为403,是为真,否为假
pm.response.to.be.notFound 响应码是否为404,是为真,否为假
pm.response.to.be.rateLimited 响应码是否为429,是为真,否为假
  • 示例如下:
pm.test(
    "状态码是201",function(){
   
   
        pm.response.to.have.status(201);
    }
);

在这里插入图片描述

这里需要特别注意:
1、以上这些方法不能直接在脚本写,需要引用一些函数;
2、完成断言的函数主要为:test和expect;
3、语法为:
pm.test("testName", specFunction)
pm.expect(assertion:*)

7 Collections应用

7.1 Collections简介

  • Collections主要是对请求的分组和分类;
  • 可将项目中的每个事件业务流串起来,或将相关的模块分类,保存在集合中,方便维护和管理。

7.2 Collections创建

  • 即就是创建集合,方便寻找、管理、执行和导出等操作;
  • 创建方式一:点击【New】-【Collections】即可:
    在这里插入图片描述
  • 创建方式二:左侧栏-【Collections】-【New Collections】:
    在这里插入图片描述
  • 参数说明:
    在这里插入图片描述
参数 说明
Name 集合名称
Description 集合描述
Authorization 授权类型
Pre-request Script 运行集合前需要执行的脚本
Tests 集合运行后需要执行的脚本
Variables 将变量添加到集合中

7.3 如何实现Collections共享?

  • 可以通过团队空间共享Collections
  • 创建好的Collections-右键-【Share Collection】:
    在这里插入图片描述
  • 注意:这个功能需要注册一个postman账号才能用,按照提示注册就行了,进入如下界面:
    在这里插入图片描述
  • 选择分享空间和团队,点击【Share and Continue】即可。

7.4 如何管理Collections?

  • 集合的浏览:左侧栏直接点击即可:
    在这里插入图片描述
  • 集合收藏:选择图中的符号后,就会进行收藏并置顶显示:
    在这里插入图片描述
  • 集合搜索:直接切换到Collections页面搜索栏搜索即可:
    在这里插入图片描述
  • 集合删除:选择结合后边的三个点,点击【delete】即可:
    在这里插入图片描述
  • 结合添加文件夹:点击集合后的三个点,点击【Add Folder】即可。

7.5 如何导入导出文件?

  • 导出Collection文件:选择集合-右键-【Export】:
    在这里插入图片描述
  • 导出和导入Environment文件:请求主界面-右键-【Manage Environment】:
    在这里插入图片描述
    在这里插入图片描述
  • Globals文件导出:在以上操作界面点击【Globals】-【Download as JSON】即可:
    在这里插入图片描述

7.6 Collections运行

  • 点击【Runner】进入运行界面,参数说明如下:
    在这里插入图片描述
  • 点击运行如下:
    在这里插入图片描述
目录
相关文章
|
6天前
|
测试技术 持续交付
探索软件测试中的自动化测试策略
随着软件开发周期的加速和市场需求的不断增长,传统的手动软件测试方法已难以满足现代软件开发的高效性和准确性要求。本文旨在探讨自动化测试在软件测试中的重要性、实施策略及其对提高软件质量的影响。通过分析自动化测试的优势与挑战,以及提供实用的自动化测试工具和框架选择指南,旨在帮助读者理解并应用自动化测试以提升软件开发效率和产品质量。
|
17天前
|
敏捷开发 测试技术 持续交付
探索软件测试中的自动化与持续集成
在快速迭代的软件开发环境中,自动化测试和持续集成(CI)已成为确保产品质量和加速交付的关键策略。本文将深入探讨自动化测试的基本原理、实施步骤以及它如何与持续集成流程相结合,以提高软件开发的效率和可靠性。我们将通过实际案例分析,展示自动化测试和CI的最佳实践,以及它们如何帮助企业实现更快的市场响应时间和更高的客户满意度。
56 16
|
19天前
|
jenkins 测试技术 持续交付
软件测试中的自动化与持续集成:提升效率与质量的关键
在快节奏的软件开发环境中,自动化测试和持续集成已经成为不可或缺的部分。本文将探讨自动化测试和持续集成的重要性,以及它们如何协同工作以提高软件开发的效率和质量。通过分析自动化测试的策略、工具选择以及持续集成的实践,我们将揭示这些技术如何帮助开发团队快速响应变化,减少错误,并加速产品上市时间。
|
18天前
|
人工智能 前端开发 测试技术
探索软件测试中的自动化框架选择与优化策略####
本文深入剖析了当前主流的自动化测试框架,通过对比分析各自的优势、局限性及适用场景,为读者提供了一套系统性的选择与优化指南。文章首先概述了自动化测试的重要性及其在软件开发生命周期中的位置,接着逐一探讨了Selenium、Appium、Cypress等热门框架的特点,并通过实际案例展示了如何根据项目需求灵活选用与配置框架,以提升测试效率和质量。最后,文章还分享了若干最佳实践和未来趋势预测,旨在帮助测试工程师更好地应对复杂多变的测试环境。 ####
41 4
|
18天前
|
机器学习/深度学习 人工智能 jenkins
软件测试中的自动化与持续集成实践
在快速迭代的软件开发过程中,自动化测试和持续集成(CI)是确保代码质量和加速产品上市的关键。本文探讨了自动化测试的重要性、常见的自动化测试工具以及如何将自动化测试整合到持续集成流程中,以提高软件测试的效率和可靠性。通过案例分析,展示了自动化测试和持续集成在实际项目中的应用效果,并提供了实施建议。
|
4天前
|
jenkins 测试技术 持续交付
软件测试中的自动化与持续集成
在现代软件开发过程中,自动化测试和持续集成已成为不可或缺的组成部分。本文将深入探讨自动化测试和持续集成的重要性、优势以及如何有效实施它们以提升软件质量和开发效率。通过具体案例分析,我们将展示这些技术如何在实际项目中发挥作用,并讨论其面临的挑战及应对策略。
17 3
|
7天前
|
测试技术 持续交付 API
探索软件测试中的自动化:从新手到专家
在软件开发的世界中,测试是确保产品质量的关键步骤。本文将通过一个初学者的视角,介绍如何从零开始构建自动化测试框架,并逐步深入到更复杂的测试场景。我们将探讨自动化测试的优势、工具选择、以及如何有效地实施和扩展自动化测试策略。无论你是刚入门的软件测试新手,还是希望提升自动化测试技能的开发人员,这篇文章都将为你提供实用的指导和启示。
|
4天前
|
测试技术 持续交付 数据安全/隐私保护
软件测试的艺术与科学:探索自动化测试框架
在软件开发的世界中,测试是确保产品质量的关键环节。本文将深入探讨自动化测试框架的重要性和实现方法,旨在为读者揭示如何通过自动化测试提升软件测试效率和准确性。我们将从测试的基本概念出发,逐步引导读者了解自动化测试框架的设计和实施过程,以及如何选择合适的工具来支持测试活动。文章不仅提供理论知识,还将分享实用的代码示例,帮助读者将理论应用于实践。无论你是测试新手还是经验丰富的开发者,这篇文章都将为你打开一扇通往更高效、更可靠软件测试的大门。
|
14天前
|
敏捷开发 Java 测试技术
软件测试中的自动化策略与实践
在快速迭代的软件开发周期中,自动化测试是确保产品质量和提升开发效率的关键。本文将深入探讨自动化测试的重要性,介绍实用的自动化测试框架,并通过一个具体的代码示例,说明如何实现一个简单的自动化测试脚本。
38 12
|
9天前
|
机器学习/深度学习 人工智能 自然语言处理
智能化软件测试:AI驱动的自动化测试策略与实践####
本文深入探讨了人工智能(AI)在软件测试领域的创新应用,通过分析AI技术如何优化测试流程、提升测试效率及质量,阐述了智能化软件测试的核心价值。文章首先概述了传统软件测试面临的挑战,随后详细介绍了AI驱动的自动化测试工具与框架,包括自然语言处理(NLP)、机器学习(ML)算法在缺陷预测、测试用例生成及自动化回归测试中的应用实例。最后,文章展望了智能化软件测试的未来发展趋势,强调了持续学习与适应能力对于保持测试策略有效性的重要性。 ####