Python热门单元测试框架对比:pytest和unittest还傻傻分不清楚?

上一篇 / 下一篇  2021-12-20 17:21:06 / 个人分类:自动化测试

前言
对于我们测试来说,做自动化测试需要编写测试用例,编写测试用例就会使用到单元测试模块,常见的python单元测试模块有unittest,pytest,nose等,但是听说过最多的也就属于pytest和unittest了,安静今天就通过这一篇文字简单的介绍下pytest和unittest的区别。
unittest
说起单元测试,安静立刻想到的就是unittest框架,为什么呢?因为安静刚开始学习的时候也是学习的unittest框架。unittest属于python的内置框架,被广泛的应用到各个项目中。unittest最早的时候是受到junit的启发,unittest支持多种自动化测试用例的编写,以及支持用例前置条件和后置数据清理功能也可以将多个测试用例放在测试集中生成测试报告。
pytest
pytest也是基于python的一个单元测试框架,是基于unittest的一个扩展框架,比unittest更加简洁,方便,pytest最主要可以支持第三方插件内容,可以更加高效的完成日常工作。而且pytest也支持unittest的代码框架内容。
区别
安静简单的从几个方面进行来说明pytest和unittest之间的区别内容吧。
断言方面
unittest的断言是根据自身携带的断言内容,提供了assertEqual,assertTrue,assertFlase等断言函数。
pytest的断言是根据Python自带的assert断言内容进行使用的。
import pytest
class Test_01:
def test_01(self):
a = 'anjing'
b = 'anjing'
assert a == b
def test_02(self):
'''
a是否存在b中
'''
a = 'anjing'
b = 'test_anjing'
assert a in b
def test_03(self):
'''
结果是否为true
'''
a = True
assert a
def test_04(self):
'''
结果是否为false
'''
a = False
assert a== False
if __name__ == '__main__':
pytest.main(['-sv'])
用例执行编写规则
unittest:可以使用自定义测试类内容,但必须继承unittest.TestCase的方法,测试用例需要以test的方法进行编写,用例的执行顺序是根据ASCII的顺序进行执行的。目前不能指定特定的用例顺序。unittest中提供了TestCase(测试用例),TestSuite(测试套件),TestLoder(加载用例),TextTestRunner(执行用例)等方法让测试用例更加方便编写,编写测试用例必须导入unittest模块,执行用例必须带有unittest.main()参数。
pytest:测试文件名必须以test_开头的py文件或者以*_test.py结尾的py文件,测试类名必须以Test开头,测试用例必须以test_开头。Pytest可以进行执行unittest的用例,pytest的执行顺序可以通过第三方插件进行定制顺序,默认是通过从上往下的顺序进行执行。pytest的执行用例不需要导入模块。执行用例可以通过命令行的形式进行执行。
前后置操作
unittest:可以通过setup()和tearDown()的方法来控制用例的前后置操作,并且每条用例执行前后都会执行前后置操作。通过setupclass()和teardownclass()方法来控制一个class下的所有用例都只执行1次前后置操作。
import unittest

class Test(unittest.TestCase):
def setUp(self):
print('unittest前置操作,每次执行用例都会进行执行')
def tearDown(self):
print('unittest后置操作,每次执行用例都会进行执行')
@classmethod
def setUpClass(cls):
print('所有用例只执行一次前置操作')
@classmethod
def tearDownClass(cls):
print('所有用例只执行一次后置操作')
def test_01(self):
print('用例01')
def test_02(self):
print('用例02')
def test_03(self):
print('用例03')

if __name__ == '__main__':
unittest.main()
通过执行后发现,setupclass下的操作只执行了用例操作,setup每条用例执行前都会执行。
pytest:模块级别的前后置操作(setup_module,teardown_function)表示模块下的测试用例只执行1次前后置操作。
import pytest
def setup_module():
print('每次用例执行前,只执行一次测试前置操作')
def teardown_module():
print('每次用例执行后,只执行一次测试后置操作')
def test01():
print('用例01')
def test02():
print('用例02')
def test03():
print('用例03')
if __name__ == '__main__':
pytest.main(['-vs'])
函数级别的前后置操作(setup_function,teardown_function)每次执行用例时都需要执行一次前后置操作。
类级别前后置操作(setup_class,teardown_class)表示类级别中测试用例只执行1次前后置操作。
方法级别前后置操作(setup_method,teardown_method)表示是在方法级别中每次都执行的用例的前后置操作。
从上面的多种setup和teardown可以看出来很方便我们进行编写测试用例,但是pytest不仅仅是这些。pytest中有个固件fixture通过装饰器进行使用,使用范围更加广泛,可以随意命名。可以在fixture中编写前后置操作,通过yield进行区别前置操作和后置操作内容。
import pytest
@pytest.fixture()
def login():

TAG:

 

评分:0

我来说两句