我想在我的子类中添加两个变量,这些变量继承自unittest.testcase
像我一样:import unittest
class mrp_repair_test_case(unittest.TestCase):
def __init__(self, a=None, b=None, methodName=['runTest']):
unittest.TestCase.__init__(self)
self.a= a
self.b = b
def test1(self):
..........
.......
def runtest()
mrp_repair_test_case(a=10,b=20)
suite = unittest.TestLoader().loadTestsFromTestCase(mrp_repair_test_case)
res = unittest.TextTestRunner(stream=out,verbosity=2).run(suite)
我怎样才能接受这个: 我收到了这个错误:
ValueError: no such test method in ****<class 'mrp_repair.unit_test.test.mrp_repair_test_case'>:**** runTest
感谢
答案 0 :(得分:6)
乍一看,您似乎需要创建mrp_repair_test_case
的实例。您当前的行:
mrp_repair_test_case(a=10,b=20)
实际上并没有做任何事情。
尝试(未测试):
def runtest():
m = mrp_repair_test_case(a=10, b=20)
suite = unittest.TestLoader().loadsTestsFromTestCase(m)
res = unittest.TextTestRunner(stream=out, verbosity=2).run(suite)
这假设您已经将'out'设置为流。
编辑:
顺便问一下,你有没有理由不使用setUp方法来设置这些值?这将是正常的最佳做法。看一下loadTestsFromTestCase的文档,看起来它只接受Class本身而不是它的实例,这意味着你正在反对unittest模块的设计。
编辑2:
为了回应您的进一步信息,我实际上会在调用测试之前将您的uid和游标值分别设置在模块级别。我通常不是全球人的忠实粉丝,但如果我正确地理解你,那么这些价值将是A)只读B)对于同一个客户总是相同的,这避免了使用它们时的大多数正常陷阱。
编辑3:
要回答你的编辑,如果你真的想使用__init__
,你可能会,但你必须推出自己的loadsTestsFromTestCase替代品,可能还有你自己的TestSuite(你必须检查内部的方法)有用)。正如我上面所说,你将会反对模块的现有设计 - 如果你决定以这种方式进行测试,那么从头开始推出自己的解决方案可能比使用unittest更容易。 修改:刚刚检查过,您肯定必须推出自己的TestSuite版本,因为现有版本会为每个测试创建一个TestCaseClass的新实例。