一,工作原理
- 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_开头的所有文件
|