pytest单元测试框架(升华篇)
-----------------------------------
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.
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("花花")
运行结果:
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需要和运行的用例放到统一层。(confest.py作用于同级及以下的模块)并且不需要做任何的imprt导入的操作。
1)conftest中fixture的scope参数为session,那么所有的测试文件执行前执行一次
2)conftest中fixture的scope参数为module,那么每一个测试文件执行前都会执行一次conftest文件中的fixture
@pytest.fixture(scope='module', autouse=True)
3)conftest中fixture的scope参数为class,那么每一个测试文件中的测试类执行前都会执行一次conftest文件中的fixture
4)conftest中fixture的scope参数为function,那么所有文件的测试用例执行前都会执行一次conftest文件中的fixture
***conftest.py文件所在目录必须存在init.py文件
总结:
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')
运行后查看报告