在python中重载unittest.testcase

前端之家收集整理的这篇文章主要介绍了在python中重载unittest.testcase前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图通过对unittest.testcase类进行子类化来创建自定义单元测试框架,但在处理__init__方法时似乎犯了一个错误.

我无法弄清楚为什么ComplexTest的构造函数在BasicTest中的构造函数之前没有被调用,并且异常似乎也与我的构造函数有关.

我是Python的新手,所以对于如何解决这个特定问题或我的用例的替代架构的任何帮助都将是非常受欢迎的.

谢谢!

1)test_framework.py

import unittest

class BasicTest(unittest.TestCase):
    def __init__(self,*args,**kwargs):
        print('BasicTest.__init__')
        super(unittest.TestCase,self).__init__(*args,**kwargs)

    def setUp(self):
        print('BasicTest.setUp')
        super(unittest.TestCase,self).tearDown()

    def tearDown(self):
        print('BasicTest.tearDown')
        super(unittest.TestCase,self).tearDown()


class ComplexTest(BasicTest):
    def __init__(self,**kwargs):
        print('ComplexTest.__init__')
        super(BasicTest,**kwargs)

    def setUp(self):
        print('ComplexTest.setUp')
        super(BasicTest,self).tearDown()

    def tearDown(self):
        print('ComplexTest.tearDown')
        super(BasicTest,self).tearDown()

2)test.py

import unittest
import test_framework

class TestValueFunctions(test_framework.ComplexTest):
    def __init__(self,**kwargs):
        print('TestValueFunctions.__init__')
        super(test_framework.ComplexTest,**kwargs)

    def setUp(self):
        print('TestValueFunctions.setUp')
        super(test_framework.ComplexTest,self).tearDown()
        self.value = 4711

    def tearDown(self):
        print('TestValueFunctions.tearDown')
        super(test_framework.ComplexTest,self).tearDown()

    def test_value(self):
        print('TestValueFunctions.test_value')
        self.assertEqual(self.value,4711)

if __name__ == '__main__':
    unittest.main()

3)当现在尝试运行它时,我看到下面的堆栈

TestValueFunctions.__init__
BasicTest.__init__
Traceback (most recent call last):
  File "D:\MyDev\ljs_app\trunk\examples\python\unittest\test.py",line 23,in <module>
    unittest.main()
  File "C:\Python27\lib\unittest\main.py",line 94,in __init__
    self.parseArgs(argv)
  File "C:\Python27\lib\unittest\main.py",line 149,in parseArgs
    self.createTests()
  File "C:\Python27\lib\unittest\main.py",line 155,in createTests
    self.test = self.testLoader.loadTestsFromModule(self.module)
  File "C:\Python27\lib\unittest\loader.py",line 65,in loadTestsFromModule
    tests.append(self.loadTestsFromTestCase(obj))
  File "C:\Python27\lib\unittest\loader.py",line 56,in loadTestsFromTestCase
    loaded_suite = self.suiteClass(map(testCaseClass,testCaseNames))
  File "D:\MyDev\ljs_app\trunk\examples\python\unittest\test.py",line 7,in __init__
    super(test_framework.ComplexTest,**kwargs)
  File "D:\MyDev\ljs_app\trunk\examples\python\unittest\test_framework.py",line 6,in __init__
    super(unittest.TestCase,**kwargs)
TypeError: object.__init__() takes no parameters

解决方法

确实你的init方法错误的.
class BasicTest(unittest.TestCase):
    def __init__(self,**kwargs)

应该:

class BasicTest(unittest.TestCase):
    def __init__(self,**kwargs):
        print('BasicTest.__init__')
        super(BasicTest,**kwargs)

这将在BasicTest的母类(TestCase)上调用__init__. setUp和tearDown也是如此:

class BasicTest(unittest.TestCase):
    ...
    def setUp(self):
        print('BasicTest.setUp')
        super(BasicTest,self).setUp()
原文链接:https://www.f2er.com/python/186112.html

猜你在找的Python相关文章