1,Unittest 简介
Unittest是Python自带的单元测试框架,不仅适用于单元测试,还可用于Web、Appium、接口自动化测试用例的开发与执行。该测试框架可组织执行测试用例,并且提供丰富的断言方法,判断测试用例是否通过,并最终生成测试结果。
unittest的基本使用方法:
1.用import unittest导入unittest模块
2.定义一个继承自unittest.TestCase 的测试用例类
3.定义setUp和 tearDown,在每个测试用例前后做一些辅助工作。
4.定义测试用例,名字以test开头。
5.一个测试用例应该只测试一个方面,测试目的和测试内容应很明确。主要是调用 assertEqual、assertRaises 等断言方法判断程序执行结果和预期值是否相符。
6.调用unittest.main()启动测试
7.如果测试未通过,会输出相应的错误提示。如果测试全部通过则不显示任何东西, 这时可以添加-v参数显示详细信息。
2,Unittest 核心要素
- TestCase:即测试用例,Unittest提供testCase类来编写测试用例,一个TestCase的实例就是一个测试用例。一条测试用例就是一个完整的测试流程,包括测试前准备环境的搭建(setUp),执行测试代码(run),以及测试后环境的还原(tearDown),通过运行一条测试用例,可以对某一个问题进行验证。
- TestFixture:即测试固件,用于测试用例环境的搭建和销毁。在测试步骤执行前需要为该测试用例准备环境(SetUp),如启动app或打开浏览器,测试步骤执行后需要恢复环境 (TearDown),如关闭app或浏览器,这时候就需要用到Fixture,使代码更简洁。
- TestSuite:即测试套件,把需要执行的测试用例集合在一起就是TestSuite。使用TestLoader来加载TestCase到TestSuite中。
- TextTestRunner:即测试执行器,用于执行测试用例。该模块中提供run方法执行TestSuite中的测试用例,并返回测试用例的执行结果,如运行的用例总数、用例通过数、用例失败数。
- report:即测试报告。unittest框架没有自带的用于生成测试报告的模块或接口,需要使用第三方的扩展模块HTMLTestRunner。
3 , Unittest 断言
断言在自动化测试脚本中是很重要的内容,只有设置正确合适的断言才能获取正确的测试结果。Unittest框架提供了自己的断言方法,如下:
断言方法 | 判断内容 |
---|
assertEqual(a, b) | 判断 a == b | assertNotEqual(a, b) | 判断 a != b | assertTrue(x) | 判断 bool(x) is True | assertFalse(x) | 判断 bool(x) is False | assertIs(a, b) | 判断 a is b | assertIsNot(a, b) | 判断 a is not b | assertIsNone(x) | 判断 x is None | assertIsNotNone(x) | 判断 x is not None | assertIn(a, b) | 判断 a in b | assertNotIn(a, b) | 判断 a not in b | assertIsInstance(a, b) | 判断 isinstance(a, b) | assertNotIsInstance(a, b) | 判断 not isinstance(a, b) |
注意:
- 如果断言成功则该条测试用例通过,断言失败则该条测试用例执行失败,且会抛出AssertionError错误。
- 以上提供的断言方法中,都有一个msg参数,默认为None。如果msg参数有对应的值,则断言失败后该msg的值会作为失败信息返回,如 assertEqual(a, b, msg="a与b不相等!")
|