如何防止django测试显示系统标准输出信息?

2021-05-13 13:25:44 发布

您现在位置:Python中文网/ 问答频道 /正文

我的问题是,由于我在运行单元测试时将日志记录添加到django应用程序中,所以所有日志消息都显示在控制台中。我用鼻子做试飞员。它通常的行为是捕获sys.stdout,只在测试失败时显示控制台输出并在最后显示。在

我曾经在运行测试时有这样的输出:

........
Ran 8 tests in 0.876s

OK
Destroying test database for alias 'default'...

这是我现在运行python manage.py test accounts时得到的输出:

^{pr2}$

当我在代码中添加了使用Python标准日志库的日志记录时,这种情况就开始发生了。我改了settings.py和{}。下面你可以看看我到底改变了什么。在

有人能帮我保持日志记录,但在运行测试时避免烦人的额外输出吗?在

添加到settings.py

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'console': {
            'class': 'logging.StreamHandler',
            'level': 'INFO',
            'stream': sys.stdout,
        },
    },
    'loggers': {
        '': {
            'handlers': ['console'],
            'level': 'INFO',
            'propagate': False,
        },
    },
}

添加到我的视图中

import logging

logger = logging.getLogger(__name__)

logger.info("log message")

django用来运行我的测试的命令

nosetests accounts/ --with-coverage --cover-package=accounts,keys, utils --cover-html --cover-erase --logging-filter='selenium' --verbosity=1

settings.py中的鼻试流道配置(工作时相同)

TEST_RUNNER = 'django_nose.NoseTestSuiteRunner'
NOSE_ARGS = [
    '--with-coverage',
    '--cover-package=accounts,keys, utils',
    '--cover-html',
    '--cover-erase',
    "--logging-filter='selenium'",
]
1条回答
网友
1楼 ·

您应该编写一个自定义测试运行器来禁用日志记录或更改级别。在

import logging

from django_nose import NoseTestSuiteRunner


class DisableLoggingNoseTestSuiteRunner(NoseTestSuiteRunner):
    """
    Disable the test runner log level below `logging.CRITICAL`.
    """
    def run_tests(self, *args, **kwargs):
        # Disable logging below critical
        logging.disable(logging.CRITICAL)
        super(DisableLoggingNoseTestSuiteRunner, self).run_tests(*args, **kwargs)

您还必须更改settings.py才能使用该测试运行程序。在

^{pr2}$

相关问题