首页 > 其他分享 >pytest单元测试框架(升华篇)

pytest单元测试框架(升华篇)

时间:2023-09-14 23:57:58浏览次数:44  
标签:单元测试 self fixture test pytest print 升华 def

-----------------------------------
Pytest框架实现一些前后置(固件,夹具)的处理,常用三种

一、setup/teardown,setup_class/teardown_class所有

为什么需要这些功能?
比如:web自动化执行用例之前,请问需要打开浏览器吗?用例执行后需要关闭浏览器?

class TestMay:

    # 这个在所有的用例之前只执行一次
    def setup_class(self):
        print('在每个类执行前的初始化的工作:比如:创建日志对象,创建数据库的连接,创建接口的请求对象。')

    # 在每个用例之前执行一次。
    def setup(self):
        print('\n在执行测试用例之前初始化的代码:打开浏览器,加载网页')

    def test_01_huahua(self):
        print('\n测试花花')

    def test_02_xingxing(self):
        print('\n测试星星')

    def teardown(self):
        print('\n在执行测试用例之后的扫尾的代码:关闭浏览器')

    def teardown_class(self):
        print('在每个类执行后的扫尾的工作:比如:销毁日志对象,销毁数据库的连接,销毁接口的请求对象。')

注意:和Unittest不一样,全是小写。

运行结果

 

------- 上面的方法不是最理想的,比如设置了setup,那么每个用例都需要执行,但实际情况有可能是只有部分用例需要执行,所以有了下面的方法-----

二、使用@pytest.fixture()装饰器来实现部分用例的前后置。

装饰器
@pytest.fixture(scope="", params="", autouse="", ids="", name="")

--------------------------------------------------------------------------------------------

(1)scope表示的是被@pytest.fixture标记的方法的作用域。function(默认),class,module, package/session.  【function】:  -------------------运行于部分用例--------------------------------
import pytest


@pytest.fixture(scope='function')
def may_fixture():
    print('前置')
    yield
    print('后置')


class TestMay:

    def test_01_yiyi(self):
        print('\n测试一一')

    def test_02_xingxing(self):
        print('\n测试星星')

运行结果如下:

【class】
import pytest


@pytest.fixture(scope='class', autouse=True)
def may_fixture():
    print('前置的方法')
    yield
    print('后置的方法')


class TestMay:

    def test_01_yiyi(self):
        print('\n测试一一')

    def test_02_xingxing(self, may_fixture):
        print('\n测试星星')


class TestYo: def test_huahua(self): print("花花")

运行结果:

 【module】

import pytest


@pytest.fixture(scope='module', autouse=True)
def may_fixture():
    print('前置的方法')
    yield
    print('后置的方法')


class TestMay:

    def test_01_yiyi(self):
        print('\n测试一一')

    def test_02_xingxing(self, may_fixture):
        print('\n测试星星')class TestYo:

    def test_huahua(self):
        print("花花")

运行结果:

(2)params:参数化(支持,列表[],元祖(),字典列表[{},{},{}],字典元祖({},{},{})
import pytest


@pytest.fixture(scope='function', params=['阳阳', '洋洋', '杨杨'])
def may_fixture(request):
    print('前置')
    yield request.param  # return和yield都有返回的意思,但是return后面不能有代码,yield后面可以接代码。
    print('后置')


class TestMay:

    def test_01_yiyi(self):
        print('\n测试一一')

    def test_02_xingxing(self, may_fixture):
        print('\n测试星星')
        print('‐‐‐‐‐‐‐‐‐‐‐‐‐‐'+str(may_fixture))

    params=['阳阳','洋洋','杨杨'] 这里params是参数名,有s。
    request.param这里是属性名,是没有s的

运行结果如下:

(3)autouse=True:自动使用,默认False

   ------------------------运行于所有用例--------------------------

import pytest


@pytest.fixture(scope='function', autouse=True)
def may_fixture():
    print('前置的方法')
    yield
    print('后置的方法')


class TestMay:

    def test_01_yiyi(self):
        print('\n测试一一')

    def test_02_xingxing(self, may_fixture):
        print('\n测试星星')
        print('‐‐‐‐‐‐‐‐‐‐‐‐‐‐'+str(may_fixture))

运行结果:


(4)ids:当使用params参数化时,给每一个值设置一个变量名。意义不大。

@pytest.fixture(scope='function', params=['阳阳', '洋洋', '杨杨'], ids=['yy1', 'yy2', 'yy3'])
def may_fixture(request):
    print('前置')
    yield request.param  # return和yield都有返回的意思,但是return后面不能有代码,yield后面可以接代码。
    print('后置')

运行结果:

 

(5)name:给表示的是被@pytest.fixture标记的方法取一个别名。
当取了别名之后,那么原来的名称就用不了了。

 

运行结果和设置别名前没有变化

--------------------------------------------------

在测试用例中,装饰器@pytest.fixture正常不会直接在用例上方进行设置,会用下面的方法:通过conftest.py和@pytest.fixture()结合使用

 

三、通过conftest.py和@pytest.fixture()结合使用实现全局的前置应用(比如:项目的全局登录,模块的全局处理)

 

1.conftest.py文件是单独存放的一个夹具配置文件,名称是不能更改。
2.用处可以在不同的py文件中使用同一个fixture函数。
3.原则上conftest.py需要和运行的用例放到统一层。并且不需要做任何的imprt导入的操作。

总结:
setup/teardown,setup_class/teardown_class 它是作用于所有用例或者所有的类


@pytest.fixtrue() 它的作用是既可以部分也可以全部前后置。


conftest.py和@pytest.fixtrue()结合使用,作用于全局的前后置。

 

 运行结果:运行了6个测试用例

 ------------------------------------------------------------------------------------------------------------------------------------------------

用例内外都有conftest.py文件时,执行顺序按被调用时的顺序决定

 

 然后执行测试用例test_03.py

 调用上图中 1 和 2 的位置后,执行结果有改变

 

四、断言

assert

 

五、pytest结合allure-pytest插件生成allure测试报告

 简易报告:pytest -html

allure-pytest

步骤1. 下载,解压,配置path路径。

https://github.com/allure-framework/allure2/releases
path路径配置:E:\allure-2.13.7\bin

云盘下载安装

链接:https://pan.baidu.com/s/1PcxQtFskz5DCKUyCCMoLXg
提取码:2lzt


验证:allure --version
问题:dos可以验证但是pycharm验证失败,怎么办,重启pycharm

 

步骤2.加入命令生成json格式的临时报告。--alluredir ./temp

 

 运行结果,可看到根目录下新增一个 temp临时报告文件夹,且下面的文件为json格式

 

步骤3.生成allure报告

os.system('allure generate ./temp -o ./report --clean')

(先找到临时报告 temp,生成文件 -o ,到report文件中, 先清除原有的报告 --clean)

allure generate 命令,固定的
./temp 临时的json格式报告的路径
-o 输出output
./report 生成的allure报告的路径
--clean 清空./report 路径原来的报告

import pytest
import os

if __name__ == '__main__':
    pytest.main(['-vs', './test_cases/test_01.py'])
    os.system('allure generate ./temp -o ./report --clean')

 

 运行后查看报告

 

标签:单元测试,self,fixture,test,pytest,print,升华,def
From: https://www.cnblogs.com/may18/p/17702693.html

相关文章

  • pytest单元测试框架
    单元测试有java:junit/testingpython:unittest/pytest 单元测试框架1.测试发现2.测试执行3.测试判断4.测试报告 一、pytest简介1.pytest是一个非常成熟的python的单元框架,比unittest更灵活。2.pytest可以和selenium,requests,appium结合实现web自动化,接口自动化,app自动......
  • 软件测试|详解 Pytest 参数化:简化测试用例的编写
    简介Pytest是一个广泛使用的Python测试框架,它提供了丰富的功能来编写和执行测试用例。其中一个强大的特性是参数化,它允许我们通过一种简洁的方式运行多个输入参数的相似测试用例,从而减少冗余的代码。本文将详细介绍Pytest的参数化功能以及如何使用它来简化测试用例的编写。参......
  • pytest的setup和teardown
    setup和teardown函数可以分别在每个测试用例之前和之后执行,以确保测试环境的准备和清除工作。通过合理使用这两个函数,您可以有效地提高测试效率,并且避免测试用例之间的相互干扰。 Pytest-setup和teardown执行用例肯定有些需要前置条件或后置操作,例如前置的用户登陆,后置的清......
  • springboot单元测试
    参考文章:SpringBoot单元测试详解_springboottest单元测试_三分恶的博客-CSDN博客JUnit4(三)高级之assertThat和Matchers(匹配器)_FXBStudy的博客-CSDN博客 一:junit测试当你的单元测试代码不需要用到SpringBoot功能,而只是一个简单的测试时,你可以直接编写你的Junit测试......
  • Jenkins windows 下 'pytest' 不是内部或外部命令,也不是可运行的程序 或批处理文件。
    问题现象: 解决:     ......
  • 关于 fakeAsync 在 Angular 应用单元测试开发领域的使用介绍
    笔者最近三年一直在SAP中国研究院从事SAPCommerceCloud(电商云)这款产品的前端开发。电商云Storefront基于开源项目Spartacus,其Github代码仓库地址可以通过这个链接访问。我最近所在的团队一直在负责Spartacus服务器端渲染(SSR)逻辑的开发,包含渲染引擎(RenderingE......
  • pytest运行警告问题解决:DeprecationWarning: pkg_resources is deprecated as an API
    前言最近在运行pytest的时候,经常出现这个警告DeprecationWarning:pkg_resourcesisdeprecatedasanAPISeehttps://setuptools.pypa.io/en/latest/pkg_resources.htmlfrompkg_resourcesimportiter_entry_points从警告上看是方法被弃用,肯定是因为新版弃用了旧版的语法。......
  • 软件测试——测试的分类(重点:黑盒测试、白盒测试、单元测试、集成测试、系统测试)
    一、按照测试对象进行划分1)界面测试界面是直接和用户进行交互的,界面设计的好坏决定了用户使用软件的直观感受界面测试(UI测试)一般包括以下内容:对比UI设计稿,验证系统显示界面的一致性和正确性验证界面上每个功能的正确性验证界面排版布局是否合理。字体大小、图片排版、......
  • python+pytest+yam接口自动化
    分层设计项目下创建api、case、data、common(utils)目录:api下存放封装好的接口,case下放编写的测试用例,data下放测试数据,common下放公共操作(像连接数据库,读取yaml文件等)api下封装的登录接口:  case下对登录写的测试用例:用例设计的原则(pytest怎么去找的用例):文件名以test_*.py......
  • pytest.mark.parametrize() 列表2
    yaml文件:--list_order-南京--list_order-北京--list_order-郑州--list_order-西安 代码:importjsonimportpprintimportpytestfromSlience.utils.login_utilimportLoginfromSlience.utils.request_utilimportSendReque......