1、pytest规则
pytest编写用例,需遵循一下规则:
1.测试文件名必须以test_开头(如:test_adv.py)
2.测试方法必须以test_开头,t必须小写
3.测试类必须以Test_开头,且T需要大写,如T为小写则该类下的所有测试方法均不会被执行,测试类,不能有__init__(self)初始化的方法-----测试用例的类不需要初始化
4.pytest测试用例函数可以脱离类,可以直接使用函数的形式(测试用例的py文件直接写为函数)------unittest中无此用法
5.需执行的测试用例方法不能使用@classmethod装饰器,否则无法加载到该用例!!!
6.运行脚本时注意关闭抓包工具及代理,否则可能导致运行过程中报错SSLerror ,握手错误。
2、conftest.py文件
conftest.py文件是pytest框架中非常重要的东西,它可以实现fixture对象自对应并自动应用跨模块、跨文件的应用操作,从而使fixture对象的定义更加灵活。相当于将一些用例的前置操作整理到conftest文件中,执行用例时如有需要则直接调用即可。
conftest.py的作用域:在一个测试工程中可以存在多个conftest.py文件,如果存在多个,则一般会对所有的conftest.py文件中的对象进行提取,提取出所有模块共用的对象,然后在根工程目录下放一个conftest.py,这样该文件就起到了全局作用。
如果每个子目录下都存放有conftest.py文件,则该文件中的对象作用范围只能够在当前层级及该层级的子目录有效。
@pytest.fixture()里面没有传入参数时,那么默认scope = ‘function’,也就是此时的级别是function,scope参数类型有以下几个类型:
1.scope = ‘session:所有测试.py文件执行前都会执行一次conftest文件中的fixture
2.scope = ‘module’:每一个测试.py文件执行前都会执行一次conftest文件中的fixture
3.scope = ‘class:每一个测试文件中的测试类执行前都会执行一次conftest文件中的fixture
4.scope = ‘function':所有文件的测试用例执行前都会执行一次conftest文件中的fixture
@pytest.fixture(scope='session')
ps:
1.function与class的区别:两者如果作用于测试函数,则两者是等价的,都表示创建全新的固件对象;但如果针对的是类中测试方法,function表示每个测试方法创建全新的对象,而class表示测试类中的所有用例共用一个固件对象。
2.session与module的区