我想确保自定义函数在每次测试后运行。
现在,我有以下解决方案,其中涉及在每个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')
最佳答案
一个简单的解决方案是在每个测试模块的设置中添加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')