如何确保自定义函数在每个Python单元测试执行后运行?

时间:2019-07-16 05:15:12

标签: python python-unittest

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

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

1 个答案:

答案 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')