【发布时间】:2014-07-03 06:33:39
【问题描述】:
Python unittest 框架中的setUp() 和setUpClass() 有什么区别?为什么要以一种方法而不是另一种方法来处理设置?
我想了解在setUp() 和setUpClass() 函数以及tearDown() 和tearDownClass() 中完成了哪些设置。
【问题讨论】:
标签: python unit-testing python-unittest
Python unittest 框架中的setUp() 和setUpClass() 有什么区别?为什么要以一种方法而不是另一种方法来处理设置?
我想了解在setUp() 和setUpClass() 函数以及tearDown() 和tearDownClass() 中完成了哪些设置。
【问题讨论】:
标签: python unit-testing python-unittest
当您的班级中有多个测试方法时,差异就会显现出来。 setUpClass 和 tearDownClass 为全班运行一次; setUp 和 tearDown 在每个测试方法之前和之后运行。
例如:
class Example(unittest.TestCase):
@classmethod
def setUpClass(cls):
print("setUpClass")
def setUp(self):
print("setUp")
def test1(self):
print("test1")
def test2(self):
print("test2")
def tearDown(self):
print("tearDown")
@classmethod
def tearDownClass(cls):
print("tearDownClass")
当你运行这个测试时,它会打印:
setUpClass
setUp
test1
tearDown
.setUp
test2
tearDown
.tearDownClass
(点(.)是测试通过时unittest的默认输出。)观察setUp和tearDown出现在test1之前和之后和@ 987654332@,而setUpClass 和tearDownClass 只出现一次,在整个测试用例的开头和结尾。
【讨论】:
unittest 在其tearDown 顺利完成之前不会认为测试已通过。
setUp 和 tearDown 对每个 test 方法运行一次(在此示例中总共运行两次),但 setUpClass 和 tearDownClass 各运行一次。
unittest 框架中的setUp() 和setUpClass() 有什么区别?主要区别(如 Benjamin Hodgson 的回答中所述)是 setUpClass 仅在所有测试之前调用一次,而 setUp 在每次测试之前立即调用。 (注意:这同样适用于其他 xUnit 测试框架中的等效方法,而不仅仅是 Python 的 unittest。)
来自unittestdocumentation:
setUpClass()在单个类中的测试运行之前调用的类方法。 setUpClass 以类作为唯一参数调用,并且必须装饰为 classmethod():
@classmethod
def setUpClass(cls):
...
和:
setUp()为准备测试夹具而调用的方法。这是在调用测试方法之前立即调用的;除了 AssertionError 或 SkipTest,此方法引发的任何异常都将被视为错误而不是测试失败。默认实现什么都不做。
这部分问题还没有回答。根据我对 Gearon 回答的评论,setUp 方法适用于所有测试共有的夹具元素(以避免在每个测试中重复该代码)。我发现这通常很有用,因为删除重复(通常)可以提高可读性并减少维护负担。
setUpClass 方法适用于您宁愿只做一次的昂贵元素,例如打开数据库连接、打开文件系统上的临时文件、加载共享库以进行测试等。之前做这些事情每个测试都会大大降低测试套件的速度,因此我们只在所有测试之前执行一次。这会稍微降低测试的独立性,但在某些情况下是必要的优化。可以说,不应该在单元测试中做这样的事情,因为通常可以在不使用真实事物的情况下模拟数据库/文件系统/库/任何东西。因此,我发现很少需要setUpClass。但是,当需要测试上述示例(或类似示例)时,它很有用。
【讨论】: