我已经写了一个小的辅助模块,它允许正是这一点:嵌套函数
例子:
def f(v1):
v2 = 1
def g(v3=2):
return v1 + v2 + v3 + 4
def h():
return 16
return g() + h() + 32
class C(object):
def foo(self):
def k(x):
return [ self, x ]
return k(3)
def m():
vm = 1
def n(an=2):
vn = 4
def o(ao=8):
vo = 16
return vm + an + vn + ao + vo
return o()
return n()
这些可以使用这种类型的代码进行单元测试:
import unittest
from nested import nested
class TestNested(unittest.TestCase):
def runTest(self):
nestedG = nested(f, 'g', v1=8, v2=1)
self.assertEqual(nestedG(2), 15)
nestedH = nested(f, 'h')
self.assertEqual(nestedH(), 16)
nestedK = nested(C.foo, 'k', self='mock')
self.assertEqual(nestedK(5), [ 'mock', 5 ])
nestedN = nested(m, 'n', vm=1)
nestedO = nested(nestedN, 'o', vm=1, an=2, vn=4)
self.assertEqual(nestedO(8), 31)
def main(argv):
unittest.main()
if __name__ == '__main__':
import sys
sys.exit(main(sys.argv))
小助手模块nested
看起来像这样:
import types
def freeVar(val):
def nested():
return val
return nested.__closure__[0]
def nested(outer, innerName, **freeVars):
if isinstance(outer, (types.FunctionType, types.MethodType)):
outer = outer.func_code
for const in outer.co_consts:
if isinstance(const, types.CodeType) and const.co_name == innerName:
return types.FunctionType(const, globals(), None, None, tuple(
freeVar(freeVars[name]) for name in const.co_freevars))
这个问题如何回答?是否有很好的解决方案来隔离单元测试的这些内部函数?即使没有从外部函数对象访问内部函数,也可能通过使用python模块解析器,ast或tokenizer来实现代码本身。显然这比编码更容易。 :-) – 2011-07-09 16:02:06
它回答了这个问题,因为没有*测试私人的实现细节。你可以依靠测试覆盖工具来告诉你,如果你测试的公共接口充分行使私有实现。 – SingleNegationElimination 2011-07-09 16:24:50