前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >接口自动化测试之pytest用例管理框架

接口自动化测试之pytest用例管理框架

作者头像
用户6367961
发布2022-11-21 12:00:13
7940
发布2022-11-21 12:00:13
举报
文章被收录于专栏:自学测试之道自学测试之道

一、pytest用例管理框架

文档:https://docs.pytest.org/en/latest/contents.html#toc

第三方库:https://pypi.org/search/?q=pytest

pytest默认规则:

1、py文件必须以test_开头或者_test结尾

2、类名必须以Test开头

3、测试用例必须以test_开头

pytest用例管理框架的作用:

1、发现测试用例,从多个py文件中通过默认的规则去找测试用例

2、执行测试用例,顺序和条件

3、判断测试结果,断言

4、生成测试报告,html、allure

python.unittest或pytest

java.junit或testng

二、pytest全局观

1、它可以和所有的自动化测试工具selenium,requests,appium结合实现web自动化、接口自动化以及APP自动化。

2、跳过用例以及失败用例重跑

3、结合allure生成美观的测试报告

4、和jenkins持续集成

5、有很多强大的插件

pytest-html 生成html测试报告

pytest-xdist 多线程运行

pytest-ordering 改变测试用例执行顺序

pytest-rerunfailures 失败用例重跑

allure-pytest 生成allure测试报告

一般实际项目开发当中都会使用requrements.txt文件保存插件名称,然后通过:pip install -r requrements.txt

三、运行方式

pytest.main('-vs','-n=2')

1、主函数的方式(命令行方式)

-v 输出更加详细的信息

-s 输出调试信息

-n 多线程运行

-reruns 数字 失败用例重跑 pytest.main('-vs','--reruns=2')

-html=报告的路径 pytest.main('-vs','--html=./report.html')

2、实际工作中使用pytest.ini的配置文件来配置运行

四、前后置、夹具

setup/teardowm 在每个用例之前和之后执行一次

setup_class/teardowm_class 在每个类之前和之后执行一次

实现部分的前置

我想其中一个用例做数据库验证,怎么办?

部分的前置:

@pytest.fixtrue(scope="作用域",params="数据驱动",autouse="自动执行",ids="自定义参数名",name="重命名") 作用域:function, class, module,package/session

可以通过yield唤醒 类似teardowm的功能,简单理解就是返回。yieId和return都是返回数据的意思,只是区分在于,yieId返回多次以及多个数据,return只会返回一次,return之后不能接代码

一般情况下:

@pytest.fixtrue()一般会和conftest.py文件一起使用

conftest.py名称是固定的,功能很强大

1、conftest.py文件时单独存放@pytest.fixtrue()的方法,用处是可以在多个py文件之间共享前置配置

2、conftest.py里面的方法在调用时不需要导入,可以直接使用

3、conftest.py可以有多个,也可以有多个不同层级

五、参数化

1、参数参数化

@pytest.mark.parametrize(argnames, argvalues)

argnames:要参数化的变量,string(逗号分割),list,tupleargvalues:参数化的值,list,list[tuple]

2、yaml数据参数化

yaml实现嵌套

yaml实现list

yaml实现字典

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-07-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 自学测试之道 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
持续集成
CODING 持续集成(CODING Continuous Integration,CODING-CI)全面兼容 Jenkins 的持续集成服务,支持 Java、Python、NodeJS 等所有主流语言,并且支持 Docker 镜像的构建。图形化编排,高配集群多 Job 并行构建全面提速您的构建任务。支持主流的 Git 代码仓库,包括 CODING 代码托管、GitHub、GitLab 等。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档