百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python+Requests+Pytest+YAML+Allure实现接口自动化

off999 2024-10-17 11:45 94 浏览 0 评论

优质文章,第一时间送达!

本项目实现接口自动化的技术选型:Python+Requests+Pytest+YAML+Allure,主要是针对之前开发的一个接口项目来进行学习,通过 Python+Requests 来发送和处理HTTP协议的请求接口,使用 Pytest 作为测试执行器,使用 YAML 来管理测试数据,使用 Allure 来生成测试报告。

接口项目开发学习:

使用Flask开发简单接口(1)--GET请求接口(https://www.cnblogs.com/wintest/p/12728095.html)

使用Flask开发简单接口(2)--POST请求接口(https://www.cnblogs.com/wintest/p/12731508.html)

使用Flask开发简单接口(3)--引入MySQL (https://www.cnblogs.com/wintest/p/12741772.html)

使用Flask开发简单接口(4)--借助Redis实现token验证(https://www.cnblogs.com/wintest/p/12777340.html)

使用Flask开发简单接口(5)--数据加密处理(https://www.cnblogs.com/wintest/p/12780090.html)

项目说明

本项目在实现过程中,把整个项目拆分成请求方法封装、HTTP接口封装、关键字封装、测试用例等模块。

首先利用Python把HTTP接口封装成Python接口,接着把这些Python接口组装成一个个的关键字,再把关键字组装成测试用例,而测试数据则通过YAML文件进行统一管理,然后再通过Pytest测试执行器来运行这些脚本,并结合Allure输出测试报告。

当然,如果感兴趣的话,还可以再对接口自动化进行Jenkins持续集成。

GitHub项目源码地址:https://github.com/wintests/pytestDemo

项目结构

  • api ====>> 接口封装层,如封装HTTP接口为Python接口

  • common ====>> 各种工具类

  • core ====>> requests请求方法封装、关键字返回结果类

  • config ====>> 配置文件

  • data ====>> 测试数据文件管理

  • operation ====>> 关键字封装层,如把多个Python接口封装为关键字

  • pytest.ini ====>> pytest配置文件

  • requirements.txt ====>> 相关依赖包文件

  • testcases ====>> 测试用例

请求方法封装

core/rest_client.py文件中,对Requests库下一些常见的请求方法进行了简单封装,以便调用起来更加方便。

class RestClient:

def __init__(self, api_root_url):
self.api_root_url = api_root_url
self.session = requests.session

def get(self, url, **kwargs):
return self.request(url, "GET", **kwargs)

def post(self, url, data=None, json=None, **kwargs):
return self.request(url, "POST", data, json, **kwargs)

def put(self, url, data=None, **kwargs):
return self.request(url, "PUT", data, **kwargs)

def delete(self, url, **kwargs):
return self.request(url, "DELETE", **kwargs)

def patch(self, url, data=None, **kwargs):
return self.request(url, "PATCH", data, **kwargs)

def request(self, url, method, data=None, json=None, **kwargs):
url = self.api_root_url + url
headers = dict(**kwargs).get("headers")
params = dict(**kwargs).get("params")
files = dict(**kwargs).get("params")
cookies = dict(**kwargs).get("params")
self.request_log(url, method, data, json, params, headers, files, cookies)
if method == "GET":
return self.session.get(url, **kwargs)
if method == "POST":
return requests.post(url, data, json, **kwargs)
if method == "PUT":
if json:
# PUT 和 PATCH 中没有提供直接使用json参数的方法,因此需要用data来传入
data = complexjson.dumps(json)
return self.session.put(url, data, **kwargs)
if method == "DELETE":
return self.session.delete(url, **kwargs)
if method == "PATCH":
if json:
data = complexjson.dumps(json)
return self.session.patch(url, data, **kwargs)

HTTP接口 封装为 Python接口

api/user.py文件中,将上面封装好的HTTP接口,再次封装为不同的Python接口。不同的Python接口,会处理不同URL下的请求。

class User(RestClient):

def __init__(self, api_root_url, **kwargs):
super(User, self).__init__(api_root_url, **kwargs)

def list_all_users(self, **kwargs):
return self.get("/users", **kwargs)

def list_one_user(self, username, **kwargs):
return self.get("/users/{}".format(username), **kwargs)

def register(self, **kwargs):
return self.post("/register", **kwargs)

def login(self, **kwargs):
return self.post("/login", **kwargs)

def update(self, user_id, **kwargs):
return self.put("/update/user/{}".format(user_id), **kwargs)

def delete(self, name, **kwargs):
return self.post("/delete/user/{}".format(name), **kwargs)

关键字返回结果类

core/result_base.py下,定义了一个空类ResultBase,该类主要用于自定义关键字返回结果。

class ResultBase:
pass

"""
自定义示例:
result = ResultBase
result.success = False
result.msg = res.json["msg"]
result.response = res
"""`

在多流程的业务场景测试下,通过自定义期望保存的返回数据值,以便更好的进行断言。

关键字封装

关键字应该是具有一定业务意义的,在封装关键字的时候,可以通过调用多个Python接口来完成。在某些情况下,比如测试一个充值接口的时候,在充值后可能需要调用查询接口得到最新账户余额,来判断查询结果与预期结果是否一致,那么可以这样来进行测试:

  • 1, 首先,可以把 充值-查询的操作封装为一个关键字,在这个关键字中依次调用充值和查询的接口,并可以自定义关键字的返回结果。

  • 2, 接着,在编写测试用例的时候,直接调用关键字来进行测试,这时就可以拿到关键字返回的结果,那么断言的时候,就可以直接对关键字返回结果进行断言。

测试用例层

根据用例名分配测试数据

测试数据位于 data文件夹下,在这里使用YAML来管理测试数据,同时要求测试数据中第一层的名称,需要与测试用例的方法名保持一致,如test_get_all_user_infotest_delete_user

test_get_all_user_info:
# 期望结果,期望返回码,期望返回信息
# except_result, except_code, except_msg
- [True, 0, "查询成功"]
省略
test_delete_user:
# 删除的用户名,期望结果,期望返回码,期望返回信息
# username, except_result, except_code, except_msg
- ["测试test", True, 0, "删除用户信息成功"]
- ["wintest3", False, 3006, "该用户不允许删除"]

这里借助 fixture方法,我们就能够通过request.function.__name__自动获取到当前执行用例的函数名testcase_name,当我们传入测试数据api_data之后,接着便可以使用api_data.get(testcase_name)来获取到对应用例的测试数据。

import pytest
from testcases.conftest import api_data

@pytest.fixture(scope="function")
def testcase_data(request):
testcase_name = request.function.__name__
return api_data.get(testcase_name)`

数据准备和清理

在接口自动化中,为了保证用例可稳定、重复地执行,我们还需要有测试前置操作和后置操作,即数据准备和数据清理工作。

@pytest.fixture(scope="function")
def delete_register_user:
"""注册用户前,先删除数据,用例执行之后,再次删除以清理数据"""
del_sql = base_data["init_sql"]["delete_register_user"]
db.execute_db(del_sql)
logger.info("注册用户操作:清理用户--准备注册新用户")
logger.info("执行前置SQL:{}".format(del_sql))
yield # 用于唤醒 teardown 操作
db.execute_db(del_sql)
logger.info("注册用户操作:删除注册的用户")
logger.info("执行后置SQL:{}".format(del_sql))

在这里,以用户注册用例为例。对于前置操作,我们应该准备一条删除SQL,用于将数据库中已存在的相同用户删除,对于后置操作,我们应该再执行删除SQL,确保该测试数据正常完成清理工作。

在测试用例中,我们只需要在用例上传入 fixture的函数参数名delete_register_user,这样就可以调用fixture实现测试前置及后置操作。当然,也可以使用pytest装饰器@pytest.mark.usefixtures来完成,如:

@pytest.mark.usefixtures("delete_register_user")` 

Allure用例描述

在这里,我们结合 Allure 来实现输出测试报告,同时我们可以使用其装饰器来添加一些用例描述并显示到测试报告中,以便报告内容更加清晰、直观、可读。如使用 @allure.title自定义报告中显示的用例标题,使用@allure.description自定义用例的描述内容,使用@allure.step可在报告中显示操作步骤,使用@allure.issue可在报告中显示缺陷及其链接等。

@allure.step("步骤1 ==>> 注册用户")
def step_1(username, password, telephone, sex, address):
logger.info("步骤1 ==>> 注册用户 ==>> {}, {}, {}, {}, {}".format(username, password, telephone, sex, address))

@allure.severity(allure.severity_level.NORMAL)
@allure.epic("针对单个接口的测试")
@allure.feature("用户注册模块")
class TestUserRegister:
"""用户注册"""
@allure.story("用例--注册用户信息")
@allure.description("该用例是针对获取用户注册接口的测试")
@allure.issue("https://www.cnblogs.com/wintest", name="点击,跳转到对应BUG的链接地址")
@allure.testcase("https://www.cnblogs.com/wintest", name="点击,跳转到对应用例的链接地址")
@allure.title(
"测试数据:【 {username},{password},{telephone},{sex},{address},{except_result},{except_code},{except_msg}】")
@pytest.mark.single
@pytest.mark.parametrize("username, password, telephone, sex, address, except_result, except_code, except_msg",
api_data["test_register_user"])
@pytest.mark.usefixtures("delete_register_user")
def test_delete_user(self, login_fixture, username, except_result, except_code, except_msg):
省略`

项目部署

首先,下载项目源码后,在根目录下找到 requirements.txt文件,然后通过 pip 工具安装 requirements.txt 依赖,执行命令:

pip3 install -r requirements.txt` 

接着,修改 config/setting.ini配置文件,在Windows环境下,安装相应依赖之后,在命令行窗口执行命令:

pytest

注意:因为我这里是针对自己的接口项目进行测试,如果想直接执行我的测试用例来查看效果,需要提前部署上面提到的接口项目。

测试报告效果展示

在命令行执行命令:pytest运行用例后,会得到一个测试报告的原始文件,但这个时候还不能打开成HTML的报告,还需要在项目根目录下,执行命令启动allure服务:

# 需要提前配置allure环境,才可以直接使用命令行
allure serve ./report`

最终,可以看到测试报告的效果图如下:

来源:https://www.cnblogs.com/wintest

回复下方「关键词」,获取优质资源


回复关键词「 pybook03」,立即获取主页君与小伙伴一起翻译的《Think Python 2e》电子版

回复关键词「入门资料」,立即获取主页君整理的 10 本 Python 入门书的电子版

回复关键词「m」,立即获取Python精选优质文章合集

回复关键词「」,将数字替换成 0 及以上数字,有惊喜好礼哦~


题图:pexels,CC0 授权。

相关推荐

安全教育登录入口平台(安全教育登录入口平台官网)

122交通安全教育怎么登录:122交通网的注册方法是首先登录网址http://www.122.cn/,接着打开网页后,点击右上角的“个人登录”;其次进入邮箱注册,然后进入到注册页面,输入相关信息即可完...

大鱼吃小鱼经典版(大鱼吃小鱼经典版(经典版)官方版)

大鱼吃小鱼小鱼吃虾是于谦跟郭麒麟的《我的棒儿呢?》郭德纲说于思洋郭麒麟作诗的相声,最后郭麒麟做了一首,师傅躺在师母身上大鱼吃小鱼小鱼吃虾虾吃水水落石出师傅压师娘师娘压床床压地地动山摇。...

谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)

要想将ppt免费转换为pdf的话,我们建议大家可以下一个那个wps,如果你是会员的话,可以注册为会员,这样的话,在wps里面的话,就可以免费将ppt呢转换为pdfpdf之后呢,我们就可以直接使用,不需要去直接不需要去另外保存,为什么格式转...

2026-02-04 09:03 off999

电信宽带测速官网入口(电信宽带测速官网入口app)

这个网站看看http://www.swok.cn/pcindex.jsp1.登录中国电信网上营业厅,宽带光纤,贴心服务,宽带测速2.下载第三方软件,如360等。进行在线测速进行宽带测速时,尽...

植物大战僵尸95版手机下载(植物大战僵尸95 版下载)

1可以在应用商店或者游戏平台上下载植物大战僵尸95版手机游戏。2下载教程:打开应用商店或者游戏平台,搜索“植物大战僵尸95版”,找到游戏后点击下载按钮,等待下载完成即可安装并开始游戏。3注意:确...

免费下载ppt成品的网站(ppt成品免费下载的网站有哪些)

1、Chuangkit(chuangkit.com)直达地址:chuangkit.com2、Woodo幻灯片(woodo.cn)直达链接:woodo.cn3、OfficePlus(officeplu...

2025世界杯赛程表(2025世界杯在哪个国家)

2022年卡塔尔世界杯赛程公布,全部比赛在卡塔尔境内8座球场举行,2022年,决赛阶段球队全部确定。揭幕战于当地时间11月20日19时进行,由东道主卡塔尔对阵厄瓜多尔,决赛于当地时间12月18日...

下载搜狐视频电视剧(搜狐电视剧下载安装)

搜狐视频APP下载好的视频想要导出到手机相册里方法如下1、打开手机搜狐视频软件,进入搜狐视频后我们点击右上角的“查找”,找到自已喜欢的视频。2、在“浏览器页面搜索”窗口中,输入要下载的视频的名称,然后...

pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
永久免费听歌网站(丫丫音乐网)

可以到《我爱音乐网》《好听音乐网》《一听音乐网》《YYMP3音乐网》还可以到《九天音乐网》永久免费听歌软件有酷狗音乐和天猫精灵,以前要跳舞经常要下载舞曲,我从QQ上找不到舞曲下载就从酷狗音乐上找,大多...

音乐格式转换mp3软件(音乐格式转换器免费版)

有两种方法:方法一在手机上操作:1、进入手机中的文件管理。2、在其中选择“音乐”,将显示出手机中的全部音乐。3、点击“全选”,选中所有音乐文件。4、点击屏幕右下方的省略号图标,在弹出菜单中选择“...

电子书txt下载(免费的最全的小说阅读器)

1.Z-library里面收录了近千万本电子书籍,需求量大。2.苦瓜书盘没有广告,不需要账号注册,使用起来非常简单,直接搜索预览下载即可。3.鸠摩搜书整体风格简洁清晰,书籍资源丰富。4.亚马逊图书书籍...

最好免费观看高清电影(播放免费的最好看的电影)

在目前的网上选择中,IMDb(互联网电影数据库)被认为是最全的电影网站之一。这个网站提供了各种类型的电影和电视节目的海量信息,包括剧情介绍、演员表、评价、评论等。其还提供了有关电影制作背后的详细信息,...

孤单枪手2简体中文版(孤单枪手2简体中文版官方下载)

要将《孤胆枪手2》游戏的征兵秘籍切换为中文,您可以按照以下步骤进行操作:首先,打开游戏设置选项,通常可以在游戏主菜单或游戏内部找到。然后,寻找语言选项或界面选项,点击进入。在语言选项中,选择中文作为游...

取消回复欢迎 发表评论: