首页 > 其他分享 >pytest单元测试框架

pytest单元测试框架

时间:2023-09-14 15:37:49浏览次数:38  
标签:__ vs 框架 -- 单元测试 pytest test 测试用例

单元测试有

java: junit/testing

python:unittest/pytest

 

单元测试框架 1.测试发现 2.测试执行 3.测试判断 4.测试报告 

一、pytest简介

1.pytest是一个非常成熟的python的单元框架,比unittest更灵活。
2.pytest可以和selenium,requests,appium结合实现web自动化,接口自动化,app自
动化。
3.pytest可以实现测试用例的跳过以及reruns失败用例重试。
4.pytest可以和allure生成非常美观的测试报告。
5.pytest可以和Jenkins持续集成。
6.pytest有很多非常强大的插件,并且这些插件能够实现很多的实用的操作。

pytest
pytest-xdist # 测试用例分布式执行。多CPU分发。 pytest-ordering # 用于改变测试用例的执行顺序(从上到下) pytest-rerunfailures # 用例失败后重跑 pytest-html # (生成html格式的自动化测试报告) allure-pytest # 用于生成美观的测试报告。

 1.Pytest插件安装

一个个安装太麻烦,统一放到requirements.txt中,用pip install -r requirements.txt进行安装

pip install -r requirements.txt

步骤:在项目名中右键NEW--File,命名为requirements.txt,输入上面指令,通过Terminal输入pip install -r requirements.txt,回车进行安装

 

 

验证是否安装成功:pytest --version

 以上安装方法只适用于本项目,如果要全部使用,则通过cmd进行安装(如果升级安装,则在 install 后面加 -U即可)

pip install pytest
pip install pytest-xdist
pip install pytest-ordering
pip install pytest-rerunfailures
pip install pytest-html
pip install allure-pytest

 

二、使用Pytest,默认的测试用例规则

1.模块名必须以test_开头或者_test结尾

2.测试类必须以Test开头,并且不能有init方法。
3.测试方法必须以test开头

 

三、Pytest测试用例运行模式

1.主函数模式

(1)运行所有:pytest.main()

   
(2)指定模块:pytest.main(['-vs','test_login.py'])

(3)指定目录:pytest.main(['-vs','./interface_testcase'])   

 

(4)通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,方法名,函数名组成。

 

 nodeid指定用例运行

指定方法

if __name__ == '__main__':
    pytest.main(['-vs', './test_cases/test_01.py::test_funtion'])  # 通过nodeid指定用例运行

指定类里面的方法

if __name__ == '__main__':
    pytest.main(['-vs', './test_cases/test_01.py::TestLogin::test_001'])

=================================================================================

如果要输出调试信息

pytest.main('-s')
-s:表示输出调试信息,包括print打印的信息
-v:结果显示更详细的信息,比如模块名,类名,方法名,测试结果
-vs:这两个参数一起用(显示详细信息,和打印信息)
-n:支持多线程或者分布式运行测试用例。
如:pytest -vs ./testcase/test_login.py -n 2
--reruns NUM:失败用例重跑
-x:表示只要要一个用例报错,那么测试停止。
--maxfail=2 出现两个用例失败就停止。
-k:根据测试用例的部分字符串(函数名,方法名等)指定测试用例。

 

 1) -vs参数

 

2) -n 测试用例并行运行

先来看没有并行的情况

 

  由下图可以看出,没有并行时,花费了 10.05S

 

 

下面来看 - n 并行运行的情况(2个测试用例,就是两个线程),测试时间是6.90S ,可以看出测试时间缩短了

if __name__ == '__main__':
    pytest.main(['-vs', './test_cases', '-n=2'])

 3) --reruns NUM 失败用例重跑

if __name__ == '__main__':
    pytest.main(['-vs', './test_cases', '--reruns=2'])

4) -k:根据测试用例的部分字符串(函数名,方法名等)指定测试用例。

if __name__ == '__main__':
    pytest.main(['-vs', './test_cases/test_01.py', '-k', 'may'])

运行结果可看出,只运行了带may的测试用例

 

2.命令行模式

,运行有,在Terminal输入


(1)运行所有:pytest
(2)指定模块:pytest -vs test_login.py
(3)指定目录:pytest -vs ./interface_testcase
(4)指定目录:pytest -vs ./interface_testcase/test_interface.py::test_04_func

参数详解:-s,-v,-vs,-v,--reruns,-x,--maxfail,-k


-s:表示输出调试信息,包括print打印的信息
-v:显示更详细的信息,模块名,类名,方法名,测试结果

-vs:这两个参数一起用(显示详细信息和打印信息)
-n:支持多线程或者分布式运行测试用例。

pytest -vs ./test_cases/test_01.py -n 2

--reruns NUM:失败用例重跑 

pytest -vs ./test_cases/test --reruns 2

-x:表示只要要一个用例报错,那么测试停止


--maxfail=2 出现两个用例失败就停止。

pytest -vs ./test_cases/test --maxfail 2


-k:根据测试用例的部分字符串(函数名,方法名等)指定测试用例。

pytest -vs ./test_cases/test_01.py -k "may"

 

--html ./report/report.html:生成html的测试报告。

 

3.通过读取pytest.ini全局配置文件运行

(配置好这个文件后,其他正常运行即可。该配置优先级高于主函数和命令行的配置)
pytest.ini这个文件它是pytest单元测试框架的核心配置文件
1.位置:一般放在项目的根目录,名称 pytest.ini
2.编码:必须是ANSI,可以使用notpad++修改编码格式。

 步骤一、 pytest_ini文件复制到电脑桌面,用notpad++,Encoding-->Convert to ANSI,保存后复制该文件

步骤二、项目右键-->Paste-->OK-->Overwrite

 

[pytest]
addopts = -vs
testpaths = ./test_cases
python_files = test_*.py
python_classes = Test*
python_functions = test


3.作用:改变pytest默认的行为。
4.运行的规则;不管是主函数的模式运行,命令行模式运行,都会去读取这个配置文件。

[pytest]
addopts = -vs #命令行的参数,用空格分隔
testpaths = ./testcase #测试用例的路径
python_files = test_*.py #模块名的规则
python_classes = Test* #类名的规则
python_functions = test #方法名的规则
 

四、pytest执行测试用例的顺序


unittest:ascII的大小来绝对的执行的顺序
pytest:默认从上到下
改变默认的执行顺序:使用mark标记
@pytest.mark.run(order=3)
import time

import pytest


def test_funtion_may():
    print("函数")


class TestLogin:
    def test_001(self):
        time.sleep(5)
        print("pytest输出")

    @pytest.mark.run(order=2)
    def test_002_may(self):
        assert 2 == 1

    def test_003(self):
        print("输出May")

    @pytest.mark.run(order=1)
    def test_004(self):
        print("花花")

运行结果如下

 

 

五、如何分组执行(冒烟用例)

  (冒烟,分模块执行,分接口和web执行)
smoke:冒烟用例,分布在各个模块里面
pytest -m "smoke"
pytest -m "smoke or usermanage"   全局配置里面增加
markets =
    smoke:冒烟用例
    usermanage:用户管理模块

 

smoke和usermanage是自定义的,根据自己需要

在用例前面增加

@pytest.mark.smoke
@pytest.mark.usermanage

test_02.py
import time
import pytest


class TestLog:
    def test_003(self):
        time.sleep(5)
        print("测试用例并行运行")

    @pytest.mark.smoke
    def test_chen(self):
        print("huayu")

    @pytest.mark.usermanage
    def test_user(self):
        print("用户管理")

 

 运行pytest -m "smoke"

 运行pytest -m "smoke or usermanage"

 

六、pytest跳过测试用例


(1)无条件跳过
@pytest.mark.skip(reason="不想运行该用例")
    def test_chen(self):
        print("huayu")


(2)有条件跳过
age = 18
    @pytest.mark.usermanage
    @pytest.mark.skipif(age>=18, reason="年龄大于18跳过")
    def test_user(self):
        print("用户管理")

 


标签:__,vs,框架,--,单元测试,pytest,test,测试用例
From: https://www.cnblogs.com/may18/p/17701317.html

相关文章

  • python的flask框架部署网页过程报错及解决方案
    python安装好flask框架之后,创建一个flask的项目,运行发生以下报错UnicodeDecodeError:'utf-8'codeccan'tdecodebyte0xa1inposition4:invalidstartbyte原因是读取flask库源码的时候系统默认未使用‘utf-8’格式win10电脑->控制面板->区域->管理->更改系统区域设置......
  • MyBatis框架详解:一个高效、灵活且易于使用的ORM框架
    MyBatis(原名ibatis)是一个基于Java语言的ORM(对象关系映射)框架,可以将数据库表中的数据转换成Java对象,也可以将Java对象中的数据插入到数据库表中。它采用了数据映射文件和注解两种方式来实现数据的映射,可以方便地管理SQL语句和实体类之间的关系。灵活性相比于其他ORM框架,MyBatis更加......
  • jquery框架学习(keep update)
    1.jquery在日常的开发中,是较为常用的一种技术,所以今天也不算较为系统详细的学习吧。2.主要是对jquery当中,许多常用的方法进行学习和总结吧3.jquery当中主要的特点就是:选择器,js当中呢,主要就是dom树结构。4.下面就不多说了,开始我们jquery当中方法的学习。1.①......
  • 支持JDK19虚拟线程的web框架,之二:完整开发一个支持虚拟线程的quarkus应用
    欢迎访问我的GitHub这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos本篇概览本篇是《支持JDK19虚拟线程的web框架》系列的中篇,前文咱们体验了有虚拟线程支持的web服务,经过测试,发现性能上它与其他两种常见web架构并无明显区别,既然如此,还有......
  • 埃森哲企业数字化规划架构框架
    本人在四大咨询机构从事咨询工作多年,二十年一线数字化规划咨询经验,提供制造业数智化转型规划服务,顶层规划/企业架构/数据治理/数据安全解决方案资料干货.一、埃森哲企业架构框架   企业数字化/信息化规划是一项层次多、跨度大的复杂工程。为此,埃森哲信息战略规划体系,定义了......
  • Dami 本地过程调用框架(主打解耦),v0.24 发布
    Dami,专为本地多模块之间通讯解耦而设计(尤其是未知模块、隔离模块、领域模块)。零依赖,特适合DDD。特点结合Bus与RPC的概念,可作事件分发,可作接口调用,可作异步响应。支持事务传导(同步分发、异常透传)支持事件标识、拦截器(方便跟踪)支持监听者排序、附件传递(多监听时,可相互合......
  • 论文研读_大规模多目标优化问题的两阶段多任务转换框架
    本文的创新点在哪里采用两阶段框架的方式来处理大规模多目标优化问题第一阶段,采用多任务优化策略和双向搜索策略,它将多目标问题改编为决策空间中的多任务问题,以增强收敛性利用双向搜索策略与MFEA相结合,将多目标问题转化为多任务问题第二阶段,提出的算法将多任务优化应......
  • 详解 WebRTC 协议原理与框架
    一、WebRTC 是什么WebRTC,名称源自网页即时通信(英语:WebReal-TimeCommunication)的缩写,是一个支持网页浏览器进行实时语音对话或视频对话的API。它于2011年6月1日开源并在Google、Mozilla、Opera支持下被纳入万维网联盟的W3C推荐标准。谷歌2011年6月3日宣布向开发人员开放WebRTC......
  • 软件测试|详解 Pytest 参数化:简化测试用例的编写
    简介Pytest是一个广泛使用的Python测试框架,它提供了丰富的功能来编写和执行测试用例。其中一个强大的特性是参数化,它允许我们通过一种简洁的方式运行多个输入参数的相似测试用例,从而减少冗余的代码。本文将详细介绍Pytest的参数化功能以及如何使用它来简化测试用例的编写。参......
  • pytest的setup和teardown
    setup和teardown函数可以分别在每个测试用例之前和之后执行,以确保测试环境的准备和清除工作。通过合理使用这两个函数,您可以有效地提高测试效率,并且避免测试用例之间的相互干扰。 Pytest-setup和teardown执行用例肯定有些需要前置条件或后置操作,例如前置的用户登陆,后置的清......