Вопрос по generator, nose, unit-testing, python, nosetests – Изменить имена тестов, созданных генераторами носовых тестов

8

Нос имеетошибка - имена тестов, созданные генераторами, не кэшируются, поэтому ошибка выглядит так, как будто она произошла в последнем тесте, а не в самом тесте, где она не прошла. Я обошел это послерешение в обсуждении отчета об ошибках, но это работает только для имен, показанных на stdout, но не в отчете XML (--with-xunit)

from functools import partial, update_wrapper
def testGenerator():
    for i in range(10):
        func = partial(test)
        # make decorator with_setup() work again
        update_wrapper(func, test)
        func.description = "nice test name %s" % i
        yield func

def test():
    pass

Выход носа, как и ожидалось, что-то вроде

nice test name 0 ... ok
nice test name 1 ... ok
nice test name 2 ... ok
...

Но имена тестов в XML - это просто «testGenerator».

...<testcase classname="example" name="testGenerator" time="0.000" />...

How can I change this so that the personalized test names are shown on both stdout and XML output?

Я использую тесты носа версии 1.1.2 и Python 2.6.6

Как насчет создания набора тестов вместо этого? Apalala
@ Апалала спасибо, похоже, это может решить. Хотя я не могу найти какую-либо информацию о том, как использовать это в носу и как это смешивается с носом ». тестовое открытие. Не могли бы вы привести пример? M.K.
В прошлый раз, когда я пытался, нос не обнаруживал бы тесты, созданные во время выполнения. Apalala
Изменение «func .__ name __»; или 'func .__ doc __'; тоже не работает. M.K.

Ваш Ответ

4   ответа
4

добавление плагина который реализует descriptionTest

from nose.plugins import Plugin
class CustomName(Plugin):
    "Change the printed description/name of the test."
    def describeTest(self, test):
         return "%s:%s" % (test.test.__module__, test.test.description)

Затем вам придетсяустановить этот плагини включите его в вызове Nose.

1

testGenerator.__name__

Вы также можете использовать это вместо

testGenerator.compat_func_name

Если у вашего тестового класса есть аргументы, я рекомендую их каррировать, а также каррировать с параметром set_setup. Использование лямбды экономит на импорте, и я думаю, что это немного чище. Например,

from nose.tools import with_setup

def testGenerator():
    for i in range(10):
        func = with_setup(set_up, tear_down)(lambda: test(i))

        func.description = "nice test name %s" % i
        testGenerator.compat_func_name = func.description

        yield func

def test(i):
    pass

def set_up():
    pass

def tear_down():
    pass
Error: User Rate Limit Exceeded
1

testGenerator.__name__ = "nice test name %s" % i

Пример:

from functools import partial, update_wrapper
def testGenerator():
    for i in range(10):
        func = partial(test)
        # make decorator with_setup() work again
        update_wrapper(func, test)
        func.description = "nice test name %s" % i
        testGenerator.__name__ = "nice test name %s" % i
        yield func

def test():
    pass

Это приведет к именам, которые вы хотите.

<testsuite name="nosetests" tests="11" errors="0" failures="0" skip="0"><testcase classname="sample" name="nice test name 0" time="0.000" />
Error: User Rate Limit Exceeded
0

import nose

class Test(object):
    CURRENT_TEST_NAME = None

    def test_generator(self):
        def the_test(*args,**kwargs):
            pass

        for i in range(10):
            # Set test name
            Test.CURRENT_TEST_NAME = "TestGenerated_%i"%i
            the_test.description = Test.CURRENT_TEST_NAME

            # Yield generated test
            yield the_test,i

    # Set the name of each test generated
    test_generator.address = lambda arg=None:(__file__, Test, Test.CURRENT_TEST_NAME)

что заставит имя хорошо отображаться в PyUnit.

Generated test names

Похожие вопросы