0

我有一个产生测试用例的基类。类注册测试的具体实现。由于鼻子只支持通过测试函数(不是类)的产量生成测试,我想要一个应用必要的函数包装的类装饰器。

注意:我需要 yield 测试用例的原因是测试类需要做一些不能在 setUp 中运行的初始化。

下面是一个显示预期行为的最小示例,但是,它仅在make_generator装饰器位于当前模块中时才有效 - 当我将其移动到单独的模块时,不会产生任何测试。谁能告诉我为什么会这样?

def make_generator(cls):
    """returns a function that instantiates ``cls`` and yields tests. """
    def generator():
        obj = cls()
        for t in obj:
            yield t

    generator.__name__ = 'test_%s' % cls.__name__
    return generator


def register(func):
    """Set _check attr of ``func``. """
    func._check = True
    return func


class BaseMixin(object):

    def __init__(self):
        """Register check handlers. """
        self.check_handlers = []
        attrs = (attr for attr in dir(self) if not attr.startswith('__'))
        for attr in attrs:
            func = getattr(self, attr)
            if getattr(func, '_check', False):
                self.check_handlers.append(attr)

    def __iter__(self):
        """Generate tests for registered handlers. """
        # do stuff
        args = []
        for check in self.check_handlers:
            func = getattr(self, check)
            yield func, args


@make_generator
class ConcreteTest(BaseMixin):

    @register
    def check_foobar(self, args):
        assert False
4

1 回答 1

0

我发现如果我将make_generator装饰器移动到不同的模块,为什么没有产生任何测试。

make_generator 将返回一个函数,该函数的__module__属性将是在其中make_generator定义的模块 - 这不是被测试的模块,因此鼻子不会运行生成的测试函数。

如果我设置__module__返回函数的属性,它可以正常工作::

def make_generator(cls):
"""returns a function that instantiates ``cls`` and yields tests. """
def generator():
    obj = cls()
    for t in obj:
        yield t

generator.__name__ = 'test_%s' % cls.__name__
# set to the same module as test case so that nose runs it
generator.__module__ = cls.__module__
return generator
于 2013-08-22T07:33:10.970 回答