python每日一练之单元测试

官方文档地址:https://docs.python.org/zh-cn/3.7/library/unittest.html#class-and-module-fixtureshtml

1、关于一些基本概念

Test fixture 官方文档把这个词翻译成“测试脚手架”,我的理解,是启动测试前的准备工做,根据使用API的不一样,实如今每一个用例执行前/后、类执行前/后、模块启动前/后的动做。python

测试用例 检查特定输入的数据时的响应。并发

Test suite测试套件 用例执行的顺序框架

Test runner 执行和输出测试结果的组件less

2、基本实例

 

 

 

TestEx继承测试基类TestCase,test告诉测试运行者这个方法表示测试。不符合此命名规则的方法,执行测试时不会运行。__init__方法会执行三次,而且都是在测试用例执行前。测试

3、命令行执行

后面再补充ui

4、test fixture

用例执行前/后须要执行的指令。spa

1.setUp()命令行

每一个用例执行前都会执行,若是此方法有问题,将会被测试框架视为这个测试失败,用例方法和tearDown不会被执行。若是setUp成功运行,无论用例方法结果如何,tearDown()都会被执行。线程

2.tearDown()

用例执行结束后运行。

 

 

3.setUpClass()

当测试套件遇到来自新类的测试时,将调用前一个类的tearDownClass()(若是有),而后调用这个新类的setupClass()。

若是在setUpClass期间引起异常,则不会运行该类中的测试,也不会运行tearDownClass。跳过的类将不会运行setUpClass或tearDownClass。若是该异常是SkipTest异常,则该类将被报告为已跳过而不是错误。

4.tearDownClass()

运行完全部测试后

     下面例子没有执行setUpClass(),为啥

 

 

 

5.setupModules()

与前面相似,不过这里指的是模块。若是setUpModule中引起了异常,则模块中的任何测试都不会运行,而tearDownModule也不会运行。若是该异常是SkipTest异常,则该模块将被报告为已跳过而不是错误。

6.tearDownModules

运行完全部的测试后

5、装饰器

1.无条件跳过@unittest.skip(reason) 无条件跳过用例或者测试类,并输出缘由

2.@unittest.skipIf(condition, reason) condition为真时跳过,输出缘由

2.@unittest.skipUnless(condition, reason) condition为假时跳过,输出缘由

3.@unittest.expectedFailure 把测试标记为失败,若是测试不经过,会被认为测试成功,反之失败。

4.exception unittest.skipTest(reason) 引起此异常以跳过一个测试。存疑~

6、test suit

1.test_suit.addTest()实现执行顺序

test_suit=unittest.TestSuit()

tests=[TestClass(‘testcase1),...]

test_suit.addTests(tests) # 添加case列表,或者addTest(TestClass(‘testcase1))逐个添加。非test开头的方法也可添加进来做为测试用例使用。

runner=unittest.TextTestRunner()

runner.run(test_suit)

2.unittest.TestLoader() 暂未展开

suit.addTests(unittest.TestLoader().loadTestsFromCase(TestClass)) 加载testCase,测试方法按照test_后面的字母顺序执行

7、HTMLReport

# 测试套件

suite = unittest.TestSuite()

# 测试用例加载器

loader = unittest.TestLoader()

# 把测试用例加载到测试套件中

suite.addTests(loader.loadTestsFromTestCase(TestStringMethods))

 

# 测试用例执行器

runner = HTMLReport.TestRunner(report_file_name='test',  # 报告文件名,若是未赋值,将采用“test+时间戳”

                               output_path='report',  # 保存文件夹名,默认“report”

                               title='测试报告',  # 报告标题,默认“测试报告”

                               description='无测试描述',  # 报告描述,默认“测试描述”

                               thread_count=1,  # 并发线程数量(无序执行测试),默认数量 1

                               thread_start_wait=3,  # 各线程启动延迟,默认 0 s

                               sequential_execution=False,  # 是否按照套件添加(addTests)顺序执行,

                               # 会等待一个addTests执行完成,再执行下一个,默认 False

                               # 若是用例中存在 tearDownClass ,建议设置为True,

                               # 不然 tearDownClass 将会在全部用例线程执行完后才会执行。

                               # lang='en'

                               lang='cn'  # 支持中文与英文,默认中文

                               )

# 执行测试用例套件

runner.run(suite)

8、经常使用API

未完待续

相关文章
相关标签/搜索