拿我们之前的代码举个例子,在 TestMath 测试类中我们写了4个测试用例,对应了 Math 类的4个方法。但是做测试的都知道,对于每个功能我们不可能只用一条用例去覆盖,我们要充分考虑各种情况从各种角度甚至刁钻的角度来验证我们的程序的功能以及健壮度等情况。比如在 test_add() 中,我们要考虑 0 0 相加,正正相加,正负相加,负负相加,甚至传入非数值类型等情况(这只是举个例子,别太纠结...),那难道我们要为每种情况一条测试用例吗?
答案是否定的,和开发一样,我们要尽可能的提高我们测试用例的复用性,下面我们来采用一些方法来提高测试用例的复用性:
1. 先看下之前的测试用例: ↓↓↓↓↓↓
import unittest
from class_13.math import Math
class TestMath(unittest.TestCase):
"""Math的测试类"""
def test_add(self): # 测试加法
result = Math(15, 30).add()
expect = 45
self.assertEqual(result, expect)
print('加法用例执行完毕!')
2. 很明显,这种测试用例的复用性是很低的,我们需要改造下测试用例:↓↓↓↓↓↓
import unittest
from class_13.math import Math
c