python单元测试用unittest框架,核心是继承unittest.TestCase类,测试方法名必须以test_开头,通过unittest.main()运行;常用断言包括assertEquals、assertTrue、assertRaises等,支持setUp/tearDown进行测试前准备与清理。

Python单元测试用unittest写,核心是继承unittest.TestCase,把测试逻辑写在以test_开头的方法里,然后调用unittest.main()运行。
写一个基础测试类
每个测试文件通常对应一个被测模块。先导入要测的函数或类,再定义测试类,继承unittest.TestCase:
示例:测试一个加法函数
import unittest <p>def add(a, b): return a + b</p><p>class TestAdd(unittest.TestCase): def test_add_positive_numbers(self): self.assertEqual(add(2, 3), 5)</p><pre class="brush:php;toolbar:false;">def test_add_negative_numbers(self): self.assertEqual(add(-1, -1), -2) def test_add_zero(self): self.assertEqual(add(0, 5), 5)
立即学习“Python免费学习笔记(深入)”;
注意:测试方法名必须以test_开头,否则不会被自动识别为测试用例。
常用断言方法
unittest提供多种assert*方法验证预期结果:
-
self.assertEqual(a, b):检查a是否等于b(推荐用于大多数值比较) -
self.assertTrue(x)/self.assertFalse(x):检查布尔表达式 -
self.assertIs(a, b):检查是否为同一对象(如None、单例) -
self.assertIn(item, container):检查元素是否在列表/字典/字符串中 -
self.assertRaises(TypeError, func, arg):检查调用是否抛出指定异常
例如测试异常:
def divide(a, b): if b == 0: raise ValueError("Cannot divide by zero") return a / b <p>def test_divide_by_zero(self): with self.assertRaises(ValueError): divide(5, 0) </p>
设置与清理(setUp / tearDown)
如果多个测试需要共用资源(如临时文件、数据库连接、实例对象),可用setUp和tearDown方法:
-
setUp():每个测试方法运行前自动执行(适合初始化) -
tearDown():每个测试方法运行后自动执行(适合清理)
例如:
class TestCalculator(unittest.TestCase): def setUp(self): self.calc = Calculator() # 每个测试前创建新实例 <pre class="brush:php;toolbar:false;">def test_add(self): self.assertEqual(self.calc.add(2, 3), 5) def test_subtract(self): self.assertEqual(self.calc.subtract(5, 2), 3) # tearDown 可留空,或关闭文件、清空缓存等
立即学习“Python免费学习笔记(深入)”;
运行测试的几种方式
有三种常用启动方式:
- 在脚本末尾加
if __name__ == '__main__': unittest.main(),直接运行文件 - 命令行进入项目根目录,执行
python -m unittest test_module(不带.py) - 用
-v参数获得详细输出:python -m unittest -v test_calc
还可以运行单个测试方法:python -m unittest test_calc.TestCalculator.test_add