断言定义
编写代码时,我们总是会做出一些假设,断言就是用于在代码中捕捉这些假设,可以将断言看作是异常处理的一种高级形式。断言表示为一些布尔表达式,程序员相信在程序中的某个特定点该表达式值为真。可以在任何时候启用和禁用断言验证,因此可以在测试时启用断言,而在部署时禁用断言。同样,程序投入运行后,最终用户在遇到问题时可以重新启用断言。
#断言 编写代码时,我们总是会做出一些假设,断言就是用于在代码中捕捉这些假设,可以将断言看作是异常处理的一种高级形式。
#assert代表断言,假设断言的条件为真,如果为假诱发AssertionError
#assert 断言的条件,错误的提升
a = 0
assert a,"a is false"
print(a)
#上面的断言代码类似下面的if语句
a = 1
if not a:
raise AssertionError("a is false")
print(a)
断言的优势
1、编写防御性代码
2、起到特殊的注释作用
unittest工作原理:
TestCase(测试用例): 所有测试用例的基类,它是软件 测试中最基本的组成单元。一个test case就是一个测试用例,是一个完整的测试流程,包括测试前环境的搭建setUp,执行测试代码(run),以及测试后环境的还原(tearDown)。测试用例是一个完整的测试单元,可以对某一问题进行验证。
TestSuite(测试套件):多个测试用例test case集合就是TestSuite,TestSuite可以嵌套TestSuite
TestLoder:是用来加载 TestCase到TestSuite中,其中有几个 loadTestsFrom_()方法,就是从各个地方寻找TestCase,创建他们的实例,然后add到TestSuite中,再返回一个TestSuite实例
TextTestRunner:是来执行测试用例的,其中的run(test)会执行TestSuite/TestCase中的run(result)方法。
TextTestResult:测试结果会保存到TextTestResult实例中,包括运行了多少用例,成功与失败多少等信息
TestFixture:又叫测试脚手,测试代码的运行环境,指测试准备前和执行后要做的工作,包括setUp和tearDown方法
unittest使用模板:
import unittest
#unittest使用的方法
class OurTest(unittest.TestCase):
"""
继承编写测试的基础类
"""
def setUp(self):
"""
类似于类的init方法,在测试执行之初制动执行,通常用来做测试数据的准备
"""
def test_add(self):
"""
具体测试的方法,使用testcase编写具体测试的方法,函数名称必须以test开头
函数当中的内容通常是获取预期值,和运行结果值
然后对两个值进行断言
"""
def tearDown(self):
"""
类似类的del方法,用来回收测试的环境
"""
if __name__ == "__main__":
unittest.main()#一种单例模式,unittest.main()的作用是:将一个单元测试模块变为可直接运行的测试脚本
Unittest小栗子:
import unittest
#举个栗子
class OurTest(unittest.TestCase):
"""
继承编写测试的基础类
"""
def setUp(self):
"""
类似于类的init方法,在测试执行之初制动执行,通常用来做测试数据的准备
"""
self.a = 1 #测试使用的参数1
self.b = 1 #测试使用的参数2
self.result = 3 #预期的结果
def test_add(self):
"""
具体测试的方法,使用testcase编写具体测试的方法,函数名称必须以test开头
函数当中的内容通常是获取预期值,和运行结果值
然后对两个值进行断言
unittest模块已经封装好了更多的断言方法
"""
run_result = self.a + self.b
self.assertEqual(run_result,self.result,"self.a+self.b不等于3") #断言两个值相等
def tearDown(self):
"""
类似类的del方法,用来回收测试的环境
"""
if __name__ == "__main__":
unittest.main()
Unitest常用的断言方法
断言方法 | 断言描述 |
---|---|
assertEqual(arg1, arg2, msg=None) | 验证arg1=arg2 |
assertNotEqual(arg1, arg2, msg=None) | 验证arg1 != arg2 |
assertTrue(expr, msg=None) | 验证expr是true,如果为false |
assertFalse(expr,msg=None) | 验证expr是false,如果为true |
assertIs(arg1, arg2, msg=None) | 验证arg1、arg2是同一个对象 |
assertIsNot(arg1, arg2, msg=None) | 验证arg1、arg2不是同一个对象 |
assertIsNone(expr, msg=None) | 验证expr是None |
assertIsNotNone(expr, msg=None) | 验证expr不是None |
assertIn(arg1, arg2, msg=None) | 验证arg1是arg2的子串 |
assertNotIn(arg1, arg2, msg=None) | 验证arg1不是arg2的子串 |
assertIsInstance(obj, cls, msg=None) | 验证obj是cls的实例 |
assertNotIsInstance(obj, cls, msg=None) | 验证obj不是cls的实例 |