当前位置: 首页>编程语言>正文

01 pytest基础-十分钟之自动化

本文内容概览

01 pytest基础-十分钟之自动化,第1张

pytest能实现的功能(简介)

  1. 自动发现测试用例:pytest会自动查找项目中以test_test开头的文件、以Test开头的类和以test_test开头的函数,并执行它们作为测试用例。

  2. 灵活的测试用例编写:pytest允许使用简洁的语法编写测试用例,可以使用函数、类和装饰器等方式组织测试代码。这使得测试用例的编写更加灵活和易于维护。

  3. 丰富的断言库:pytest提供了丰富的断言方法,用于验证测试结果是否符合预期。这些断言方法包括比较运算符、容器操作、异常处理等。使用这些断言方法可以编写清晰、简洁的断言语句。

  4. 参数化测试(parametrize):pytest支持参数化测试,可以通过一次编写多个测试用例,并使用不同的参数进行测试。这样可以减少冗余的代码,提高测试的覆盖率。

  5. 丰富的插件生态系统:pytest具有一个活跃的插件生态系统,可以通过安装插件来扩展其功能。这些插件可以用于生成测试报告、集成持续集成工具、模拟网络请求等。插件的使用可以根据需求定制测试框架的功能。

  6. 并发执行测试:pytest支持并发执行测试用例,可以提高测试的效率。这对于大型项目和长时间运行的测试套件特别有用。

  7. 集成其他测试工具:pytest可以与其他测试工具(如Selenium、Mock等)进行集成,方便进行更复杂的测试场景。这样可以扩展pytest的功能,满足特定的测试需求。

安装

pip3 install -U pytest
01 pytest基础-十分钟之自动化,第2张

显示 Successfully installed 代表安装好了
注意
如果安装过慢可以更改下载源来增加下载安装速度 这里可以更改安装源(这里以清华源为例)
https://mirrors.tuna.tsinghua.edu.cn/help/pypi/

python -m pip install --upgrade pip
pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple

更改后再执行 pip 安装命令安装即可

默认用例执行规则

pytest会自动查找项目中以test_test开头的文件、以Test开头的类和以test_test开头的函数,并将它们作为测试用例执行。
pytest会递归地搜索项目目录及其子目录中的测试文件,找到所有符合命名规则的测试用例

总结就是

  1. 文件要以test_*.py*_test.py命名
  2. 测试类要以Test开头
  3. 函数要以 test 或者 test_开头

pycharm编写运行第一个测试用例

"""编写的第一个case"""
def test_01_case():
    print("test_01_case")


class TestFirstCase(object):    
    def test_class_case(self):
        print("test_class_case")

    def no_test_case(self):
        print("no_test_case")


def no_test_case2():
    print("no_test_case")

01 pytest基础-十分钟之自动化,第3张

可以看到按照规则写的pytest收集到并执行了

运行方式

执行的三种方式

  1. 命令行执行
pytest + 执行参数
py.test + 执行参数
python -m pytest + 执行参数

这里插播介绍两个常用的执行参数 (-s -v)

允许直接打印测试函数中的输出

pytest -s  # 允许直接打印测试函数中的输出
01 pytest基础-十分钟之自动化,第4张

显示详细的测试结果信息

pytest -v  
01 pytest基础-十分钟之自动化,第5张
  1. py文件中调用
import pytest

if __name__ == '__main__':
    pytest.main(["执行参数"])  // 列表中放执行参数 
  1. pycharm 中执行 (需要设置好pycharm的Default test runner)


    01 pytest基础-十分钟之自动化,第6张

    01 pytest基础-十分钟之自动化,第7张

运行规则

执行文件夹下所有的case


pytest  /指定目录
# 或者 cd到这个目录下执行 pytest
pytest 

执行单个py文件

# 指定 pytest 具体的文件名
pytest test_xxx.py 

按节点nodeid运行(每个case代表一个节点nodeid)

  1. pytest 文件名::class::test_case (类的方式编写的case)
  2. pytest 文件路径/文件名::class::test_case
  3. pytest 文件名::test_case (函数方式编写的case)
  4. pytest 文件路径/文件名::test_case
 # 执行类中具体的某一条case   
 pytest test_01_first_case.py::TestFirstCase::test_class_case                           
 # 执行类
 pytest test_01_first_case.py::TestFirstCase
# 执行某一条case
pytest test_01_first_case.py::test_01_case
# 执行文件
pytest test_01_first_case.py

按关键词运行

# 运行名称包含 case但是不包含class的用例
pytest -k "case and not class" -v   

按照标记运行

这里不具体讲 等到学习mark的时候再展开说

# 这样就会运行 指定标记的case
pytest -m 标记 

断言

断言用于验证测试结果是否符合预期
pytest的断言比较简单 直接使用python内置的 assert 即可进行断言
基本语法

assert 表达式 
  1. 当表达式结果为 True时 断言通过
  2. 当表达式为False时 断言失败 本条case算是失败 然后继续跑后续的case
def test_01_case():
    print("test_01_case")
    assert 1 != 1   # 这里 1 != 1  结果是False 所以这条case失败

这里 1 != 1 结果是False 所以这条case失败


01 pytest基础-十分钟之自动化,第8张

一些常用的断言

  1. assert a >= b
  2. assert a == b
  3. assert len(a) == len(b) # 容器类的断言(如列表、字典)
  4. assert a in b

附加知识:对于抛出的异常pytest允许使用pytest.raises装饰器来断言代码是否抛出了预期的异常
例如,pytest.raises(ZeroDivisionError)用于断言被装饰的代码块是否抛出了0作为被除数的异常。


https://www.xamrdz.com/lan/5my1994745.html

相关文章: