目录
一、UnitTest介绍
UnitTest是目前市场应用主流的测试框架技术之一。其实只是用来做测试用例管理以及生成测试报告的一个模块而已。Junit和UnitTest是同一个家族的成员。
UnitTest是Python的自带官方库之一,所以不需要做任何的环境安装和部署。
UnitTest4大组件:
-
前置与后置条件:测试流程执行前必须要提前准备好的内容叫做前置条件。测试流程执行结束之后必须要执行的内容叫做后置条件。前置条件一般用于做初始化行为,后置条件一般用于做资源释放的相关操作。前后置条件不会关联到任何业务逻辑。setup与teardown是前置与后置。定义是通过函数来实现。分为函数级别和类级别的前后置。
-
测试用例:TestCase,在UnitTest中有自己的用例管理模式,包括排序、命名规则等相关。
-
断言机制:UnitTest封装有自己的断言函数。用于在断言时调用,所有的断言都可以通过self.的方式来进行断言的方法调用。
-
套件与运行器:套件TestSuite是用于做测试用例的管理的模块,便于整个测试流程的执行、冒烟测试、测试抽查、持续集成等需求的应用。运行器Runner是用于生成测试结果(测试报告),通过运行套件的测试用例来生成最终的测试结果
二、UnitTest语法规则
1. 创建一个UnitTest类,是通过继承的方式来实现,继承的对象固定写法是unittest.TestCase
2. 测试用例管理,测试用例在UnitTest中是以函数的形式来实现的。且用例的名称一定要用test开头,否则无法识别为测试用例
个人建议,所有用例命名的时候通过test_序号_名称来定义,例如def test_01_login
3. unittest的调用,一定是在main中调用unittest.main()的方式来实现。
4. 测试用例运行流程:
1. 获取所有的测试用例(包含test开头的函数)
2. 对测试用例进行排序,排序规则是固定的ascii规则进行排序。0-9,A-Z,a-z的顺序
5. 用例在运行过程中,如果没有报错,则表示通过,如果报错,不管是否为断言报错,都会判定为是失败的测试用例。一般不会轻易
添加try..except来进行用例内容的管理
6. UnitTest运行时控制台信息的顺序,不要纠结。因为UnitTest本身打印信息在控制台会出现有乱序的情况。
7. 用例的内容设计的时候,一定要尽可能减少彼此之间的关联性。每一个测试用例尽可能的独立化。更好确保其他的流程用例执行时不受到影响。
复杂业务流程下,可以通过用多个不同的文件,来管理不同的测试流程,
简单业务流程下,可以一个用例实现一个流程。
8. UnitTest支持普通函数的编写。需要注意命名的时候不要用test开头
9. UnitTest支持你进行源码的修改,修改用例排序规则,修改用例更名规则等。应用场景极少,基本不需要,做知识扩充了解即可。
# unittest导包
import unittest
# 创建UnitTest类
class UnitDemo(unittest.TestCase):
# 定义测试用例是通过def来完成
def test_02_login(self):
print('这是测试用例02')
def test_01_simple(self):
print('这是测试用例01')
def test_03_failed(self):
assert 1 == 2
def test_04_exception(self):
try:
print(1 / 0)
except:
print('嘿! 我报错啦~')
def test_05(self):
self.login()
# 普通函数,在UnitTest中不会被直接运行,有需要的时候通过调用函数来执行
def login(self):
print('这是login')
# UnitTest运行的固定写法
if __name__ == '__main__':
unittest.main()
三、UnitTest基本应用及前后置
前置与后置条件:
Unittest中前后置是固定写法,都是setup和teardown
1. 前后置只能够定义一个。
2. 前后置级别是函数级和类级
3. 函数级前后置条件,在每一个测试用例执行前后都会分别执行一次。
4. 类级别的前后置条件,在每一个类运行前后分别执行一次。
5. 不要在前后置中进行逻辑代码的编写,所有的初始化和资源释放,是不需要有逻辑的。
import unittest
class TestSimple(unittest.TestCase):
# 函数级
# 前置条件的定义
def setUp(self):
print('这是setup')
# 后置条件
def tearDown(self) -> None:
print('这是teardown')
# 类级别
@classmethod
def setUpClass(cls) -> None:
print('这是类级别的setup')
cls.a = 'hcc'
@classmethod
def tearDownClass(cls) -> None:
print('这是类级别的teardown')
# 定义测试用例是通过def来完成
def test_02_login(self):
print('这是测试用例02')
def test_01_simple(self):
print('这是测试用例01')
def test_03_failed(self):
assert 1 == 2
def test_04_exception(self):
try:
print(1 / 0)
except:
print('嘿! 我报错啦~')
def test_05(self):
self.login()
def test_06(self):
print(self.a)
# 普通函数,在UnitTest中不会被直接运行,有需要的时候通过调用函数来执行
def login(self):
print('这是login')
# unittest中是以class为大单位来管理测试用例的,所以一个py文件中可以有多个class
class TestSimple2(unittest.TestCase):
@classmethod
def setUpClass(cls) -> None:
pass
def test_01(self):
print('这是第二个测试类当中的测试用例01')
if __name__ == '__main__':
unittest.main()