初学 pytest 记录

news2025/7/28 3:33:47
  1. 安装

    pip install pytest
    

    用例可以是函数也可以是类中的方法

    def test_func():
    	print()
    
    class TestAdd:
    # def __init__(self):  在 pytest 中不可以使用__init__方法
    #     self.cc = 12345
    @pytest.mark.api
    def test_str(self):
        res = add('1', '2')
        assert res == '12'
    
    def test_int(self):
        res = add(1, 2)
        assert res == 3
    
    def test_list(self):
        res = add([1, 2], [3, 4])
        assert res == [1, 2, 3, 4]
    
  2. 启动测试

    • 命令行输入 pytest 会自动检索项目中所有的用例去执行 参数 -k “xx” 模糊匹配文件执行
    • 根目录新建 main.py 文件 右键运行脚本
    main.py
    import pytest
    pytest.main()
    
  3. 用户自定义标记

    可以根据不同类型的用例分成不同的种类.在用例多的情况下可以根据需求执行部分种类测试日志.
    配置
    创建配置文件,我这边创建在项目的根目录下 pytest.ini

    [pytest]
    markers =
       api : 接口测试
       ui : UI测试
       ut : 重试
       login : 登录测试
       ddt: 数据驱动测试
    

    在 markers 中key:value 形式的就是自定义的标记,名称:注释
    打标记
    @pytest.mark.标记名称来使用.

    @pytest.mark.tt
    def test_func():
    	print()
    

    使用

    • 命令行
    pytest -m 标记名称
    
    • 添加到配置文件中 pytest.ini 在配置文件中添加参数后.在命令行直接执行 pytest 会自动携带addopts中的参数
    [pytest]
    addopts = -m 标记名称
    
  4. 内置标记

    • skip 无条件跳过
    • skipif 满足条件跳过
    • xfail 预期失败
    • xfailif 满足条件预期失败
    • parametrize 参数化
      使用@pytest.mark.parametrize标记.参数1为字段,参数 2 为函数解析出来的嵌套列表
      @pytest.mark.parametrize('a, b, c', read_csv('/Users/nieminghua/Desktop/pycode/pythonProject/Apytest/data.csv'))
      def test_ddt(a, b, c):
      	assert int(a) + int(b) == int(c)
      
  5. 夹具-fixture

    我把fixture 理解成用例执行的前置操作和后置操作(钩子函数)
    比如,在对 web 网站进行测试时,前置必要条件需要先打开浏览器.测试完毕后关闭浏览器.

    • fixture 可以被 fixture 调用
    • 在fixture中的yield关键字可以返回值,只能返回 1 个值
    • 在使用 fixture 中参数scope可以控制夹具的作用范围
      1. function 默认值, 每个用例都会执行一遍
      2. class 每个类执行一遍
      3. module 每个模块执行一遍
      4. session 每个会话执行一遍
      5. package 每个包执行一遍
    如果不指定作用域,则每个用例执行都会单独去执行 fixture
    @pytest.fixture()
    def func2():
        # 前置操作
        print(datetime.now(), "func2用例开始执行")
        yield [1, 2, 3]
        # 后置操作
        print(datetime.now(), "func2用例执行结束")
    
    @pytest.mark.usefixtures("func",'func2')
    def test_1():
        print('test1')
    
    @pytest.mark.usefixtures("func",'func2')
    def test_2():
        print('test2')
    
    
    >>>
    Apytest/test_fixture.py::test_1 2025-06-05 18:32:58.075634 func1用例开始执行
    2025-06-05 18:32:58.077104 func2用例开始执行
    test1
    PASSED2025-06-05 18:32:58.078129 func2用例执行结束
    2025-06-05 18:32:58.078950 func1用例执行结束
    
    Apytest/test_fixture.py::test_2 2025-06-05 18:32:58.080741 func1用例开始执行
    2025-06-05 18:32:58.080920 func2用例开始执行
    test2
    PASSED2025-06-05 18:32:58.081668 func2用例执行结束
    2025-06-05 18:32:58.082254 func1用例执行结束
    

    指定作用域给 fixture 添加scope=“session”

    @pytest.fixture(scope='session')
    def func():
        # 前置操作
        print(datetime.now(), "func1用例开始执行")
        yield
        # 后置操作
        print(datetime.now(), "func1用例执行结束")
    
    
    @pytest.fixture(scope='session')
    def func2():
        # 前置操作
        print(datetime.now(), "func2用例开始执行")
        yield [1, 2, 3]
        # 后置操作
        print(datetime.now(), "func2用例执行结束")
    
    @pytest.mark.usefixtures("func",'func2')
    def test_1():
        print('test1')
    
    @pytest.mark.usefixtures("func",'func2')
    def test_2():
        print('test2')
    
    >>>
    Apytest/test_fixture.py::test_1 2025-06-06 14:54:55.729863 func1用例开始执行
    2025-06-06 14:54:55.730163 func2用例开始执行
    test1
    PASSED
    Apytest/test_fixture.py::test_2 test2
    PASSED2025-06-06 14:54:55.733253 func2用例执行结束
    2025-06-06 14:54:55.733882 func1用例执行结束
    
    

    对于一些更通用的 fixture 可以定义在conftest.py 文件中.给 fixture添加 autouse=True 参数,和 scope 指定作用域,这样所有的用例在作用域范围内都会自动关联到 fixture.(fixture同样可以嵌套使用)

    conftest.py
    在 func2 方法中调用了 func 所以即使 func 并没有 autouse=True,一样会被调用.
    @pytest.fixture(scope='session')
    def func():
        # 前置操作
        print(datetime.now(), "conftest_func1用例开始执行")
        yield
        # 后置操作
        print(datetime.now(), "conftest_func1用例执行结束")
    
    @pytest.fixture(autouse=True, scope='session')
    def func2(func):
        # 前置操作
        print(datetime.now(), "conftest_func2用例开始执行")
        yield [1, 2, 3]
        # 后置操作
        print(datetime.now(), "conftest_func2用例执行结束")
    
    >>>>
    Apytest/test_fixture.py::test_1 2025-06-06 16:29:25.996684 conftest_func1用例开始执行
    2025-06-06 16:29:25.997059 conftest_func2用例开始执行
    test1
    PASSED
    Apytest/test_fixture.py::test_2 test2
    PASSED2025-06-06 16:29:26.000212 conftest_func2用例执行结束
    2025-06-06 16:29:26.001231 conftest_func1用例执行结束
    
    
  6. 测试报告

    这里用到第三方插件allure

    	pip install allure-pytest
    

    allure下载地址官网

    添加启动命令

    pytest.ini
    [pytest]
    addopts =  --alluredir=allure-results --clean-alluredir
    

    加上这条命令后执行完会生成一个allure-results文件,里边放着 json 格式的测试日志.
    在这里插入图片描述
    之后在执行allure generate allure-results -o allure-report --clean命令. -o 参数为报告输出路径
    之后打开目录里的 index.html 就可以看到报告
    在这里插入图片描述

    可以在 main.py 文件中通过 os 模块来执行生成的动作,这样每次执行完用例会自动生成报告

    import pytest
    import os
    
    pytest.main()
    
    os.system("allure generate allure-results -o allure-report --clean")
    

    用例分类
    在报告中按功能给用例分类.

    • @allure.epic 项目名称
    • @allure.feature 模块名称
    • @allure.story 业务场景名称
    • @allure.title 标题
    • @allure.description 描述
    • @allure.setup 环境信息
    • @allure.testcase 测试用例链接
    • @allure.issue 缺陷链接
    • @allure.link 链接
    @allure.epic("hil测试")
    @allure.feature("故障注入")
    @allure.story("CVD")
    @allure.title("HTO")
    @allure.description("描述 11")
    @allure.testcase("https://www.baidu.com", "用例链接")
    @allure.issue("https://www.sogou.com", "缺陷链接", )
    @allure.link("链接")
    @pytest.mark.ut
    def test_01():
        assert 1 == 1
    
    
    @allure.epic("hil测试")
    @allure.feature("故障注入")
    @allure.story("CVD")
    @allure.title("低压")
    @allure.description("描述 11")
    @allure.testcase("www.baidu.com", "用例链接")
    @allure.issue("www.sogou.com", "缺陷链接", )
    @pytest.mark.ut
    def test_02():
        assert 1 == 2
    
    
    @allure.epic("hil测试")
    @allure.feature("故障注入")
    @allure.story("HTO")
    @allure.description("描述 11")
    @allure.testcase("www.baidu.com", "用例链接")
    @allure.issue("www.sogou.com", "缺陷链接", )
    @pytest.mark.ut
    def test_03():
        assert 1 == 1
    

    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2407402.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【数据分析】R版IntelliGenes用于生物标志物发现的可解释机器学习

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍流程步骤1. 输入数据2. 特征选择3. 模型训练4. I-Genes 评分计算5. 输出结果 IntelliGenesR 安装包1. 特征选择2. 模型训练和评估3. I-Genes 评分计…

Mobile ALOHA全身模仿学习

一、题目 Mobile ALOHA:通过低成本全身远程操作学习双手移动操作 传统模仿学习(Imitation Learning)缺点:聚焦与桌面操作,缺乏通用任务所需的移动性和灵活性 本论文优点:(1)在ALOHA…

Springboot社区养老保险系统小程序

一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,社区养老保险系统小程序被用户普遍使用,为方…

关键领域软件测试的突围之路:如何破解安全与效率的平衡难题

在数字化浪潮席卷全球的今天,软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件,这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下,实现高效测试与快速迭代?这一命题正考验着…

ABAP设计模式之---“简单设计原则(Simple Design)”

“Simple Design”(简单设计)是软件开发中的一个重要理念,倡导以最简单的方式实现软件功能,以确保代码清晰易懂、易维护,并在项目需求变化时能够快速适应。 其核心目标是避免复杂和过度设计,遵循“让事情保…

微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据

微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据 Power Query 具有大量专门帮助您清理和准备数据以供分析的功能。 您将了解如何简化复杂模型、更改数据类型、重命名对象和透视数据。 您还将了解如何分析列,以便知晓哪些列包含有价值的数据,…

USB Over IP专用硬件的5个特点

USB over IP技术通过将USB协议数据封装在标准TCP/IP网络数据包中,从根本上改变了USB连接。这允许客户端通过局域网或广域网远程访问和控制物理连接到服务器的USB设备(如专用硬件设备),从而消除了直接物理连接的需要。USB over IP的…

算法笔记2

1.字符串拼接最好用StringBuilder&#xff0c;不用String 2.创建List<>类型的数组并创建内存 List arr[] new ArrayList[26]; Arrays.setAll(arr, i -> new ArrayList<>()); 3.去掉首尾空格

听写流程自动化实践,轻量级教育辅助

随着智能教育工具的发展&#xff0c;越来越多的传统学习方式正在被数字化、自动化所优化。听写作为语文、英语等学科中重要的基础训练形式&#xff0c;也迎来了更高效的解决方案。 这是一款轻量但功能强大的听写辅助工具。它是基于本地词库与可选在线语音引擎构建&#xff0c;…

SAP学习笔记 - 开发26 - 前端Fiori开发 OData V2 和 V4 的差异 (Deepseek整理)

上一章用到了V2 的概念&#xff0c;其实 Fiori当中还有 V4&#xff0c;咱们这一章来总结一下 V2 和 V4。 SAP学习笔记 - 开发25 - 前端Fiori开发 Remote OData Service(使用远端Odata服务)&#xff0c;代理中间件&#xff08;ui5-middleware-simpleproxy&#xff09;-CSDN博客…

AI,如何重构理解、匹配与决策?

AI 时代&#xff0c;我们如何理解消费&#xff1f; 作者&#xff5c;王彬 封面&#xff5c;Unplash 人们通过信息理解世界。 曾几何时&#xff0c;PC 与移动互联网重塑了人们的购物路径&#xff1a;信息变得唾手可得&#xff0c;商品决策变得高度依赖内容。 但 AI 时代的来…

Unsafe Fileupload篇补充-木马的详细教程与木马分享(中国蚁剑方式)

在之前的皮卡丘靶场第九期Unsafe Fileupload篇中我们学习了木马的原理并且学了一个简单的木马文件 本期内容是为了更好的为大家解释木马&#xff08;服务器方面的&#xff09;的原理&#xff0c;连接&#xff0c;以及各种木马及连接工具的分享 文件木马&#xff1a;https://w…

深度学习习题2

1.如果增加神经网络的宽度&#xff0c;精确度会增加到一个特定阈值后&#xff0c;便开始降低。造成这一现象的可能原因是什么&#xff1f; A、即使增加卷积核的数量&#xff0c;只有少部分的核会被用作预测 B、当卷积核数量增加时&#xff0c;神经网络的预测能力会降低 C、当卷…

10-Oracle 23 ai Vector Search 概述和参数

一、Oracle AI Vector Search 概述 企业和个人都在尝试各种AI&#xff0c;使用客户端或是内部自己搭建集成大模型的终端&#xff0c;加速与大型语言模型&#xff08;LLM&#xff09;的结合&#xff0c;同时使用检索增强生成&#xff08;Retrieval Augmented Generation &#…

Reasoning over Uncertain Text by Generative Large Language Models

https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…

华硕a豆14 Air香氛版,美学与科技的馨香融合

在快节奏的现代生活中&#xff0c;我们渴望一个能激发创想、愉悦感官的工作与生活伙伴&#xff0c;它不仅是冰冷的科技工具&#xff0c;更能触动我们内心深处的细腻情感。正是在这样的期许下&#xff0c;华硕a豆14 Air香氛版翩然而至&#xff0c;它以一种前所未有的方式&#x…

云原生玩法三问:构建自定义开发环境

云原生玩法三问&#xff1a;构建自定义开发环境 引言 临时运维一个古董项目&#xff0c;无文档&#xff0c;无环境&#xff0c;无交接人&#xff0c;俗称三无。 运行设备的环境老&#xff0c;本地环境版本高&#xff0c;ssh不过去。正好最近对 腾讯出品的云原生 cnb 感兴趣&…

以光量子为例,详解量子获取方式

光量子技术获取量子比特可在室温下进行。该方式有望通过与名为硅光子学&#xff08;silicon photonics&#xff09;的光波导&#xff08;optical waveguide&#xff09;芯片制造技术和光纤等光通信技术相结合来实现量子计算机。量子力学中&#xff0c;光既是波又是粒子。光子本…

html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码

目录 一、&#x1f468;‍&#x1f393;网站题目 二、✍️网站描述 三、&#x1f4da;网站介绍 四、&#x1f310;网站效果 五、&#x1fa93; 代码实现 &#x1f9f1;HTML 六、&#x1f947; 如何让学习不再盲目 七、&#x1f381;更多干货 一、&#x1f468;‍&#x1f…

九天毕昇深度学习平台 | 如何安装库?

pip install 库名 -i https://pypi.tuna.tsinghua.edu.cn/simple --user 举个例子&#xff1a; 报错 ModuleNotFoundError: No module named torch 那么我需要安装 torch pip install torch -i https://pypi.tuna.tsinghua.edu.cn/simple --user pip install 库名&#x…