【python】pytest测试用例学习

一、Pytest简介

pytest是基于单元测试框架unittest的升级版本,相比与unittest支持跨多个文件前置,支持丰富的报告,简练的断言,丰富的插件功能,
pytest分模块运行前置和后置操作分为2种方式,支持经典的setup、setdown和fixture;以及标记参数mark、断言、常用插件

二、pytest文件和函数命令规则

1: 测试文件以 test_ 开头 & 结尾
2: 测试类以 Test 开头,并且不能带有init方法
3: 测试函数&方法以 test开头
4: 断言使用 assert

三、pytest文件的三种运行方式

1.命令行运行
–help
–collect-only 查看可执行用例
test_*.py 执行测试文件
–maxfail=2 最大报错
-m 运行mark标记用例
–setup-show 用例执行的夹具
pytest -k “add” 执行所有测试用例名中含有“add”的用例
pytest - s 打印测试用例中print语句
pytest -v 增加打印细节
pytest - x 一旦发现失败用例,停止运行
pytest -maxfail=2 当测试遇到两条失败,立刻停止运行
pytest -m “标签名” 给测试用例加标签

2.“”“配置文件”“”
pytest.ini
[pytest]
markers=自定义mark:标签名
addopts= 运行时参数(可添加多个命令行参数,空格分隔,所有参数与命令行一致)
3.“”“main方法”“”
import pytest

if name == ‘main’:
pytest.main([“-vs”])

 # file_name: test_abc.py
 import pytest # 引入pytest包
 def test_a(): # test开头的测试函数
     print("------->test_a")
     assert 1 # 断言成功
 def test_b():
     print("------->test_b")
     assert 0 # 断言失败
 if __name__ == '__main__':
        pytest.main("-s  test_abc.py") # 调用pytest的main函数执行测试

四、pytest的框架结构

模块级: setup_module/teardown_module 模块始末,全局的(优先最高)
函数级: setup_function/teardown_function 只对函数用例生效(不在类中)
类级:   setup_class/teardown_class 只在类中前后运行一次(在类中)
方法级: setup_method/teardown_methond 开始于方法始末(在类中)
方法级: setup/teardown 运行在调用方法的前后

五、Fixture

1、简介:
fixture区别于unnitest的传统单元测试(setup/teardown)有显著改进:
  1.有独立的命名,并通过声明它们从测试函数、模块、类或整个项目中的使用来激活。
  2.按模块化的方式实现,每个fixture都可以互相调用。
  3.fixture的范围从简单的单元测试到复杂的功能测试,可以对fixture配置参数,或者跨函数function,类class,模块module或整个测试session范围。

2、fixture的作用范围(scope)
fixture里面有个scope参数可以控制fixture的作用范围:session>module>class>function
-function:每一个函数或方法都会调用
-class:每一个类调用一次,一个类中可以有多个方法
-module:每一个.py文件调用一次,该文件内又有多个function和class
-session:是多个文件调用一次,可以跨.py文件调用,每个.py文件就是module
3.fixture参数详解

fixture(scope=‘function’,params=None,autouse=False,ids=None,name=None)

fixture里面有个scope参数可以控制fixture的作用范围,scope有4个级别参数:“function”(默认)、“class”、“module”、"session。

params:一个可选的参数列表,它将导致多个参数调用fixture功能和所有测试使用它。

autouse:如果True,则为所有测试激活fixture func可以看到它。如果为False则显示需要参考来激活fixture。

ids:每个字符串id的列表,每个字符串对应于params这样他们就是测试ID的一部分。如果没有提供ID它们将从params自动生成。

name:fixture的名称。这默认为装饰函数的名称。如果fixture在定义它的统一模块中使用,夹具的功能名称将被请求夹具的功能arg遮蔽,解决这个问题的一种方法时将装饰函数命令"fixture_“然后使用”@pytest.fixture(name=’’)"

六、数据驱动

Pytest 测试框架的数据驱动是由 pytest 自带的***pytest.mark.parametrize()***来实现的。

方法:
     parametrize(argnames, argvalues, indirect=False, ids=None, scope=None)
 常用参数:
     argnames:参数名
     argvalues:参数对应值,类型必须为list或元组
                当参数为一个时格式:[value]
                当参数个数大于一个时,格式为:[(param_value1,param_value2.....),(param_value1,param_value2.....)]
      ids:使用的数据组别名,类型必须为list或元组,与argvalues一一对应,用于使用的数据组的展示
 使用方法:
     @pytest.mark.parametrize(argnames,argvalues)
     ️ 参数值为N个,测试方法就会运行N次

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值