我想确保自定义函数在每次测试后运行。

现在,我有以下解决方案,其中涉及在每个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')

08-19 20:35