目录
测试代码
测试函数
python标准库中的模块unittest提供了代码测试工具。
- 单元测试用于核实函数的某个方面没有问题
- 测试用例是一组单元测试,用于核实函数在各种情形下的行为都符合要求。良好的测试用例考虑了函数可能收到的各种输入,包含针对所有这些情形的测试。全覆盖测试用例包含一整套单元测试,涵盖了各种可能的函数使用方式。
可通过的测试
要为函数编写测试用例,可先导入模块unittest以及要测试的函数,再创建一个继承unittest.TestCase的类,并编写一系列方法对函数行为的不同方面进行测试。
import unittest
from name_function import get_formatted_name
class NameTestCase(unittest.TestCase):
"""能够正确地处理姓名吗?"""
def test_name(self):
formatted_name = get_formatted_name('A','B')
self.assertEqual(formatted_name,'A B')
unittest.main()
- 以test_打头的方法将自动运行
- unittest.main()运行文件中的测试
不能通过的测试
如果检查的条件没有错误,而测试未通过,说明编写的代码有错误,应该对代码进行修改。
测试类
各种断言方法
下表为常用的6个断言方法,使用这些方法可以核实返回的值等于或不等于预期的值、返回的值为True或False、返回的值在列表或不在列表中。只能在unittest.TestCase()的类中使用这些方法。
方法 | 用途 |
---|---|
assertEqual(a,b) | 核实a==b |
assertNotEqual(a,b) | 核实a!=b |
assertTrue(x) | 核实x为True |
assertFalsex) | 核实x为False |
assertIn(item,list) | 核实item在list中 |
assertNotIn(item,list) | 核实item不在list中 |
setUp()方法
python会先运行setUp方法,再运行以test_打头的方法。这样可以避免重复的创建对象。
import unittest
from survey import AnonymousSurvey
class TestAnonymousSurvey(unittest.TestCase):
"""针对AnonymousSurvey类的测试"""
def setUp(self):
"""创建一组调查对象以及一组答案,供测试方法使用"""
question = "what language did you first learn to speak?"
self.my_survey = AnonymousSurvey(question)
self.responses = ['A','B','C']
def test_store_single_response(self):
"""测试单个答案"""
self.my_survey.store_response(response[0])
self.assertIn(self.response[0],self.my_survey.responses)
def test_store_three_response(self):
"""测试3个答案"""
for response in self.responses:
self.my_survey.store_response(response)
for response in self.responses:
self.assertIn(self.response,self.my_survey.responses)
unittest.main()
运行完测试用例时,每完成一个单元测试,python都打印一个字符:测试通过打印一个句点;测试引发错误时打印一个E;测试导致断言失败时打印一个F。