接口测试—知识速查(Postman)

文章目录

  • 接口测试
    • 1. 概念
    • 2. 原理
    • 3. 测试流程
    • 4. HTTP协议
      • 4.1 URL的介绍
      • 4.2 HTTP请求
        • 4.2.1 请求行
        • 4.2.2 请求头
        • 4.2.3 请求体
        • 4.2.4 完整的HTTP请求示例
      • 4.3 HTTP响应
        • 4.3.1 状态行
        • 4.3.2 响应头
        • 4.3.3 响应体
        • 4.3.4 完整的HTTP请求示例
    • 5. RESTful接口规范
    • 6. 测试用例的设计思路
      • 6.1 单接口测试
      • 6.2 多接口测试
    • 7 自动化框架的设计思路
    • 7.测试工具(Postman)
      • 7.1 Postman 断言
        • 7.1.1 响应状态码断言
        • 7.1.2 包含指定字符串断言
        • 7.1.3 JSON数据断言
        • 7.1.4 请求头断言
      • 7.2 Postman 环境变量
        • 7.2.1 全局变量/公有变量
        • 7.2.2 局部变量/私有变量
      • 7.2 Postman 关联
      • 7.3 Postman 请求前置脚本
      • 7.3 Postman 参数化
      • 7.4 Postman 报告(Newman)
        • 7.4.1 安装步骤
        • 7.4.2 运行步骤
      • 7.5 Tips小提示
        • 7.5.1 使中文可以正常显示提供的方法
    • 面试题
      • Cookie,Session,Token的区别


接口测试

1. 概念

接口可以分为软件接口和硬件接口 。

硬件接口:是指同一计算机不同功能层之间的通信规则称为接口。可以理解为负责连接外部设备的入 口,传输数据的端口,比如usb接口。

软件接口:就是指程序中具体负责在不同模块之间传输或接受数据并做处理的类或者函数。(数据交互的通道)

2. 原理

模拟客户端向服务器发送请求,服务器接收请求后进行相应的业务处理,并向客户端返回响应数据,检查响应数据是否符合预期。

  • 请求:是否正确,默认请求成功是200(GET),如果请求错误也能返回404、500等。
  • 检查:返回数据的正确性与完整性
  • 安全性:接口一般不会暴露在网上任意被调用,需要做一些限制,比如次数限制

3. 测试流程

1、需求分析:主要依据需求文档

2、接口文档解析:一般是由开发人员编写接口文档(API文档)

3、设计测试用例

4、执行测试:使用接口测试工具实现通过编写代码实现

5、接口缺陷管理与跟踪

6、生成测试报告

7、接口自动化持续集成

4. HTTP协议

  • HTTP:(HyperText Transfer Protocol)超文本传输协议,是一个基于请求与响应模式的、应用层的协议,也是互联网上应用最为广泛的一种网络协议。

4.1 URL的介绍

  • Uniform Resource Locator 统一资源定位符,是互联网上标准资源的地址。HTTP使用URL来建立连接和传输数据。

https://www.baidu.com/s?wd=软件&测试

1、协议部分:“https”,常见的协议有HTTP,HTTPS、FTP等

2、域名部分:“www.baidu.com”,也可以使用IP地址作为域名使用

3、端口部分:“8080”,端口可以省略,默认端口(HTTP:80,HTTPS:443,FTP:21)

4、资源路径部分:“/s”

5、查询参数部分:“?wd=软件&测试”,可以允许有多个参数,多个之间用“&”作为分隔符

4.2 HTTP请求

  • http请求由三部分组成,分别是:请求行请求头请求体

4.2.1 请求行

  • 请求行包含请求方法请求目标HTTP协议版本

  • 常用请求方法:

    GET:从服务器获取资源(一项或多项)。

    POST:在服务器新建一个资源。

    PUT:在服务器更新资源(客户端提供改变后的完整资源) 。

    DELETE:从服务器删除资源。

  • 示例:

    GET /index.html HTTP/1.1

4.2.2 请求头

  • 请求头包含了关于请求的附加信息,如请求的主机内容类型认证信息等。

  • 常见的请求头:Host、Content-Type、Authorization等。

  • Content-Type:请求体数据类型

    text/html:HTML格式

    image/jpeg:jpg图片格式

    application/json:JSON数据格式

    application/x-www-form-urlencoded: 表单默认的提交数据格式

    multipart/form-data:在表单中进行文件上传时使用

  • 示例:

    Host: www.example.com
    Content-Type: application/json
    Authorization: Bearer token

4.2.3 请求体

  • 请求体是可选的,通常在使用POST或PUT方法时使用,用于向服务器发送数据。请求体可以包含表单数据JSON数据等。

  • 示例:

    {
    “name”: “John”,
    “age”: 25
    }

4.2.4 完整的HTTP请求示例

GET /index.html HTTP/1.1

Host: www.example.com

Content-Type: application/json

Content-Length: 34

Authorization: Bearer token

{
“name”: “John”,
“age”: 25
}

4.3 HTTP响应

  • http响应由三部分组成:状态行响应头响应体

4.3.1 状态行

  • 状态行包含协议版本号状态码状态消息三部分。

  • 状态码有三位数字组成,第一个数字定义了响应的类别。

  • 状态码含义:

    1xx 信息性响应,一般是告诉客户端,请求已经收到了,正在处理,别急…

    2xx 处理成功响应,一般表示:请求收悉、我明白你要的、请求已受理、已经处理完成等信息.

    3xx 重定向响应,它让客户端再发起一个请求以完成整个处理。

    4xx 处理发生错误,责任在客户端,如客户端的请求一个不存在的资源,客户端未被授权,禁止访问等。

    5xx 处理发生错误,责任在服务端,如服务端抛出异常,路由出错,HTTP版本不支持等。

  • 常见响应状态码:

状态码状态消息说明
200OK服务器成功返回用户请求的数据
201CREATED用户新建或修改数据成功
204NO CONTENT用户删除数据成功
301Moved Permanently被请求的资源已永久移动到新位置
302Move Temporarily被请求的资源临时性移动到新位置
400Bad Request客户端请求有语法错误,不能被服务器所理解
401Unauthorized未授权的(未登录)
403Forbidden表示用户得到授权,但是访问是被禁止的
404Not Found请求资源不存在
500INTERNAL SERVER ERROR服务器发生错误,用户将无法判断发出的请求是否成功
503Server Unavailable服务器当前不能处理客户端的请求,一段时间后可能恢复正常
  • 示例:

    HTTP/1.1 200 OK

4.3.2 响应头

  • 响应头包含服务器的基本信息数据的描述(内容长度(Content-Length)、内容类型(Content-Type)、连接状态(Connection)、编码方式(charset)等等)。

  • 示例:

    Server: Apache/2.2.14 (Win32)

    Content-Length: 88

    Content-Type: text/html

    Connection: Closed

4.3.3 响应体

  • 响应的消息体,数据包含普通文本XMLJSONHTML源码等等。

  • 示例:

    ​ Hello World!

4.3.4 完整的HTTP请求示例

HTTP/1.1 200 OK

Date: Mon, 27 Jul 2009 12:28:53 GMT

Server: Apache/2.2.14 (Win32)

Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT

Content-Length: 88

Content-Type: text/html

Connection: Closed

​ Hello World!

5. RESTful接口规范

  • RESTful :一种网络应用程序的设计风格和开发方式,提供了一组设计原则和约束条件。
  • 示例:
操作请求方式URL成功状态码
查询某个用户GEThttp://127.0.0.1:8080/myweb/users/1200
查询所有用户GEThttp://127.0.0.1:8080/myweb/users200
添加用户POSThttp://127.0.0.1:8080/myweb/users201
修改用户PUThttp://127.0.0.1:8080/myweb/users/1201
删除用户DELETE查询某个用户http://127.0.0.1:8080/myweb/users/1204
  • 特点:
    • 请求 API 的 URL 用来定位资源
    • 通过标准HTTP方法对资源进行增删改查操作
    • 利用HTTP状态码返回状态信息

6. 测试用例的设计思路

  • 接口功能测试:验证接口功能是否按照接口文档实现(输入+处理+输出)

6.1 单接口测试

  • 正向功能:(通过性测试) 必填参数(p2),全部参数(p2),组合参数。

  • 反向测试:(异常测试)

    • 参数异常:多参、少参、无参、错误参数
    • 数据异常:数据为空(p3)、长度不符(p3)、类型不符(p3)、错误数据、过期数据
    • 业务数据异常:结合业务功能考虑输出的各种异常返回情况(业务数据不合理)(p3)

6.2 多接口测试

  • 业务场景功能测试(站在用户角度考虑常用的使用场景)接口之间数据依赖

7 自动化框架的设计思路

  1. 搭建基础框架——整理项目目录。
  2. 通用功能类封装——封装通用功能,如数据库工具类等。
  3. 接口对象封装与调用——封装接口AOI对象,用pytest编写脚本调用。
  4. 测试数据参数化——测试数据json文件设计,参数化实现。
  5. 用例组织执行——执行测试用例,生成测试报告。

7.测试工具(Postman)

7.1 Postman 断言

  • 作用:让Postman工具代替人工自动判定预期结果和实际结果是否一致。

7.1.1 响应状态码断言

  • 模板名称:Status code: Code is 200
  • 模板内容
// 判断响应状态码是否等于200
pm.test("Status code is 200", function () {
    pm.response.to.have.status(200);
});

// 解释说明:
pm.test(参数1:字符串-测试断言名称,参数2:回调函数-具体断言语句)
pm.response.to.have.status(code:Number);	判断是否含有指定状态码

7.1.2 包含指定字符串断言

  • 模板名称:Response body: Contains string
  • 模板内容
// 判断响应结果是否包含指定字符串
pm.test("Body matches string", function () {
	pm.expect(pm.response.text()).to.include("string_you_want_to_search");
});

// 解释说明:
pm.expect()			// 接受实际结果
.to					// 连接符,用于连接断言与判断
.include()			// 用于指定断言方式和预期结果
pm.response.text()	// 获取响应结果的文本

7.1.3 JSON数据断言

  • 模板名称:Response body: JSON value check
  • 模板内容
// 校验响应的JSON数据
pm.test("Your test name", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.value).to.eql(100);
});

// 解释说明:
pm.response.json()	// 获取响应结果的JSON数据
pm.expect(json对象的属性)			// 接受实际结果
.to.eql()			// 用于指定断言方式和预期结果

7.1.4 请求头断言

  • 模板名称:response headers:content type header check
  • 模板内容
// 校验请求头的属性
pm.test("Content-Type is present", function () {
    pm.response.to.have.header("Content-Type");
});

pm.response()				// 获取响应对象
.to.have.header(请求头属性)	// 用于指定断言方式和预期结果

7.2 Postman 环境变量

  • 一套环境中,变量不能重复,各个环境变量之间,变量名可以重复,只对选择了对应环境的测试集生效。

  • 环境的分类:开发环境、测试环境、生产/线上环境

  • 应用场景

    1. url地址

    2. header

    3. body

    注意:别忘了添加引号包裹,postman的特殊语法

  • 调用:{{变量名}}

7.2.1 全局变量/公有变量

  • 作用范围:针对postman下面所有测试集均生效
  • Globals
  • 代码获取全局变量
# 获取全局变量
pm.globals.get("全局变量");
# 设置全局变量
pm.globals.set("全局变量", "变量值")

7.2.2 局部变量/私有变量

  • 作用范围:针对某个环境下面所有测试集
  • Variable
  • 代码获取私有变量
# 获取私有变量
pm.environment.get("私有变量");
# 设置私有变量
pm.environment.set("私有变量", "变量值")

注意:如果私有变量名与全局变量名相同,优先执行私有变量

7.2 Postman 关联

  • 后一个接口的请求需要依赖前一个接口的响应数据,一般通过全局变量或者环境变量来进行参数在接口之间的传递。
  • 流程图

在这里插入图片描述

7.3 Postman 请求前置脚本

  • 在Pre-request Script页签编写,在请求发送之前被执行。
// 生成随机数 0到1之间的小数
var ran = Math.random()

// 把刚刚的随机数放入到全局变量中
pm.globals.set("ran_key", ran);

7.3 Postman 参数化

  • 场景:测试脚本中仅测试数据不一样,使用参数化提高脚本复用。

  • 步骤

    1. 测试数据保存在数据文件单独维护

    2. 引用数据文件实现脚本循环调用

  • 准备数据文件

# CSV文件
username,admin
username,
# json文件
[
    {"username":"admin"},
    {"username":""}
]
  • 引用数据文件数据:

    1. 请求参数中获取:

    引用相关对象的keyeg:{{username}}

    1. 代码中获取:

    Postman内置data对象引用key
    eg. data.status

7.4 Postman 报告(Newman)

7.4.1 安装步骤

  1. 先下载Node.js

    https://nodejs.org/en/

  2. 安装NodeJs

    打开cmd, 输入node, 如果没有报错, 说明node安装成功。

  3. 安装newman

    打开cmd, 输入npm install -g newman

  4. 通过查看newman版本测试安装是否成功

    打开cmd, 输入newman -v, 出现版本信息即安装成功

  5. 安装newman-reporter-html

    打开cmd,输入:npm install -g newman-reporter-html

7.4.2 运行步骤

  1. 保存的文件目录(包含数据文件、测试集、局部变量、全局变量),cmd进入命令行黑窗口

    注意:文件名不要有中文,空格等。

  2. 运行测试文件

    格式

    newman run 测试脚本文件 -e 环境变量文件 -g 全局变量文件 -d 测试数据文件 -r html --reporter-html-export contract/contract.html

    命令

    newman run postman_collection.json -e postman_environment.json -g postman_globals.json -d data.json -r html --reporter-html-export contract/contract.html

    解释

    run 测试脚本文件:表示要执行的postman脚本,及导出的测试集

    -e 环境变量文件:指定脚本中依赖的环境变量文件的路径

    -g 全局变量文件:指定脚本中依赖的全局变量文件的路径

    -d 测试数据文件:指定脚本中依赖的测试数据文件的路径

    –reporter-html-export haha/hehe.html:代表生成的位置和名字

7.5 Tips小提示

7.5.1 使中文可以正常显示提供的方法

var UTFTranslate = {
ReChange:function(pValue){
return unescape(pValue.replace(/&#x/g,'%u').replace(/\\u/g,'%u').replace(/;/g,''));
}
};
const $ = cheerio.load(responseBody);  // 把响应结果保存 
var mydata =  $("title").html();
mydata = UTFTranslate.ReChange(mydata); // 调用一开始的翻译函数

面试题

Cookie,Session,Token的区别

  • Cookie:是一种在服务器产生在客户端保存数据的机制,通常用于记录用户登录状态、购物车信息等。Cookie可以设置过期时间,也可以设置为只在特定域名下有效。
  • Session:是一种在服务器产生在服务器端保存数据的机制,通常用于记录用户登录状态、购物车信息等。Session可以在多个请求之间共享数据,但是需要通过加密等方式保证安全性。
  • Token:是一种在服务器产生在客户端保存数据,用于身份验证的机制,通常用于API接口的身份验证。Token可以通过加密等方式保证安全性,并且可以在多个请求之间共享数据。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/61772.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring boot 集成 Skywalking 配置 || Skywalking 打不开【已解决】

一、Skywalking官网 Apache SkyWalking 1.下载Skywalking APM (如果下载最新的,双击打开闪退,选老点的版本) 2. 下载 Skywalking Agents 如果下载太慢,建议复制下载链接,然后用下载器下载,比…

BeanFactory和ApplicationContext容器

1.BeanFactory容器 在Spring容器中,BeanFactory是IOC容器中的最顶级的接口,是最基础的版本,里面定义了管理bean的基本方法,如:获取bean、判断是否存在等等方法。 BeanFactory下面有很多的实现类,各有职责&…

js:使用LetterAvatar通过canvas实现浏览器中生成字母头像

实现效果 LetterAvatar的原理就是利用了浏览器对象canvas 在线体验:https://mouday.github.io/tools/pages/letter-avatar/index.html LetterAvatar.js 完整代码 /** LetterAvatar* * Artur Heinze* Create Letter avatar based on Initials* based on https:/…

保留网络:大型语言模型的Transformer继任者

原文信息 原文题目:《Retentive Network: A Successor to Transformer for Large Language Models》 原文引用:Sun Y, Dong L, Huang S, et al. Retentive Network: A Successor to Transformer for Large Language Models[J]. arXiv preprint arXiv:2…

装饰器模式(C++)

定义 动态(组合)地给一个对象增加一些额外的职责。就增加功能而言,Decorator模式比生成子类(继承)更为灵活(消除重复代码&减少子类个数)。 一《设计模式》 GoF 装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能&#xf…

MongoDB 6.0.8 安装配置

一、前言 MongoDB是一个基于分布式文件存储的数据库。由C语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。在高负载的情况下,添加更多的节点,可以保证服务器性能。 MongoDB 将数据存储为一个文档,数据结构由键值(key>value…

【Linux:线程池】

文章目录 1 线程池概念2 第一个版本的线程池3 第二个版本的线程池4 第三个版本的线程池5 STL中的容器以及智能指针的线程安全问题6 其他常见的各种锁7 读者写者问题(了解) 1 线程池概念 一种线程使用模式。线程过多会带来调度开销,进而影响缓存局部性和整体性能。而…

【绪论0】

#pic_center R 1 R_1 R1​ R 2 R^2 R2 目录 知识框架No.0 引言No.1 操作系统的概念功能和定义一、操作系统的概念和定义1、电脑的演变 二、操作系统的功能和目标 No.2 操作系统的特征一、并发二、共享三、虚拟四、异步 No.3 操作系统的发展与分类一、手工操作阶段二、批处理阶段…

elementui Cascader 级联选择使用心得

相信大家对于elementui并不陌生,作为适配Vue的优秀UI框架之一,一直被所有的开发者痛并快乐着。今天要记录的就是里边的主角之一Cascader。 首先先介绍一下Cascader ---> 当一个数据集合有清晰的层级结构时,可通过级联选择器逐级查看并选择…

IDEA超强XSD文件编辑插件-XSD / WSDL Visualizer

前言 XSD / WSDL Visualizer可以简化XML架构定义(XSD)和WSDL文件编辑过程; 通过使用与IntelliJ无缝集成的可视化编辑器,转换处理XSD和WSDL文件的方式。告别导航复杂和难以阅读的代码的挫败感,迎接流线型和直观的体验。 插件安装 在线安装 IntelliJ IDE…

6.物联网操作系统信号量

一。信号量的概念与应用 信号量定义 FreeRTOS信号量介绍 FreeRTOS信号量工作原理 1.信号量的定义 多任务环境下使用,用来协调多个任务正确合理使用临界资源。 2.FreeRTOS信号量介绍 Semaphore包括Binary,Count,Mutex; Mutex包…

【面试题】位图

文章目录 位图如何添加数据如何删除数据代码实现给100亿个整数,如何找到只出现一次的数字代码实现给两个文件,分别有100亿个整数,但只有1g内存,如何找到文件的交集?1个文件有100亿个int,1G内存,…

EventBus 开源库学习(一)

一、概念 EventBus是一款在 Android 开发中使用的发布-订阅事件总线框架,基于观察者模式,将事件的接收者和发送者解耦,简化了组件之间的通信,使用简单、效率高、体积小。 一句话:用于Android组件间通信的。 二、原理…

插入排序讲解

插入排序(Insertion-Sort)一般也被称为直接插入排序。对于少量元素的排序,它是一个有效的算法。插入排序是一种最简单的排序方法,它的基本思想是将一个记录插入到已经排好序的有序表中,从而一个新的、记录数增1的有序表…

【Linux命令详解 | pwd命令】Linux系统中用于显示当前工作目录的命令

文章标题 简介一,参数列表二,使用介绍1. pwd命令的基本使用2. pwd命令中的参数3. pwd命令的工作机制4. pwd命令的实际应用 总结 简介 pwd命令是Linux中的基础命令之一,使用该命令可以快速查看当前工作目录。在掌握Linux命令时,pw…

golang函数传参——值传递理解

做了五年的go开发,却并没有什么成长,都停留在了业务层面了。一直以为golang中函数传参,如果传的是引用类型,则是以引用传递,造成这样的误解,实在也不能怪我。我们来看一个例子,众所周知&#xf…

单例模式(C++)

定义 保证一个类仅有一个实例,并提供一个该实例的全局访问点。 应用场景 在软件系统中,经常有这样一些特殊的类,必须保证它们在系统中只存在一个实例,才能确保它们的逻辑正确性、以及良好的效率。如何绕过常规的构造器,提供一种…

微信小程序iconfont真机渲染失败

解决方法: 1.将下载的.woff文件在transfonter转为base64, 2.打开网站,导入文件,开启base64按钮,下载转换后的文件 3. 在下载解压后的文件夹中找到stylesheet.css,并复制其中的base64 4. 修改index.wxss文…

Netty:当Channel将数据发送成功以后,存放发送数据的ByteBuf会被自动释放

说明 使用Netty框架编程,当Channel将数据发送成功以后,存放发送数据的ByteBuf会被自动释放。 为了进行验证,我们可以在发送数据前,通过io.netty.buffer.ByteBuf的refCnt()函数看看引用计数,通过Channel发送成功以后再…