一,工作原理
- TestCase:一个TestCase的实例就是一个测试用例,测试用例就是一个完整的测试流程,包括测试前准备环境的搭建(setUp),执行测试代码(test),以及测试后环境的还原(tearDown)
- TestSuite:测试用例集,多个测试用例集合在一起
- TestLoader: 用来加载TestCase到TestSuite中,其中有loadTestsFrom_()方法,就是从项目中寻找TestCase,创建实例,然后add到TestSuite中,再返回一个TestSuite实例
- TestRunner:测试集的运行器,可以在此基础上扩展子类TextTestRunner或者HTMLTestRunner生成不同样式的测试报告。
TestRunner语法:TextTestRunner(stream=None, description=None, verbosity=num)->stream:运行测试用例之后的结果要保存的文本文件流对象;description:对生成报告的描述文字;verbosity:日志显示等级,只有三个等级(0,1,2)
二,详解
1,unittest是python自带的框架,创建测试类时,需要继承unittest.testcase,
2,unittest中的五个特殊方法的使用场景和执行顺序
-
setUp(),test_xxx(),tearDown(),无论怎么调整,执行顺序不变
-
setUp(),主要是进行测试用例的资源初始化,放测试用例的前提条件
-
tearDown(),用于测试资源的释放
-
test_xxx(),测试用例的编写
-
@classmethod,注解的方法是类方法,不用创建对象也能用,在对象创建之前已经存在,随类一起进内存
-
setUpClass/tearDownClass:给当前单元测试类的所有用例进行初始化或者资源释放
setUp()和setUpClass的区别 - setUp()不需要@classmethod注解;setUpClass需要 - setUp()实例方法,需要创建对象再调用,setUpClass不需要 - setUp()在每一个测试用例执行之前运行一次,setUpClass在测试执行之前只执行一次
3,测试用例执行:
main():把所有测试用例执行一遍,测试用例执行顺序不能改变,按照用例的字母顺序执行;
testsuite:a,调用addtest,addtests()将指定的测试用例加载到测试集合中;b,使用testsuite的run()方法进行测试集合;c,run方法中的参数是testresult的对象:re=unittest.TestResult(),re中存储的是测试执行的结果
TestLoader:a,创建TestLoader对象,loader=unittest.TestLoader();b,使用loader的方法loadtestsfromName()将指定的测试用例加载到测试集合中,并返回给测试集合对象;loadtestsfromName()的参数比较灵活:可以是模块名,可以是模块名.类名,可以是模块中类的某个用例名;c,使用loader的discover方法,将指定的文件或者模块一次性加载
suite=unittest.discover(r’路径名’,pattern=‘运行的文件名’)
pattern可以使用匹配规则very_*.py:匹配以very_开头的所有文件