当前位置: 首页 > news >正文

接口测试基础

一、认识接口测试

9d9b3fd2f1544c0499b49d9e537d8e28.png


接口测试

接口:系统之间数据交互的通道。

  • 硬件接口

  • 软件接口


fae44ac390dc45beb611673d3f61d5b5.png


接口测试:基于不同的输入参数,校验接口响应数据与预期数据是否一致。


为什么要学接口测试?

  • 提前介入测试、尽早发现问题

  • 中级测试工程师必备技能

18783831634c41d7aebde6677981a2fb.png


接口测试学什么?

  • 接口测试用例设计

  • 工具实现接口测试

  • 代码实现接口测试

2e1dc4f6762a4a80a0cded669d4f12a6.png


二、项目介绍

项目介绍

  • 项目名称:客达天下

  • 项目类型:销售管理系统 (CRM)

  • 项目特点:

    • 前后端分离

    • 功能通用性强

a167a8aceb9940f193511c496b07af78.png


熟悉项目

  • 项目角色:销售人员、销售经理、财务人员等

  • 项目业务:线索管理、合同管理等

  • 项目技术:

99bbf24f42a74edc93a99c86ec3102a4.png


待测接口

 需求:完成管理业务及相关单位模块接口测试。
合同管理业务登录添加课程上传合同新增合同
课程管理模块添加课程修改课程查询课程删除课程

64691b5ce06b4f219690cea5d8939436.png


接口测试流程

920cb6735ed9403fb156d64110df72f1.png


三、HTTP协议

3296f7f3ad62407e8bd4e5a9e0380b77.png


URL

URL:是互联网上标准资源的地址,一般称为统一资源定位符。

组成:协议://hostname[:port]/path/ [?查询参数1 & 查询参数2]

示例:

8befb7f37ec9410c920d8d518ec2edd7.png


HTTP协议

HTTP:超文本传输协议,基于请求与响应的应用层协议

作用:规定了客户端与服务器之间信息传递规范,是二者共同遵守的协议。

组成:

  • HTTP请求:定义请求数据格式

    • 请求行、请求头、请求体

  • HTTP响应:定义响应数据格式

    • 状态行、响应头、响应体


HTTP —请求行

位置:请求数据第一行

作用:说明需求方法、访问的资源、协议版本

356de25b276a42cbb778ff5cfd73db15.png


常用请求方法:

  • GET:从服务器获取资源

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

  • PUT:在服务器更新资源

  • DELETE:从服务器删除资源


HTTP请求—请求头

位置:请求数据第二行到空白行之间

作用:通知服务器客户端请求信息

特点:请求头部由键值对组成,每行一对

baad76fdf1fc44e8afd8083c798539d4.png


Content-Type:请求体数据类型

  • text/html:HTML格式

  • image/jpeg:jpg图片格式

  • application/json:JSON数据格式

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

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


HTTP请求—请求体

位置:空白行之间的内容

作用:传输数据实体

注意:请求体常在POST、PUT方法中使用

常配合的请求头:Content-Type和Content-Length

140da9c1b9824df98642deadb0677e27.png


  • 请求报文中可以没有请求体数据


HTTP响应—状态行

位置:响应数据第一行

作用:描述服务器处理结果

内容:状态行由协议版本号、状态码、状态消息组成

84ab820e7f58454e978dc5e05c461273.png


状态码:三位数字组成,第一个数字定义响应类别

 1XX:提示信息2XX:成功3XX:重定向4XX:客户端错误5XX:服务端错误

HTTP响应—常见的响应状态码

54527f14ec3241e6a0a8c90b3189f393.png


HTTP响应—响应头

位置:第二行开始到空白行之间

作用:描述客户端要使用的一些附加信息

特点:响应头由键值对组成,每行一对

182d5437eec046ef98692fc41f08d5c3.png


HTTP响应—响应体

位置:响应数据空白行之后

作用:服务器返回的数据实体

特点:有图片、json、xml、html等多种类型

332b1001fa3843eabe23577ff5fec61a.png


案例:

5ef773462df44478b8a046cc38284b30.png


四、接口规范

接口规范

作用:让前端开发与后台接口开发人员更好的配合,提高工作效率

常见接口规范:

传统接口风格

 RESTful接口风格

3f5362ac41be4d59a27084dae7c30cdb.png


传统接口风格

示例:对用户进行操作的相关接口,包括增删改查

872a0594bc914974909f953afe8a6544.png


RESTful

RESTful:一种网络应用程序的设计风格和开发方式,提供了一组设计原则和约束条件。

示例:

d354d3dcc72f48c390761b809571e2a9.png


特点:

  • 请求 API 的 URL 用来定位资源
  • 通过标准HTTP方法对资源进行增删改查操作
  • 利用HTTP状态码返回状态信息

区别

c15ca0099f3545d7b00a819f8647485d.png


Postman测试步骤

9cf2b35dd45e43c7900f52c650c740dd.png


一、合同新增业务

e1b0aa6180164ceea04dfc55d421add9.png


二、找业务路径

3bd0a330e8654b758c7c6485494ba45d.png


三、解析接口文档

7d076ef7ee9e4ec0871b5dfe430eea01.png


四、编写接口测试用例

65bed71bdeb4408dbb7eeec6ede20fa7.png


总结

1aa0a52f09234a559ef741ec9d731ffc.png


Postman使用

一、Postman介绍

介绍:Postman是一款接口调试工具

特点:支持 Mac、Windows 和 Linux

下载:

 https://www.getpostman.com

4e72dfa8a7574b1dba07aa7a7d20e597.png


二、登录接口调式

获取验证码

 需求:使用postman访问验证码接口,并查看响应结果​地址:
​​​​​​​ http://kdtx-test.itheima.net/api/captchaimage​实现步骤1.设置请求方式2.输入接口地址3.点击发送请求4.查看响应结果

a37546fa92d248249cc43d5ef1d8fcf2.png


登录

 需求:使用Postman访问验证码接口,并查看响应结果说明:地址:http://kdtx-test.itheima.net/api/login方法:post请求数据:请求头:Content-Type:application/json请求体:["username": "admin","password": "admin 123","code":"2","uuid":"验证码接口返回结果中的数据值"]实现步骤:1.设置请求方式2.输入接口地址3.点击发送请求4.查看响应结果

156268fc6ece41779f96f1ba04821430.png


总结

d43638f592e3439ca9d6f56d73af3527.png


三、自动关联数据

问题:每次登录之前都需要手动复制验证码数据

思路:

6d2159a872a04f2687adbd6cbaf9f96f.png


自动关联数据

环境创建与选择

e313e7e586fb4dd8b8fbaa7169dc5b65.png


案例:使用自动关联技术,实现登录成功

需求:

 1.验证码接口:/api/captchaimage2.登录接口:/api/login登录接口请求体uuid字段 -> 验证码接口返回 uuid字段

分析:

 1.验证码接口响应体中提取uuidvar jsonData = pm.response.json();2.设置环境变量保存uuidpm.environment.set("var_name",value);3.登录接口引用uuid请求参数中引用: {{var_name}}

c3d04bd5a05d45539285a4c413f831da.png


总结

a02f7776a80d4652a9b5cda77048b06a.png


接口调式

一、添加课程接口调试

1b5f9b1b4af347869906186e54abe31b.png


二、上传合同接口调试

bd59ec39708b4330b827ee8fbaee850d.png


Postman调试合同上传接口

6ae6443169f34c8fbcab909fd1686aab.png


6c181f797d8f4f6abc3848555cb1272f.png


三、新增合同接口调试

添加合同接口调试

1a4f7e49ebf34950a1fe50c492c8f332.png

注意:

测试数据中的合同编号 contracNo 必须唯一。


查询合同列表接口调试

6af519951c844b1aa6604269e3150443.png


总结

6adc026629c04bac8a54929e64d548a3.png


Postman进阶

一、批量执行

735f7adb6c2e45388c47421b4e4d9634.png


Postman批量执行

作用:通过运行测试集的方式批量运行测试用例

步骤:

  1. 点击测试集中的 "Run" 按钮,批量运行测试用例

  2. 弹出 Collection Runner窗口,点击运行按钮

  3. 查看测试结果

638741ef8f524ed7bce683fdad430019.png


1d18dc21453f4f41bb077b8c3145e8ba.png


aa87e3335c0c4e88958c3bd99a6373bb.png


1f2e4449ce69418aadfb2cab9e797ac2.png


二、登录接口测试

d33b854278764f998d819a7e6964f400.png


案例:完成 KDTX项目登录接口用例设计

需求:已注册正确的用户名和密码,登录成功用户名或密码错误,登录失败,提示 "用户名或密码错误"需求:按照接口测试思路进行测试点分析从测试点转化为测试用例使用Postman进行接口测试

提取测试点

2d43ddda31064601b6e5dadb76397005.png


设计测试用例

227f2b07012040118b3426a1d5757c9f.png


步骤:

  • 点击测试集中的 "Add folder" 添加文件夹管理测试用例

  • 点击文件夹上的 "Add Request" 添加请求实现测试用例

27840e5900d748b99ccd9c308f53d33a.png


总结

1f0688c00cb146daa8eafec3c55869bc.png


三、Postman断言

Postman断言介绍

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

用法:

f45953d0f43c46c59faef46f06023796.png


Postman断言—响应状态码断言

模块名称: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);  // 判断是否包含指定的状态码

Postman断言—包含指定字符串断言

模块名称:Response body: Contains string

模块内容:

2c0520e836cf48c99c386ccc34133f94.png


Postman断言—JSON断言

模块名称:Response body: JSON value check

模块内容:

9fc5e4975b7f4a36acf8c66e1c75154a.png


6ddcbfd30c9d4db0887e015f110ff824.png


总结

4d9cb15bd17f47a7826d096ac4acb667.png


四、参数化

Postman参数化介绍

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

步骤:

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

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

c1667ebc3fac4846ad8d8038200b1e69.png


Postman参数化实现

准备数据文件

a34cd38b8e0e414297999a2492057189.png


引用数据文件数据

4b8a8246f4d34d81a01b3aa55a85607c.png


Postman参数化实现

选择数据文件:运行测试集时选择数据文件

99eaa54576124f728c272e90f0e4b157.png


5967f7bd6f014f9cb456e9c573aa579e.png


总结

490dd1ef95254a6fa6b67da2d54f8cba.png


课程项目实践

一、课程添加

课程添加接口文档

4c72e0153a9344cea8bc92cae9b8ffd0.png


9ed60101e90342b193315a44bd38f4b3.png


1.提取测试点

2343872678fb4131909c3fa8094cc30e.png


2.设计测试用例

1166e1678240409d82b857a1c3ab0ad1.png


3.使用Postman进行接口测试

步骤:

  • 点击测试集中的 "Add folder" 添加文件夹管理测试用例

  • 点击文件夹上的 "Add Request" 添加请求实现测试用例

ef6644dde608447f991d11dcb2416a58.png


总结

c686b6fbad4a407dab0e12015fc40e62.png


二、查询课程列表

查询课程列表接口文档

5f670219a3374ebbbd24aaeadb80ec96.png


5e7780fb4192447e9bbef1dd20679f78.png


提取测试点

b990c7e215c14ed089b6ec5763048baf.png


设计测试用例

8c6599f0b2b04215856de4a870b33256.png


三、课程修改

课程修改接口文档

0728926f09a6492f81a5e863fbfba3c6.png


50bd2efb5b9941c68de0b57694dd4f6f.png


提取测试点

572b9e1c6ed643bb9954eb5c70dab7a7.png


设计测试用例

eb0412698d734ebcb11aae8c4dbd8841.png


四、课程删除

课程删除接口文档

04739869d4c14774a4eceab4a5f67ad8.png


59dfd8a4c0064fb7a1aa6ec9e2e6d0bc.png


提取测试点

d789afb83b02421a9e92548f61742e6f.png


设计测试用例

f206f65daaee45d9b6ccedddb4c01ce7.png


 

相关文章:

接口测试基础

一、认识接口测试 接口测试 接口:系统之间数据交互的通道。 硬件接口 软件接口 接口测试:基于不同的输入参数,校验接口响应数据与预期数据是否一致。 为什么要学接口测试? 提前介入测试、尽早发现问题 中级测试工程师必备技能 接口测试学…...

为什么 from . import * 不会导入子模块

为什么 from . import * 不会导入子模块 在 Python 中,from . import * 并不会自动导入子模块。这是因为 import * 的行为是由模块的 __all__ 变量决定的。如果没有定义 __all__,它只会导入当前模块中定义的顶层变量和函数,而不会递归地导入…...

LangGPT结构化提示词编写实践

langGPT提示词 # Role: 浮点数比较助手 ## Profile - author: LangGPT - version: 1.0 - language: 中文 - description: 一个专门帮助用户进行浮点数比较的助手,确保LLM能够准确识别和对比浮点数。## Skills 1. 理解浮点数的结构和数值意义。 2. 精…...

React: class 和 style

一、class 1、在react中使用className属性来绑定类名 <div className"header flex-middle-middle">添加2个类名 </div>2、动态添加类名 <div className{item ${nameactive ? active : }}>动态添加active类名 </div>二、style 1、react中…...

【数据结构】包装类、初识泛型

&#x1f387;&#x1f389;&#x1f389;&#x1f389;点进来你就是我的人了 博主主页&#xff1a;&#x1f648;&#x1f648;&#x1f648;戳一戳&#xff0c;欢迎大佬指点&#xff01; 人生格言: 当你的才华撑不起你的野心的时候,你就应该静下心来学习! 欢迎志同道合的朋友…...

TCP客户端connect断线重连

文章目录 TCP客户端connect断线重连1、为什么要断线重连2、实现代码 TCP客户端connect断线重连 1、为什么要断线重连 客户端会面临服务器崩溃的情况&#xff0c;我们可以试着写一个客户端重连的代码&#xff0c;模拟并理解一些客户端行为&#xff0c;比如游戏客户端等. 考虑到…...

细说MCU用DMA改变DAC输出信号频率和改善输出波形质量的方法

目录 一、参考硬件 二、修改定时器参数改变输出波形频率 三、改善波形质量 四、代码修改 五、查看结果 一、参考硬件 本项目的软件硬件工程参考作者的其他文章&#xff1a;细说MCU用DMA实现DAC输出的方法-CSDN博客 https://wenchm.blog.csdn.net/article/details/14065…...

Java高级面试题

文章目录 Java高级特性Java 8 中的新特性有哪些&#xff1f;Lambda 表达式的用途是什么&#xff1f;Stream API 的工作原理是什么&#xff1f;Optional 类的作用是什么&#xff1f;什么是函数式接口&#xff1f;Java 9 之后的新特性有哪些&#xff1f; 并发编程Java中的线程池是…...

USART串口理论知识总结

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 USART串口理论知识总结 1、通讯的串行和并行1.串口采用发送数据代码并用printf重代码 1、通讯的串行和并行 1.串口采用发送数据代码并用printf重代码 #include <stdint.h…...

基于 HTML+ECharts 实现智慧景区数据可视化大屏(含源码)

构建智慧景区数据可视化大屏&#xff1a;基于 HTML 和 ECharts 的实现 随着旅游业的蓬勃发展&#xff0c;智慧景区的概念逐渐深入人心。通过数据可视化&#xff0c;景区管理者可以实时监控游客流量、设施使用情况以及环境状况&#xff0c;从而提升游客体验和管理效率。本文将详…...

vxe-table——实现切换页码时排序状态的回显问题(ant-design+elementUi中table排序不同时回显的bug)——js技能提升

之前写的后台管理系统&#xff0c;都是用的antdelement&#xff0c;table组件中的【排序】问题是有一定的缺陷的。 想要实现的效果&#xff1a; antv——table组件一次只支持一个参数的排序 如下图&#xff1a; 就算是可以自行将排序字段拼接到列表接口的入参中&#xff0c…...

SQL

SQL全称 Structured Query Language&#xff0c;结构化查询语言。操作关系型数据库的编程语言&#xff0c;定义了一套操作关系型数据库统一标准 。 SQL通用语法 SQL语句可以单行或多行书写&#xff0c;以分号结尾。SQL语句可以使用空格/缩进来增强语句的可读性。MySQL数据库的…...

maven archetype

1.简介 maven脚手架是为了创建一个项目模板&#xff0c;以后新建项目都能够复用该模板 maven中模板引擎使用的是velocity,在文件中可以使用它的语法获取变量等操作 2.实现 单模块脚手架实现 pom.xml <?xml version"1.0" encoding"UTF-8"?> &…...

浏览器打开抽奖系统html

<!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>在线抽奖 随机选取 自动挑选</title> <script src"https://libs.baidu.com/jquery/1.10.2/jquery.min.js"></script> <style> body {…...

微信小程序-使用Component方法代替Page方法构造页面

一.使用Component方法的前提条件 在小程序js文件里使用Component方法代替Page方法需要在json文件里面定义usingComponents属性 {"usingComponents": {} }二.注意事项 1.在page页面里使用的钩子函数和事件监听方法都需要写在methods对象里面 methods:{update(){thi…...

Spark SQL----DISTRIBUTE BY子句

Spark SQL----DISTRIBUTE BY子句 一、描述二、语法三、参数四、例子 一、描述 DISTRIBUTE BY子句用于根据输入表达式对数据进行重新分区。与CLUSTER BY子句不同&#xff0c;这不会对每个分区内的数据进行排序。 二、语法 DISTRIBUTE BY { expression [ , ... ] }三、参数 e…...

HTML5-canvas1

1、canvas&#xff1a;创建画布 <canvas id"canvas"></canvas>2、画一条直线 var canvasdocument.getElementById(cancas&#xff09;; canvas.width800; canvas.height800; var contextcanvas.getContext(2d); //获得2d绘图上下文环境 //画一条直线 c…...

【NOI-题解】1009 - 数组逆序1162 - 数组元素的删除1211 - 数组元素的插入1161. 元素插入有序数组1159. 数组元素的移动

文章目录 一、前言二、问题问题&#xff1a;1009 - 数组逆序问题&#xff1a;1162 - 数组元素的删除问题&#xff1a;1211 - 数组元素的插入问题&#xff1a;1161. 元素插入有序数组问题&#xff1a;1159. 数组元素的移动 三、感谢 一、前言 本章节主要对数组问题中数组元素移…...

新电脑如何设置 npm 源及查看源、安装 cnpm、pnpm 和 yarn 的详细教程

当你获得一台新电脑&#xff0c;或需要在现有电脑上优化 JavaScript 和 Node.js 的开发环境时&#xff0c;正确配置 npm 是一步不可少的过程。本教程将详细指导你如何设置 npm 源&#xff0c;查看当前源&#xff0c;以及如何安装 cnpm、pnpm 和 yarn。 1. 设置 npm 源 npm (N…...

完全移动huggingface模型仓库(不是简单mv)

Linux中移动huggingface模型仓库 参考链接 先在bashrc中配置&#xff1a; export HF_DATASETS_CACHE"/your/path/dataset" export HF_HOME"/your/path/" export HUGGINGFACE_HUB_CACHE"/your/path/hub" export TRANSFORMERS_CACHE"/your…...

Qt Widget类解析与代码注释

#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码&#xff0c;写上注释 当然可以&#xff01;这段代码是 Qt …...

iPhone密码忘记了办?iPhoneUnlocker,iPhone解锁工具Aiseesoft iPhone Unlocker 高级注册版​分享

平时用 iPhone 的时候&#xff0c;难免会碰到解锁的麻烦事。比如密码忘了、人脸识别 / 指纹识别突然不灵&#xff0c;或者买了二手 iPhone 却被原来的 iCloud 账号锁住&#xff0c;这时候就需要靠谱的解锁工具来帮忙了。Aiseesoft iPhone Unlocker 就是专门解决这些问题的软件&…...

django filter 统计数量 按属性去重

在Django中&#xff0c;如果你想要根据某个属性对查询集进行去重并统计数量&#xff0c;你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求&#xff1a; 方法1&#xff1a;使用annotate()和Count 假设你有一个模型Item&#xff0c;并且你想…...

DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI

前一阵子在百度 AI 开发者大会上&#xff0c;看到基于小智 AI DIY 玩具的演示&#xff0c;感觉有点意思&#xff0c;想着自己也来试试。 如果只是想烧录现成的固件&#xff0c;乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外&#xff0c;还提供了基于网页版的 ESP LA…...

【HTML-16】深入理解HTML中的块元素与行内元素

HTML元素根据其显示特性可以分为两大类&#xff1a;块元素(Block-level Elements)和行内元素(Inline Elements)。理解这两者的区别对于构建良好的网页布局至关重要。本文将全面解析这两种元素的特性、区别以及实际应用场景。 1. 块元素(Block-level Elements) 1.1 基本特性 …...

html-<abbr> 缩写或首字母缩略词

定义与作用 <abbr> 标签用于表示缩写或首字母缩略词&#xff0c;它可以帮助用户更好地理解缩写的含义&#xff0c;尤其是对于那些不熟悉该缩写的用户。 title 属性的内容提供了缩写的详细说明。当用户将鼠标悬停在缩写上时&#xff0c;会显示一个提示框。 示例&#x…...

Web 架构之 CDN 加速原理与落地实践

文章目录 一、思维导图二、正文内容&#xff08;一&#xff09;CDN 基础概念1. 定义2. 组成部分 &#xff08;二&#xff09;CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 &#xff08;三&#xff09;CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 &#xf…...

Hive 存储格式深度解析:从 TextFile 到 ORC,如何选对数据存储方案?

在大数据处理领域&#xff0c;Hive 作为 Hadoop 生态中重要的数据仓库工具&#xff0c;其存储格式的选择直接影响数据存储成本、查询效率和计算资源消耗。面对 TextFile、SequenceFile、Parquet、RCFile、ORC 等多种存储格式&#xff0c;很多开发者常常陷入选择困境。本文将从底…...

VM虚拟机网络配置(ubuntu24桥接模式):配置静态IP

编辑-虚拟网络编辑器-更改设置 选择桥接模式&#xff0c;然后找到相应的网卡&#xff08;可以查看自己本机的网络连接&#xff09; windows连接的网络点击查看属性 编辑虚拟机设置更改网络配置&#xff0c;选择刚才配置的桥接模式 静态ip设置&#xff1a; 我用的ubuntu24桌…...

C语言中提供的第三方库之哈希表实现

一. 简介 前面一篇文章简单学习了C语言中第三方库&#xff08;uthash库&#xff09;提供对哈希表的操作&#xff0c;文章如下&#xff1a; C语言中提供的第三方库uthash常用接口-CSDN博客 本文简单学习一下第三方库 uthash库对哈希表的操作。 二. uthash库哈希表操作示例 u…...