掌握 Python 接口自动化测试理论,深度解读测试框架源码

news/2024/11/17 5:39:07/

目录:导读

引言

一、什么是接口测试、为什么要做接口测试

1、什么是接口测试

2、为什么要做接口测试

二、接口测试的流程

1、接口测试的流程

2、为什么要写测试用例

3、接口测试设计要点

三、python接口自动化-requests的应用

1、requests简介

2、requests安装

3、requests-发送get请求

4、requests-发送post请求

5、response的其他应用

四、python接口自动化-unittest的应用

1、unittest简介

2、unittest的简单应用

结语


引言

Python 是一种易于学习和使用的编程语言,越来越多的软件测试人员开始将其用于接口自动化测试。但要想真正掌握 Python 接口自动化测试,不仅需要理论知识的支持,还需要深入了解各种自动化测试框架的源码实现

接下来文章将为你详细介绍 Python 接口自动化测试的理论知识,包括接口测试中的常见问题和解决方案、自动化测试的设计原则和流程等;

同时,我们还会深度解读主流 Python 自动化测试框架的源码实现,例如 unittest、pytest 和 requests 等。

无论你是初学者还是有一定经验的测试工程师,我们相信这篇文章都能给你带来新的启示和灵感,助你在 Python 接口自动化测试领域更进一步!

一、什么是接口测试、为什么要做接口测试

1、什么是接口测试

接口测试是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等。 
一般来说,测试接口,就是指测试接口的功能,性能和稳定性测试,当然可能还有安全性测试。一般,来说我们听说到的接口基本上都是指HTTP或者HTTPS协议的接口测试,也就是一些web服务请求。一个软件项目中,
有很多接口,少的有几十个,多的有几百上千个接口。这个时候,我们没有软件界面,没有具体的测试场景,只有一个接口描述文档。我们需要把接口这样抽象的东西,通过软件测试的理论和方法去测试接口,找出接口的功能和安全性的缺陷。接口有内部接口和外部接口。内部接口就是开发人员自己开发的接口。外部接口,好比网站调用微信支付和支付宝支付接口。还有一些模块与模块之间的接口。【转至 北京宏哥】

2、为什么要做接口测试

1、现在很多系统前后端架构是分离的,因为不同端(前段,后端)的工作进度不一样,所以我们要针对最开始出来的接口,以及需要调用其他公司的(银行,支付宝,微信,qq等)一些接口进行接口测试及验证数据,从安全层面来说,只依赖前端进行限制已经完全不能满足系统的安全要求(绕过前端太容易了), 需要后端同样进行控制,在这种情况下就需要从接口层面进行验证。在这种情况下就需要从接口层面进行验证。前后端传输、日志打印等信息是否加密传输也是需要验证的,特别是涉及到用户的隐私信息,如身份证,银行卡等。

2、如今系统越来越复杂,传统的靠前端测试已经大大降低了效率,而且现在我们都推崇测试前移也叫测试左移,希望测试能更早的介入测试,那接口测试就是一种及早介入的方式。例如传统测试,需要等前后端都完成才能进行测试,才能进行自动化代码编写。 而如果是接口测试,只需要前后端定义好接口,那这时自动化就可以介入编写接口自动化测试代码,手工测试只需要后端代码完成就可以介入测试后端逻辑而不用等待前端工作完成。【转至 北京宏哥】

二、接口测试的流程

1、接口测试的流程

接口测试也是属于功能测试,所以跟我们以往的功能测试流程并没有太大区别,测试流程依旧是:
a.测试接口文档(需求文档).
b.根据接口文档编写测试用例(用例编写完全可以按照以往规则来编写,例如等价类划分,边界值等设计方法)
c. 执行测试,查看不同的参数请求,接口的返回的数据是否达到预期。


接口测试和功能测试一样,流程也大致遵守V模型:

一般来说,接口测试左边的每个阶段,每个公司可能都侧重点不同,例如有些公司就没有需求讨论和需求评审这个阶段。不管如何,用例设计,这个是少不了,而且是重点,要花时间的阶段。只有覆盖全面的接口测试用例,才能有比较好的测试接口覆盖率,才会找出更多的接口的Bug,后期接口才能越稳定。

2、为什么要写测试用例

a.理清思路,避免漏测和重复测
b.提高测试效率
c.跟进测试进度
d.告诉领导做过
e.跟进重复性工作
f.更好的记录问题,发现问题,复现问题

3、接口测试设计要点

主要从四个方面来设计接口用例:功能,逻辑业务,异常,安全
功能:
功能是否正常;
功能是否按照接口文档实现
逻辑业务:
是否依赖业务,比如接口调用之前,需要调用登录接口,如果不登录也能请求数据,不符合业务规则。
异常:
参数异常和数据异常
参数异常:关键字参数,参数为空,多,少参数,错误参数
数据异常:关键字数据,数据为空,长度不一致,错误数据
安全:
cookie:有cookie才能获取数据,如果不带cookie还有信息返回,说明有问题
header:正常接口带header信息,删除header看是否能够返回数据。
唯一识别码:app手机识别码,一般是唯一的。

三、python接口自动化-requests的应用

1、requests简介

如果想用python做接口测试,我们首先有不得不了解和学习的模块。
它就是python的第三方模块:Requests。
虽然Python内置有urllib模块用于访问网络资源。但是,它用起来比较麻烦,而且,缺少很多实用的高级功能。
所以呢更好的方案是使用requests。它也是目前应用最广泛、最方便、功能最强大的一个Python第三方库,
主要用于处理URL资源
ruquests的中文官网:Requests: 让 HTTP 服务人类 — Requests 2.18.1 文档
requests的英文官网:http://www.python-requests.org/en/master/
有兴趣的可以看一下它的很多实用的高级功能

2、requests安装

a.使用pip安装

pip install requests

如果下载比较慢,配置使用国内镜像进行下载 pypi | 镜像站使用帮助 | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror

pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple

b.使用pycharm安装
步骤1:

步骤2:

步骤3:

步骤4:

3、requests-发送get请求

import requests# 请求的url,以小望之家的以id查企业接口为例
url = "https://endpoint.xiaowangtech.com/xw-moonlit/moonlit/enterprise/search-detail?enterpriseId=410417"# header信息
header = {"Access-Token": "6693dfed-bbbf-4163-9e59-e21a19ec7195","Accept": "application/json, text/plain, */*",
}# 使用requests发送get请求
r = requests.get(url=url, headers=header)# 以text格式打印出参
print(r.text)# 以json格式打印出参
print(r.json())

4、requests-发送post请求

import requests# 请求的url,以小望之家的获取企业列表为例
url = "https://endpoint.xiaowangtech.com/xw-moonlit/moonlit/enterprise/list"# header信息
header = {"Access-Token": "6693dfed-bbbf-4163-9e59-e21a19ec7195","Accept": "application/json, text/plain, */*",
}
# 请求入参
json = {"enterpriseName": "","current": 1,"size": 10
}
# 使用requests发送post请求
r = requests.post(url=url, headers=header, json=json)# 以text格式打印出参
print(r.text)# 以json格式打印出参
print(r.json())

5、response的其他应用

-- r.status_code #响应状态码
-- r.content #字节方式的响应体,会自动为你解码 gzip 和deflate 压缩
-- r.headers #以字典对象存储服务器响应头,但是这个字典比较特殊,字典键不区分大小写,若键不存在则返回 None
-- r.json() #Requests 中内置的 JSON 解码器,requests的方便之处还在于,对于特定类型的响应,例如JSON,可以直接获取
-- r.url # 获取 url
-- r.encoding # 编码格式,requests自动检测编码
-- r.cookies # 获取 cookie
-- r.raw #返回原始响应体-- r.text #字符串方式的响应体,会自动根据响应头部的字符编码进行解码
-- r.raise_for_status() #失败请求(非 200 响应)抛出异常

四、python接口自动化-unittest的应用

1、unittest简介

java开发小伙伴应该都清楚常见的单元测试框架 Junit 和 TestNG。
python 里面也有单元测试框架,就是unittest,相当于是一个 python 版的 junit。
python 里面的单元测试框架除了 unittest,还有一个 pytest 框架,这个实际上用的比较少。
本次主要介绍unittest,unittest单元测试框架不仅可以适用于单元测试,还可以适用自动化测试用例的开发与执行,该测试框架可组织执行测试用例,
并且提供了丰富的断言方法,判断测试用例是否通过,最终生成测试结果。

查看其中文官网:unittest --- 单元测试框架 — Python 3.11.3 文档
英文官网:unittest — Unit testing framework — Python 3.11.3 documentation

安装方法与requests相似,不过多描述。

2、unittest的简单应用

unittest结构代码:

# 导入unittest
import unittest# 定义一个测试类,并集成unittest.TestCase这个类
class TestCase01(unittest.TestCase):# 类装饰器,作用为在用例开始前先执行此函数@classmethoddef setUpClass(cls):print("case类开始执行")# 类装饰器,作用为在用例结束后执行此函数@classmethoddef tearDownClass(cls):print("case类执行结束")# 每条用例开始前执行此函数def setUp(self):print("case开始执行")# 每条用例结束后执行此函数def tearDown(self):print("case执行结束")# 测试用例1def test_01(self):print("case1")# 测试用例2def test_02(self):print("case2")# 测试用例3def test_03(self):print("case3")# 测试用例4def test_04(self):print("case4")if __name__ == "__main__":# 运行用例unittest.main()

运行结果分析:

结语

这篇贴子到这里就结束了,最后,希望看这篇帖子的朋友能够有所收获。

 获取方式:留言【接口自动化测试学习】即可

如果你觉得文章还不错,请大家 点赞、分享、留言 下,因为这将是我持续输出更多优质文章的最强动力!

 


http://www.ppmy.cn/news/59157.html

相关文章

代码随想录算法训练营第五十二天 |动态规划 part13

300. 最长递增子序列 给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序…

Linux 用户管理与文件权限

Linux 是一个多用户系统,它允许多个用户同时登陆主机,并为他们分配不同的资源和工作环境进行使用。当然,不同的用户都有文件的私有需求,所以设置不同用户文件的权限管理十分重要。 01 用户与用户组 Linux 中一般将文件访问权限的…

LeetCode 1376. Time Needed to Inform All Employees【自顶向下,自底向上(记忆化搜索+空间优化+迭代)】中等

本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章…

原生OpenFeign相较于传统HTTP工具的优化和原理

文章目录 1.HTTP工具使用流程及问题1.1 使用OkHttp3流程示例1.2 存在的两大问题 2.OpenFeign的优化3.OpenFeign实现原理3.1 使用Feign构造动态代理对象3.2 Feign动态代理的实现原理 本篇介绍的是springcloud-openfeign的底层框架io.github.openfeign,重点不是框架如…

介绍一款优秀的网址导航,可以部署到自己公司内部:hexo-theme-webstack

GitHub - HCLonely/hexo-theme-webstack: A hexo theme based on webstack. | 一个基于webstack的hexo主题。 中文文档 A Hexo theme based on WebStackPage. Installation hexo > 4.0 git clone https://github.com/HCLonely/hexo-theme-webstack themes/webstack hexo …

E. Train Hard, Win Easy(数学推导 + 前缀和)

Problem - E - Codeforces 这是一个有关竞赛编程的问题。Zibi 是一名竞赛编程教练,有 n 名选手想要备战。培训比赛具有一些不同寻常的规则——每个团队有两名成员和两个问题,每个选手都会编写其中一个问题的代码。当然,一个团队中的人将编写不…

感知机介绍

1&#xff0c;数学定义&#xff1a; Note:<>在数学中通常指求期望的意思。 假设我们用感知机区分cat和dog&#xff0c;使用下面三个特征&#xff1a;x1: color of hair&#xff1b;x2:length of leg&#xff1b;x3:volume of head。cat 用1表示&#xff0c;dog用-1表示&…

MySQL数据备份和恢复

MySQL数据备份和恢复 数据备份 mysqldump是MySQL数据库备份工具&#xff0c;可以备份MySQL数据库中的数据和结构&#xff0c;生成.sql文件&#xff0c;方便数据的迁移和恢复。 使用mysqldump工具前一定要配置环境变量 打开开始菜单&#xff0c;搜索“环境变量”。点击“编辑…