我想确保自定义函数在每次测试后运行。
现在,我有以下解决方案,其中涉及在每个unitTest模块中添加一个tearDown()
调用,这似乎是一个过大的选择。
import unittest
custom_descr = []
def do_something(test):
custom_descr.append('from '.format(test))
class Tester(unittest.TestCase):
def test_1(self):
do_something('test_1')
def tearDown(self):
for descr in custom_descr:
print(descr)
是否有可能按照(但是,以下操作无效):
,将所有描述集中在任何base_class中,从而避免在每个模块中编写tearDown()
。
import unittest
# in common_module.py
custom_descr = []
def do_something(test):
custom_descr.append('from '.format(test))
class Test_Base(unittest.TestCase):
def tearDown(self):
for descr in custom_descr:
print(descr)
# in module1.py
class Tester1(Test_Base):
def test_1(self):
do_something('test_1')
# in module2.py
class Tester2(Test_Base):
def test_2(self):
do_something('test_2')
答案 0 :(得分:1)
一个简单的解决方案是在每个测试模块的设置中添加self.tearDown = Test_Base.warn
,但这远不是我想要的-因为我仍然需要在每个模块中重复代码(但是很小)
import unittest
// in common_module.py
custom_descr = []
def do_something(test):
custom_descr.append('from '.format(test))
class Test_Base(unittest.TestCase):
def final(self):
for descr in custom_descr:
print(descr)
//in module1.py
class Tester1(Test_Base):
def setUp(self):
self.tearDown = Test_Base.final
def test_1(self):
do_something('test_1')
//in module2.py
class Tester2(Test_Base):
def setUp(self):
self.tearDown = Test_Base.final
def test_2(self):
do_something('test_2')