unittest与pytest的区别-CSDN博客
阿里云国内75折 回扣 微信号:monov8 |
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6 |
Unittest vs Pytest
主要从用例编写规则、用例的前置和后置、参数化、断言、用例执行、失败重运行和报告这几个方面比较unittest和pytest的区别:
用例编写规则
用例前置与后置条件
断言
测试报告
失败重跑机制
参数化
用例分类执行
如果不好看可以看下面表格
总体来说unittest用例格式复杂兼容性无插件少二次开发方便。pytest更加方便快捷用例格式简单可以执行unittest风格的测试用例无须修改unittest用例的任何代码有较好的兼容性。pytest插件丰富比如flask插件可用于用例出错重跑还有xdist插件可用于设备并行执行效率更高。
实例演示
讲了七大区别总要演示一下具体实例用事实说话。
前后置区别
这里抽用例前置与后置的区别来讲先看unittest的前后置使用
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
|
运行结果
从结果上得知 三个方法的逻辑优先级 setUp()&tearDown() < setUpClass()&tearDownClass() < setUpModule()&tearDownModule()
接下来看pytest的前后置
1、我们都知道在自动化测试中都会用到前后置pytest 相比 unittest 无论是前后置还是插件等都灵活了许多还能自己用 fixture 来定义。
首先了解一下用例运行前后置级别如下
1.模块级全局的整个模块开只运行一次优先于测试用例。
2.类级别定义在类里面只针对此类生效。类似unittest的cls装饰器
3.函数级只对函数生效类下面的函数不生效。
4.方法级定义在类里面每个用例都执行一次
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
|
运行结果
2、这是原始用法下面看使用FixtureFixture 其实就是自定义 pytest 执行用例前置和后置操作首先创建 conftest.py 文件 规定此命名导入 pytest 模块运用 pytest.fixture 装饰器默认级别为函数级
其它用例文件调用即可如下定义一个函数继承 conftest.py 文件里的 login 函数即可调用
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
运行结果
3、扩展用法多个自定义函数和全局级别展示全局的比如用于登录获取到token其他用例模块就不需要再登录了
1 2 3 4 5 6 7 8 9 10 |
|
运行结果
细心的人应该可以知道测试用例2并没有调用login函数因为前置设置的是共享模式类似全局函数。
参数化区别
参数化应用场景一个场景的用例会用到多条数据来进行验证比如登录功能会用到正确的用户名、密码登录错误的用户名、正确的密码正确的用户名、错误的密码等等来进行测试这时就可以用到框架中的参数化来便捷的完成测试。
参数化 就是数据驱动思想即可以在一个测试用例中进行多组的数据测试而且每一组数据都是分开的、独立的。
unittest参数化其实是ddt叫数据驱动。
pytest数据驱动就是参数化使用@pytest.mark.parametrize
1.先看unittest如何进行参数化
1 2 3 4 5 6 7 8 9 |
|
运行结果
2.pytest中参数化的用法
在测试用例的前面加上
@pytest.mark.parametrize("参数名",列表数据)
参数名用来接收每一项数据并作为测试用例的参数。
列表数据一组测试数据。
@pytest.mark.parametrize("参数1,参数2",[(数据1数据2),(数据1数据2)])
示例:
@pytest.mark.parametrize("a,b,c",[(1,3,4),(10,35,45),(22.22,22.22,44.44)])
def test_add(a,b,c):
res = a + b
assert res == c
实例
1 2 3 4 5 6 7 |
|
运行结果
这可能是B站最详细的pytest自动化测试框架教程整整100小时全程实战